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);}");  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM