QT实现图片按钮(用qss切割图片,或者放三张图片)

本文介绍了一种使用Qt为按钮设置自定义样式的两种方法:一种是通过切割图片并利用border-image属性来实现不同状态下的样式变化;另一种是直接指定不同状态下按钮所使用的独立图片。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我在网上找了很久,把他综合了一下

不说了关键代码来了;


void SetButtonStyle(QPushButton *button, QString imgsrc, int CutSec)
{
int img_w=QPixmap(imgsrc).width();
int img_h=QPixmap(imgsrc).height();
int PicWidth = img_w/CutSec;
button->setFixedSize(PicWidth,img_h);
button->setStyleSheet(QString("QPushButton{border-width: 41px; border-image: url(%1) 0 0 0 %2 repeat repeat;border-width: 0px; border-radius: 0px;}")
.append("QPushButton::hover{border-image: url(%1) 0 0 0 %3 repeat repeat;}")
.append("QPushButton::pressed{border-image: url(%1) 0 0 0 %4 repeat repeat;}")
.append("QPushButton::checked{border-image: url(%1) 0 0 0 %4 repeat repeat;}")
.append("QPushButton::disabled{border-image: url(%1) 0 0 0 %5 repeat repeat;}")
.arg(imgsrc).arg(0).arg(PicWidth*1).arg(PicWidth*2).arg(PicWidth*3));
}


调用


SetButtonStyle(ui->pushButton,":/btn/image/btn.png",4);



还有一种方式就是三张独立的图片


ui->pushButton->setStyleSheet("QPushButton{border-image: url(:/btn/image/1.png);}"
"QPushButton:hover{border-image: url(:/btn/image/3.png);}"
"QPushButton:pressed{border-image: url(:/btn/image/2.png);}");


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值