在qss文件中使用自定义属性, 要手动刷新才会生效

//控件自定义属性
setProperty("state", m_strState);




//qss文件如下
QPushButton#buttonItem[state=previewNormal]{ 
color:#FF0000;
font: 20pt;
border:2px solid #00ff00;
border-radius:10px;
background:qlineargradient(spread:pad,x1:0,y1:0,x2:0,y2:1,stop:0 #4D004D,stop:1 #012029);



//刷新代码 
    this->style()->unpolish(this);
    this->style()->polish(this);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 qss 设置自定义属性的方法如下: 1. 在 qss 文件添加自定义属性的声明,例如: ``` QPushButton[customAttribute="value"] { /* Style rules go here */ } ``` 2. 在代码为控件设置自定义属性,例如: ``` pushButton->setProperty("customAttribute", "value"); ``` 3. 在代码应用 qss 样式表,例如: ``` pushButton->setStyleSheet(styleSheet); ``` 注意:自定义属性的名称必须以 "q_" 或 "Q_" 开头,否则无法在 qss 使用。 ### 回答2: 在使用Qt编程时,可以使用QSS(Qt Style Sheets)来设置控件的样式和外观。要给控件设置自定义属性,可以按照以下步骤操作: 首先,在代码创建一个派生自QWidget或其子类的自定义控件,例如MyWidget。 然后,在MyWidget类的头文件定义一个成员变量作为自定义属性,例如myProperty。 接下来,在MyWidget类的实现文件提供一个getter和setter方法来访问和修改这个自定义属性。 再次,在QSS使用选择器来选择需要设置自定义属性的控件,例如具有自定义属性的MyWidget实例,可以通过选择器“MyWidget[myProperty="value"]”来选择。 最后,在QSS使用属性设置语法来设置自定义属性的值。例如,可以通过设置“myProperty: value;”来给控件设置自定义属性的值。 总结起来,要在QSS内给控件设置自定义属性,需要在代码定义自定义控件,提供getter和setter方法来访问和修改自定义属性,然后在QSS使用选择器和属性设置语法来设置自定义属性的值。这样在QSS就可以通过选择器选择具有自定义属性的控件,并为它们设置相应的样式。 ### 回答3: 在Qt,可以通过在QSS样式表内定义自定义属性来给控件设置自定义属性。下面是一个实现的示例: 首先,在Qt设计师设计界面并添加一个控件,例如QPushButton。然后,选择该控件,右键单击选择"Go to slot...",选择"clicked()"信号的槽函数。 在生成的槽函数内,可以通过setProperty()函数给控件设置自定义属性。例如,设置一个自定义属性"myProperty"为"myValue": ```cpp void MainWindow::on_pushButton_clicked() { ui->pushButton->setProperty("myProperty", "myValue"); } ``` 接下来,在QSS样式表,可以通过"["和"]"操作符定义自定义属性的样式。例如,设置属性"myProperty"为"myValue"的背景颜色为红色: ```qss QPushButton[myProperty="myValue"] { background-color: red; } ``` 将以上样式表应用到控件上,即可使设置了自定义属性的控件显示红色背景。 需要注意的是,自定义属性的类型只能是字符串。如果要设置其他类型的属性,可以使用 QVariant 类型进行转换。 总结来说,通过在槽函数内使用 setProperty() 方法给控件设置自定义属性,然后在样式表使用设置的属性值来定义样式,就可以实现在 QSS 内给控件设置自定义属性
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值