博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
QT之设计部件背景色
阅读量:6210 次
发布时间:2019-06-21

本文共 1341 字,大约阅读时间需要 4 分钟。

一、使用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 。參数不匹配时。调色板效果是不会显示的。

你可能感兴趣的文章
ARCH模型
查看>>
关于JSONP以及跨域相关
查看>>
用TCP穿透NAT(TCP打洞)的实现
查看>>
软件工程本质性工作的四大难题--没有银弹
查看>>
AngularJS--及其他js框架对比
查看>>
mysql索引总结(2)-MySQL聚簇索引和非聚簇索引
查看>>
从强制解包看 Swift 的设计
查看>>
volley2--volley的使用和架构
查看>>
洛谷P1420 最长连号
查看>>
from String value ('{}'); no single-String constructor/factory
查看>>
【转】redis 消息队列发布订阅模式spring boot实现
查看>>
Bootstrap 栅格系统 理解与总结
查看>>
Java主线程等待所有子线程执行完毕再执行解决办法(转)
查看>>
17秋 软件工程 团队第五次作业 Alpha Scrum9
查看>>
DIV和SPAN的区别
查看>>
Jodd
查看>>
处理 Windows 虚拟机的计划内维护通知
查看>>
学习是一件艰苦的事情
查看>>
redis资料收集
查看>>
pm2使用心得
查看>>