6

独自のを実装する必要があるカスタムQWidget(実際には、から派生)があります。スタイルシート情報の使い方は?QAbstractButtonpaintEvent

たとえば、誰かが私のカスタムクラスに(直接または継承を介して)適用する次のスタイルシートを定義するとします。

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がスタイルシートから解決したチェック状態の背景にブラシを使用するにはどうすればよいですか?

4

1 に答える 1

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

私はまだもっと良い方法がなければならないと思います。

于 2011-05-03T15:55:08.817 に答える