Qt第十二章 样式表

样式表

1.样式表

盒子模型

在这里插入图片描述

2.选择器

  • 样式表语法,选择器{属性1:值;属性2:值;}
  • 如果只有单个属性,分号可以不加

选择器类型

选择器示例描述
通用选择器*匹配所有控件
类型选择器QPushButton匹配给定的控件,包括子类
类选择器.QPushButton匹配给定的控件,不包括子类
属性选择器QPushButton[flat=“false”]匹配给定类型中符合[属性]的控件
ID选择器QPushButton#closeButton匹配给定类型,且对象名为closeButton的控件
子孙对象选择器QDialog QPushButton匹配给定类型的子孙控件
子对象选择器QDialog>QPushButton匹配给定类型的直接子控件
辅助[子控件]选择器QComboxBox::drop-down复杂对象子控件
伪状态选择器QPushButton:hover控件的特定状态下的样式
并集选择器QPushButton,QLineEdit若干基础选择器可以写一起,逗号隔开
QPushButton[down = "false"]{color:yellow;background:red}
QLabel[text = "TextLabel"]{color:red}

同时在UI和文件代码里设置样式表会冲突,只会生效ui里设置的

伪状态选择器Pseudo-State

QPushButton:hover{color:red}
状态描述
:disabled控件禁用
:enabled控件启用
:focus控件获取输入焦点
:hover鼠标在控件上悬停
:pressed鼠标按下
:checked控件被选中
:unchecked~
:indetetminate控件部分被选中
:open控件打开
:closed~
:on控件可以切换,且处于on状态
:off~
!对以上状态的否定

3.控件示例

QLabel#label{
 font-family: "微软雅黑";
font-size: 20px;
 font-style: italic;
color: rgb(239,204,180);
border-image:url("C:/Users/PVer/Pictures/Resource/派蒙.jpeg")
}

QPushButton{
/*上右下左设置padding间距*/
padding:20px 0px 0px 50px;
border: 3px solid black;
border-radius: 10px;
background-color:red;
}

QLineEdit{
border-top:2px solid yellow;
border-right:2px dotted black;
border-top-left-radius:10px;
border-left:3px solid black;
}

QLabel#label_2{
background-image:url("C:/Users/PVer/Pictures/Resource/xiaoku.png");
background-repeat:no-repeat;
background-position:left top;
}

QLabel#label_2:hover{
background-color:green;
}

QPushButton:pressed{
background-color:orange;
}

QCheckBox::indicator{
background-color:grey;
border-radous:5px;
}

QCheckBox::indicator:checked{
background-color:black;
}

QCheckBox::indicator:!checked:hover{
background-color:green
}

在这里插入图片描述

4

.细节、注意事项

继承自QWidget的类,设置qss样式表没有效果,需要重写paintEvent

 void CustomWidget::paintEvent(QPaintEvent *)
 {
     QStyleOption opt;
     opt.initFrom(this);
     QPainter p(this);
     style()->drawPrimitive(QStyle::PE_Widget, &opt, &p, this);
 }

而且必须使用Q_OBJECT宏

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yerennuo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值