簡體   English   中英

基於樣式表偽狀態值繪制自定義 QWidget

[英]Painting custom QWidget based on style sheet pseudo-state value

我有一個自定義QWidget (實際上,從QAbstractButton派生),我必須實現我自己的paintEvent 如何使用樣式表信息?

例如,假設有人定義了以下樣式表(直接或通過繼承)應用於我的自定義 class:

QAbstractButton { font-weight: bold; background-color: red }
QAbstractButton:checked { background-color: blue }

在我的paintEvent方法中,如何獲得正確的背景顏色以顯示選中的 state?

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.
}

我仍然認為必須有更好的方法。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM