作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个自定义 QWidget
(实际上,源自 QAbstractButton
)我必须实现我自己的 paintEvent
.如何使用样式表信息?
例如,假设有人定义了(直接或通过继承)应用于我的自定义类的以下样式表:
QAbstractButton { font-weight: bold; background-color: red }
QAbstractButton:checked { background-color: blue }
paintEvent
方法,如何获得正确的背景颜色以显示选中状态?
void MyButton::paintEvent(QPaintEvent */*event*/) {
ensurePolished(); // Don't think this is necessary...
qDebug() << Q_FUNC_INFO << isChecked(); // This is showing the right value
QStylePainter painter(this);
painter.fillRect(rect(), painter.background()); // always red, even if checked
}
if (isChecked()) {
// painter.fillRect(rect(), ???);
//
// style()->drawPrimitive(???, ...);
//
// QStyleOptionButton opt;
// opt.initFrom(this);
// QBrush bg_brush = opt.???
// painter.fillRect(rect(), bg_brush);
//
// ???
} else {
painter.fillRect(rect(), painter.background());
}
最佳答案
我永远无法找到如何获得解析的颜色(和填充)信息,但能够通过将其他小部件的子元素绘制到我的中来解决它。这不是我想要做的,并且在其他情况下可能不起作用(如果您的小部件不能通过将 Qt 知道如何绘制的东西混合在一起来组成)。
void MyButton::paintEvent(QPaintEvent */*event*/) {
QStylePainter painter(this);
QStyleOptionButton opt;
opt.initFrom(this);
opt.state |= isChecked() ? QStyle::State_On : QStyle::State_Off;
opt.text = text();
painter.drawPrimitive(QStyle::PE_Widget, opt);
QStyleOptionButton label_opt = opt;
label_opt.rect =
style()->subElementRect(QStyle::SE_CheckBoxContents, &opt, this);
painter.drawControl(QStyle::CE_CheckBoxLabel, label_opt);
// ... etc.
}
关于qt - 基于样式表伪状态值绘制自定义QWidget,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5863417/
我是一名优秀的程序员,十分优秀!