QT之設計部件背景色


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




免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM