QT 自定义控件继承QWidget设置样式无效的办法

本文解决了QWidget自定义控件无法应用CSS样式的问题,并详细解释了如何通过重载paintEvent()来实现样式显示。此外,还介绍了如何设置QPushButton在hover状态下的边框高亮效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题1:
自定义控件继承QWidget, 想要设置QWidget CSS样式,发现无论是在Designer界面还是在代码中设置setStyleSheet均不起作用(style书写没有问题)

解决办法:
css样式需要通过paint才能正常绘制到控件表面,而QWidget的paintEvent()是空的,这就要求我们在继承QWidget的时候重载paintEvent(),如下所示
这里写图片描述
这里写图片描述

问题2:
想要设置QPushButton在hover的时候边框高亮,使用如下样式
QPushButton
{
border-width:1px
}
QPushButton:hover
{
border-color:rgb(255, 255, 255)
}
结果hover的时候边框并没有高亮
解决办法:
border-style默认为none, 即没有边框,故需要先设置border-style值,border-color属性才会生效
QPushButton:hover
{
border-style:solid;
border-color:rgb(255, 255, 255)
}
borlder-style取值:

border-style : 0none     无边框(默认)
               1、solid    单实线 
               2、double   双实线
               3、dashed   虚线
               4、dotted   点线
               5、groove   沟线
               6、ridge    脊线
               7、inset    内陷边框
               8、outset   外凸边框
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值