根据样式表伪状态值绘制自定义QWidget

时间:2011-05-02 23:03:08

标签: 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从样式表中解析的已检查状态背景?

1 个答案:

答案 0 :(得分:2)

我从来没有找到如何获得已解析的颜色(和填充)信息,但能够通过将其他小部件的子元素绘制到我的手中来解决它。这不是完全我想要做的事情,并且可能在其他情况下不起作用(如果你的小部件不能通过将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.
}

我仍然认为必须有更好的方法。