• 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- 41px; border-image: url(%1)  0 0 0 %2 repeat  repeat;border- 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);}");  
  • 相关阅读:
    bzoj4598: [Sdoi2016]模式字符串
    bzoj3156: 防御准备
    bzoj1966: [Ahoi2005]VIRUS 病毒检测
    bzoj3170: [Tjoi2013]松鼠聚会
    bzoj3171: [Tjoi2013]循环格
    POJ1068Parencodings
    2013年山东省第四届ACM大学生程序设计竞赛 Alice and Bob
    POJ2632Crashing Robots
    POJ1328Radar Installation
    POJ2586Y2K Accounting Bug
  • 原文地址:https://www.cnblogs.com/findumars/p/5553309.html
Copyright © 2020-2023  润新知