一、使用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 。參數不匹配時。調色板效果是不會顯示的。