QT中设置背景颜色
//**layout大小設置方法:reSize(QSize(600,?600));就ok了,這個是設置主窗口的大小,layout會自動適應主窗口的。**//
QWidget是所有用戶界面對象的基類,這意味著可以用同樣的方法為其它子類控件改變背景顏色。
Qt中窗口背景的設置,下面介紹三種方法。
1.使用QPalette
2.使用Style Sheet
3.繪圖事件
一般我不用QSS設置窗口背景,也不建議使用。(這里是對于窗口而,如果是子部件當然可以)。因為窗口使用QSS設置背景之后,若子部件不使用同樣的方式來設置,默認則會繼承父窗口的樣式。
使用QPalette
使用QPalette來設置背景色
m_pWidget = new QWidget(this); m_pWidget->setGeometry(0, 0, 300, 100); QPalette pal(m_pWidget->palette());pal.setColor(QPalette::Background, Qt::black); //設置背景黑色 m_pWidget->setAutoFillBackground(true); m_pWidget->setPalette(pal); m_pWidget->show();使用Style Sheet
使用樣式表來設置背景色,可以參考:Qt Style Sheets文檔
注意樣式表記得加上color否則會提示無效樣式表
color:rgb(85, 170, 0) m_pWidget = new QWidget(this); m_pWidget->setGeometry(0, 0, 300, 100); m_pWidget->setStyleSheet("background-color:black;"); m_pWidget->show();如果從QWidget子類化一個Widget,為了能夠使用樣式表則需要為自定義Widget提供paintEvent事件。void CustomWidget::paintEvent(QPaintEvent *event) { Q_UNUSED(event);QStyleOption opt; opt.init(this); QPainter p(this); style()->drawPrimitive(QStyle::PE_Widget, &opt, &p, this); }繪圖事件
重寫paintEvent,使用QPainter來繪制背景。
****************************設置背景圖片
//設置背景圖片//QPixmap pixmap(":/png/background.png");QPixmap pixmap(":/png/back640-480.png");QPalette palette;palette.setBrush(backgroundRole(), QBrush(pixmap));setPalette(palette);?
設置背景顏色
//設置stack背景色,用于測試
//stack->setFixedSize(QPixmap(":/png/profile.PNG").width(),480); stack->setAutoFillBackground(true);; QPalette p=stack->palette(); p.setColor(QPalette::Window,QColor("blue")); stack->setPalette(p);?
設置layout的邊欄
?
setMargin(0)
?
一、使用QT樣式表設計部件外觀
樣式表使用文本描寫敘述,能夠使用QApplication::setStyleSheet()函數將其設置到整個應用程序上。也能夠使用QWidget::setStyleSheet()函數將其設置到一個指定的部件上。
?
?
1、使用代碼設置樣式表
假設希望對指定部件設置背景色。能夠加入例如以下代碼:
?
//設置pushButton的背景為黃色
ui->pushButton->setStyleSheet("background:yellow");
//設置horizontalSlider的背景為藍色
ui->horizontalSlider->setStyleSheet("background:blue");
......
假設希望對相同的部件都設置相同的背景色,能夠在它們的父部件上設置樣式表,代碼例如以下:
setStyleSheet("QPushButton{background:yellow}QSlider{background:blue}");
採用這樣的方式,再往主窗體上加入的全部QPushButton和QSlider部件的背景色都會改為這里指定的顏色。
?
?
?
2、在QT設計師界面設置樣式表
?
假設須要設置同類部件為同一指定顏色。則在主界面上右擊,選則“改變樣式表”。加入代碼:
QPushButton{
}
注意光標留在第一個大括號后面,然后點擊“加入顏色”下拉框選擇顏色。這樣就能夠設置同樣控件指定背景色了。
?
?
二、使用調色板QPalette類設計部件外觀
QPalette類基本的顏色角色例如以下:
?
//首先要調用setAutoFillBackground(true)來設置窗口自己主動填充背景
ui->pushButton->setAutoFillBackground(true);
//獲取pushbutton的調色板
QPalette p = ui->pushButton->palette();
//設置button文本顏色為紅色
p.setColor(QPalette::ButtonText, Qt::red);
//設置button背景色為綠色
p.setColor(QPalette:Active, QPalette::Button, Qt::green);
//改動后的調色板
ui->pushButton->setPalette(p);
?
//設置lineEdit不可用
ui->lineEdit->setDisabled(true);
QPalette p2 = ui->lineEdit->palette();
//設置lineEdit不可用時背景色為藍色
p2.setColor(QPalette::Disabled, QPalette::Base, Qt::Blue);
ui->lineEdit->setPalette(p2);
?
提示:
對于不同的Qt控件,當我們用QPalette設置其背景/前景顏色時,須要指定不同的顏色角色參數。
比方:對于QTextEdit,設置其背景時要使用QPalette::Base ; 對于QWidget則使用QPalette::Window 。參數不匹配時。調色板效果是不會顯示的。
總結
- 上一篇: Qt窗体布局思路
- 下一篇: QT信号与槽(自定义带参数的信号)