スタイルシートの疑似状態値に基づいたカスタムQWIDGETのペイント
-
28-10-2019 - |
質問
カスタムがあります 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.
}
私はまだより良い方法が必要だと思います。
所属していません StackOverflow