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

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

不说了关键代码来了;(这是一张图片切图的效果)

 

[cpp] view plain copy
 
  1. void SetButtonStyle(QPushButton *button, QString imgsrc, int CutSec)  
  2. {  
  3.     int img_w=QPixmap(imgsrc).width();  
  4.     int img_h=QPixmap(imgsrc).height();  
  5.     int PicWidth = img_w/CutSec;  
  6.     button->setFixedSize(PicWidth,img_h);  
  7.     button->setStyleSheet(QString("QPushButton{border-width: 41px; border-image: url(%1)  0 0 0 %2 repeat  repeat;border-width: 0px; border-radius: 0px;}")  
  8.       .append("QPushButton::hover{border-image: url(%1) 0 0 0 %3  repeat  repeat;}")  
  9.       .append("QPushButton::pressed{border-image: url(%1) 0  0 0 %4 repeat  repeat;}")  
  10.       .append("QPushButton::checked{border-image: url(%1) 0  0 0 %4 repeat  repeat;}")  
  11.       .append("QPushButton::disabled{border-image: url(%1) 0  0 0 %5 repeat  repeat;}")  
  12.       .arg(imgsrc).arg(0).arg(PicWidth*1).arg(PicWidth*2).arg(PicWidth*3));  
  13. }  


调用

 

 

[cpp] view plain copy
 
  1. SetButtonStyle(ui->pushButton,":/btn/image/btn.png",4);  


效果图

 

(资源)

 

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

 

 

[cpp] view plain copy
 
    1. ui->pushButton->setStyleSheet("QPushButton{border-image: url(:/btn/image/1.png);}"  
    2.                                 "QPushButton:hover{border-image: url(:/btn/image/3.png);}"  
    3.                                  "QPushButton:pressed{border-image: url(:/btn/image/2.png);}");  
posted @   findumars  Views(7867)  Comments(1Edit  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
历史上的今天:
2015-06-02 发现一个好的开源项目:lomoX(挑着看,每天看一点,看一年就ok了)——用Webkit开发桌面软件,炫
点击右上角即可分享
微信分享提示