0

如何在 QDial 上添加资源图像?

我已经为 QDial 完成了一个自定义类,但是我怎样才能在其中包含一个样式表,以便像为按钮一样添加资源图像?例如:

button1->setStyleSheet("border-image:url(:/resources/img/knob.png)");
4

1 回答 1

1

QDial 不支持样式表,除了背景颜色。但是,这就是我的做法。

但是,一个警告:这根本不完整,它只是让你知道如何去做。

在您的标题中,为 QPixmap 设置一个属性,该属性将成为您的背景图像:

class QCustomDial : public QDial
{
    Q_OBJECT

    Q_PROPERTY(QPixmap backgroundImage READ backgroundImage WRITE setBackgroundImage DESIGNABLE true)

    QPixmap* m_background;

 public:
    QPixmap backgroundImage()    { return *m_background; }

    void setBackgroundImage(QPixmap pixmap) 
    { 
        *m_background = pixmap;
        update(); 
    }

 private:
    QPixmap* m_background;
};

然后,在您的paintEvent 中,您必须绘制像素图:

void QCustomDial::paintEvent(QPaintEvent*)
{
    QPainter painter(this);
    ...
    QPoint start(0, 0); //whatever you want 
    painter.drawPixmap(start, *m_background);
    ...
}

最后,您在问题中想要的部分:样式表。现在您已经定义了 a Q_PROPERTY,您可以从样式表中获取它:

QCustomDial {
    qproperty-backgroundImage: url(:/resources/img/knob.png);
}

我希望它会帮助你。我还建议您阅读有关自定义 QDial(part1part2)的博客。

于 2017-11-30T09:20:41.257 回答