QT之設計部件背景色
阿新 • • 發佈:2017-08-13
ack 主界面 disable tracking avi blue line popu 基本
......
假設希望對相同的部件都設置相同的背景色,能夠在它們的父部件上設置樣式表,代碼例如以下:
}
//首先要調用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樣式表設計部件外觀
樣式表使用文本描寫敘述,能夠使用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();
//設置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之設計部件背景色