Рисование собственного QWidget на основе значения псевдосостояния таблицы стилей

У меня есть обычай 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 ответ

Решение

Я никогда не мог выяснить, как получить информацию о разрешенном цвете (и заполнении), но смог обойти ее, нарисовав подэлементы других виджетов в моем. Это не совсем то , что я пытался сделать, и может не сработать в других случаях (если ваш виджет не может быть скомпонован путем объединения вещей, которые 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.
}

Я все еще думаю, что должен быть лучший путь.

Другие вопросы по тегам