qt - 基于样式表伪状态值绘制自定义QWidget

标签 qt stylesheet qwidget qabstractbutton

我有一个自定义 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 从样式表解析的选中状态背景?

最佳答案

我永远无法找到如何获得解析的颜色(和填充)信息,但能够通过将其他小部件的子元素绘制到我的中来解决它。这不是我想要做的,并且在其他情况下可能不起作用(如果您的小部件不能通过将 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/

相关文章:

c++ - 有没有一种方法可以将 Qt 中的信号设为 `eat`?

用于桌面应用程序的 Ruby gui

html - CSS 响应式页脚

qt - 从 QWidget 内的另一个类访问方法

c++ - inferior 停止是因为它收到了来自可调整大小的滚动区域上的操作系统错误的信号

windows - 如何让Qt Creator的jom.exe复制带空格的路径中的文件?

ruby-on-rails - 对于程序员来说,是否有任何插件或框架或工具可以使网页美观?

未应用子内容占位符中的 CSS 样式表

Qt如何知道widget,用户上次在哪个元素上设置了焦点

qt - QWidget::mapToGlobal() 当小部件不可见时