Qt 创建一个自定义按钮

一、概述

   案例:编写一个自定义按钮。要求:1.给按钮添加自定义背景 2.监听按钮点击事件

二、代码案例

  1.创建一个类让其继承QWidget,点击下一步下一步最后完成

 

 

 

   2.打开MyPushButton,让其继承QPushButton。如下所示:

MyPushButton::MyPushButton(QWidget *parent) : QPushButton(parent)
{

}

  3.重载其构造函数,让其传入按钮背景图片的路径。可设按钮的固定尺寸大小、icon、样式等。设置完成后这个自定义按钮就完成了。

MyPushButton::MyPushButton(QString normalImg,QString pressImg){
    normalImgPath = normalImg;
    pressedImgPath = pressImg;
    QPixmap pixmap;
    //判断是否能正常加载图片,若不能则提示用户
    bool ret = pixmap.load(normalImgPath);
    if(!ret){
       qDebug() << normalImg <<"加载图片失败" ;

    }
    //设置图片固定尺寸
    this->setFixedSize(pixmap.width(),pixmap.height());
    //设置不规则图片的样式表
    this->setStyleSheet("QPushButton{border:0px}");
    //设置图标
    this->setIcon(pixmap);
    //设置图标大小
    this->setIconSize(QSize(pixmap.width(),pixmap.height()));


}

  4.新建一个window类进行测试,在测试类的构造方法中加入如下的代码,并使用信号和槽函数监听按钮的点击事件

//创建开始按钮
    MyPushButton *startBtn = new MyPushButton(":/res/MenuSceneStartButton.png");
    startBtn->setParent(this);
    startBtn->move(this->width()*0.5-startBtn->width()*0.5,this->height()*0.7);

    //连接信号槽,监听开始按钮点击
    connect(startBtn,&MyPushButton::clicked,[=](){
       //点击自定义按钮的时候这个代码块的代码会执行。
    });

 

  案例如下图所示:一个圆润的开始按钮

  

 

posted on 2022-01-05 16:50  飘杨......  阅读(379)  评论(0编辑  收藏  举报