QT中设置背景颜色
//**layout大小設(shè)置方法:reSize(QSize(600,?600));就ok了,這個(gè)是設(shè)置主窗口的大小,layout會(huì)自動(dòng)適應(yīng)主窗口的。**//
QWidget是所有用戶(hù)界面對(duì)象的基類(lèi),這意味著可以用同樣的方法為其它子類(lèi)控件改變背景顏色。
Qt中窗口背景的設(shè)置,下面介紹三種方法。
1.使用QPalette
2.使用Style Sheet
3.繪圖事件
一般我不用QSS設(shè)置窗口背景,也不建議使用。(這里是對(duì)于窗口而,如果是子部件當(dāng)然可以)。因?yàn)榇翱谑褂肣SS設(shè)置背景之后,若子部件不使用同樣的方式來(lái)設(shè)置,默認(rèn)則會(huì)繼承父窗口的樣式。
使用QPalette
使用QPalette來(lái)設(shè)置背景色
m_pWidget = new QWidget(this); m_pWidget->setGeometry(0, 0, 300, 100); QPalette pal(m_pWidget->palette());pal.setColor(QPalette::Background, Qt::black); //設(shè)置背景黑色 m_pWidget->setAutoFillBackground(true); m_pWidget->setPalette(pal); m_pWidget->show();使用Style Sheet
使用樣式表來(lái)設(shè)置背景色,可以參考:Qt Style Sheets文檔
注意樣式表記得加上color否則會(huì)提示無(wú)效樣式表
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子類(lèi)化一個(gè)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); }繪圖事件
重寫(xiě)paintEvent,使用QPainter來(lái)繪制背景。
****************************設(shè)置背景圖片
//設(shè)置背景圖片//QPixmap pixmap(":/png/background.png");QPixmap pixmap(":/png/back640-480.png");QPalette palette;palette.setBrush(backgroundRole(), QBrush(pixmap));setPalette(palette);?
設(shè)置背景顏色
//設(shè)置stack背景色,用于測(cè)試
//stack->setFixedSize(QPixmap(":/png/profile.PNG").width(),480); stack->setAutoFillBackground(true);; QPalette p=stack->palette(); p.setColor(QPalette::Window,QColor("blue")); stack->setPalette(p);?
設(shè)置layout的邊欄
?
setMargin(0)
?
一、使用QT樣式表設(shè)計(jì)部件外觀
樣式表使用文本描寫(xiě)敘述,能夠使用QApplication::setStyleSheet()函數(shù)將其設(shè)置到整個(gè)應(yīng)用程序上。也能夠使用QWidget::setStyleSheet()函數(shù)將其設(shè)置到一個(gè)指定的部件上。
?
?
1、使用代碼設(shè)置樣式表
假設(shè)希望對(duì)指定部件設(shè)置背景色。能夠加入例如以下代碼:
?
//設(shè)置pushButton的背景為黃色
ui->pushButton->setStyleSheet("background:yellow");
//設(shè)置horizontalSlider的背景為藍(lán)色
ui->horizontalSlider->setStyleSheet("background:blue");
......
假設(shè)希望對(duì)相同的部件都設(shè)置相同的背景色,能夠在它們的父部件上設(shè)置樣式表,代碼例如以下:
setStyleSheet("QPushButton{background:yellow}QSlider{background:blue}");
採(cǎi)用這樣的方式,再往主窗體上加入的全部QPushButton和QSlider部件的背景色都會(huì)改為這里指定的顏色。
?
?
?
2、在QT設(shè)計(jì)師界面設(shè)置樣式表
?
假設(shè)須要設(shè)置同類(lèi)部件為同一指定顏色。則在主界面上右擊,選則“改變樣式表”。加入代碼:
QPushButton{
}
注意光標(biāo)留在第一個(gè)大括號(hào)后面,然后點(diǎn)擊“加入顏色”下拉框選擇顏色。這樣就能夠設(shè)置同樣控件指定背景色了。
?
?
二、使用調(diào)色板QPalette類(lèi)設(shè)計(jì)部件外觀
QPalette類(lèi)基本的顏色角色例如以下:
?
//首先要調(diào)用setAutoFillBackground(true)來(lái)設(shè)置窗口自己主動(dòng)填充背景
ui->pushButton->setAutoFillBackground(true);
//獲取pushbutton的調(diào)色板
QPalette p = ui->pushButton->palette();
//設(shè)置button文本顏色為紅色
p.setColor(QPalette::ButtonText, Qt::red);
//設(shè)置button背景色為綠色
p.setColor(QPalette:Active, QPalette::Button, Qt::green);
//改動(dòng)后的調(diào)色板
ui->pushButton->setPalette(p);
?
//設(shè)置lineEdit不可用
ui->lineEdit->setDisabled(true);
QPalette p2 = ui->lineEdit->palette();
//設(shè)置lineEdit不可用時(shí)背景色為藍(lán)色
p2.setColor(QPalette::Disabled, QPalette::Base, Qt::Blue);
ui->lineEdit->setPalette(p2);
?
提示:
對(duì)于不同的Qt控件,當(dāng)我們用QPalette設(shè)置其背景/前景顏色時(shí),須要指定不同的顏色角色參數(shù)。
比方:對(duì)于QTextEdit,設(shè)置其背景時(shí)要使用QPalette::Base ; 對(duì)于QWidget則使用QPalette::Window 。參數(shù)不匹配時(shí)。調(diào)色板效果是不會(huì)顯示的。
總結(jié)
- 上一篇: Qt窗体布局思路
- 下一篇: linux 中的 nohup 命令(设置