qt使用qproperty在css中设置自定义的qobject类属性
- IT业界
- 2025-07-21 19:20:32

在Qt的CSS样式表中使用 qproperty 来赋值,首先需要在类的定义中使用 Q_PROPERTY 宏声明属性,并提供相应的 getter 和 setter 函数。
// MyWidget.h #ifndef MYWIDGET_H #define MYWIDGET_H #include <QWidget> class MyWidget : public QWidget { Q_OBJECT Q_PROPERTY(QString text READ getText WRITE setText) public: explicit MyWidget(QWidget *parent = nullptr); QString getText() const; void setText(const QString &text); protected: void paintEvent(QPaintEvent *event) override; }; #endif // MYWIDGET_H // MyWidget.cpp #include "MyWidget.h" #include <QPainter> MyWidget::MyWidget(QWidget *parent) : QWidget(parent) { // 初始化其他内容 } QString MyWidget::getText() const { return m_text; } void MyWidget::setText(const QString &text) { m_text = text; update(); // 通知界面进行更新,这里假设你的属性影响了界面显示 } void MyWidget::paintEvent(QPaintEvent *event) { Q_UNUSED(event); // 在绘制时使用 m_text QPainter painter(this); painter.drawText(rect(), m_text); }MyWidget 类有一个名为 text 的属性,使用 Q_PROPERTY 宏声明,并提供了相应的 getter 和 setter 函数。
接下来,在CSS样式表中,使用 qproperty-text 来为这个属性设置值:
MyWidget { qproperty-text: "Hello, World!"; }qt使用qproperty在css中设置自定义的qobject类属性由讯客互联IT业界栏目发布,感谢您对讯客互联的认可,以及对我们原创作品以及文章的青睐,非常欢迎各位朋友分享到个人网站或者朋友圈,但转载请说明文章出处“qt使用qproperty在css中设置自定义的qobject类属性”
上一篇
C/C++内存管理
下一篇
Scrum敏捷开发流程及支撑工具