QColor color = QColorDialog::getColor(Qt::white, this);
QPalette pal = ui->pushButton_BackGroundColor->palette();
pal.setColor(QPalette::Button,color);
ui->pushButton_BackGroundColor->setPalette(pal);
ui->pushButton_BackGroundColor->setAutoFillBackground(true);
ui->pushButton_BackGroundColor->setFlat(true);
// 直接設置成顏色
QPalette pal = ui->pushButton_5->palette();
pal.setColor(QPalette::Button,Qt::blue);
ui->pushButton_5->setPalette(pal);
ui->pushButton_5->setAutoFillBackground(true);
ui->pushButton_5->setFlat(true);
字體顏色的設置一般時(shí)以下兩種方案:
(1)屬于QWidget子類(lèi)的一些控件
可以直接使用樣式表,例如label->setStyleSheet("color:white");
(2)不屬于QWidget子類(lèi)的控件
可以考慮設置其前景色,例如各種ViewtreeWidgetItem->setForeground(0,QBrush(QColor(Qt::white)));
-------------------------------------------------------------------------------------------------
我要實(shí)現的效果:
正常狀態(tài)下:黑底(背景色),白字(前景色),圓角,向外凸起;
鼠標停留:背景和前景都反色;
鼠標按下:背景色變?yōu)榈{色,向內凹陷。
代碼:
ui->pushButton_GoToProcess->setStyleSheet("QPushButton{background-color:black;\
color: white; border-radius: 10px; border: 2px groove gray;\
border-style: outset;}"
"QPushButton:hover{background-color:white; color: black;}"
"QPushButton:pressed{background-color:rgb(85, 170, 255);\
border-style: inset; }"
);
結果:
(1)正常狀態(tài)

(2)鼠標停留

(3)鼠標按下

-------------------------------------------------------------------------------------------------
如果要對多個(gè)按鈕實(shí)現同樣的效果,只要將setStyleSheet里的字符串定義成QString,后面其他按鈕直接調用這個(gè)QString就好了。
定義:
QString button_style="QPushButton{background-color:black;\
color: white; border-radius: 10px; border: 2px groove gray;\
border-style: outset;}"
"QPushButton:hover{background-color:white; color: black;}"
"QPushButton:pressed{background-color:rgb(85, 170, 255);\
border-style: inset; }";
調用:
ui->pushButton_Save->setStyleSheet(button_style);
-------------------------------------------------------------------------------------------------
對于按鈕如果想設置為圖片,則最好使用添加icon,這樣的話(huà)位置比較合適,如果是使用setStyleSheet還需要對位置進(jìn)行設置(直接設置會(huì )發(fā)現位置有點(diǎn)偏)。另外要加上一句:
聯(lián)系客服