qpushbutton,想弄个背景图片给按钮 我有个qpushbutton想弄个背景图片给按钮做背景先是遇到了坑用样式表不管用我用setStyleSheet之后这个半透明的png图像就变成了带白底色的——Qt 样式表的background-image会自动填充底色PNG 透明通道会丢失出现白色背景。 解决办法不用background-image改用图片画在按钮底层。重写按钮 paintEvent完美保留透明通道首选新建透明按钮类 TransparentBtn.h#ifndef TRANSPARENTBTN_H #define TRANSPARENTBTN_H #include QPushButton #include QPainter class TransparentBtn : public QPushButton { Q_OBJECT public: explicit TransparentBtn(QWidget *parent nullptr); void setBgPixmap(const QPixmap pix); protected: void paintEvent(QPaintEvent *event) override; private: QPixmap m_bg; }; #endifTransparentBtn.cpp#include TransparentBtn.h TransparentBtn::TransparentBtn(QWidget *parent) : QPushButton(parent) { } void TransparentBtn::setBgPixmap(const QPixmap pix) { m_bg pix; } void TransparentBtn::paintEvent(QPaintEvent *event) { QPushButton::paintEvent(event); QPainter p(this); // 绘制PNG原图透明通道完全保留 p.drawPixmap(rect(), m_bg); }使用// ui里把控件提升为TransparentBtn ui-pushButton-setBgPixmap(QPixmap(:/img/trans_bg.png)); ui-pushButton-setText(文字正常居中);文字自动覆盖在图片上层不会被挤开透明 PNG 不会变白底。然后又遇到了重写按钮paintEvent管用但是文字在图片之下怎么改一下你现在先画背景图再调用基类绘制文字顺序反了。 调换绘制顺序先用画家画出透明背景图再调用父类 paintEvent 绘制文字文字就会盖在图片上面修改后的 paintEventvoid TransparentBtn::paintEvent(QPaintEvent *event) { QPainter p(this); // 第一步先画透明背景图 if (!m_bg.isNull()) { p.drawPixmap(rect(), m_bg); } // 第二步再执行原生按钮绘制文字、鼠标悬浮效果都会画在图片上层 QPushButton::paintEvent(event); }配套属性防止底色干扰透明 PNG构造函数里加上两句彻底杜绝白底TransparentBtn::TransparentBtn(QWidget *parent) : QPushButton(parent) { setAttribute(Qt::WA_TranslucentBackground); setStyleSheet(border:none; background-color:transparent;); }效果 PNG 透明正常显示按钮文字正常居中悬浮、点击样式都保留文字始终浮在图片之上。