Qt 自定义仿iphone开关按钮

在做项目时,经常用到QPushButton,这次想设计成类似iphone开关按钮的样式。通过自定义Button类继承QPushButton类,重写paintEvent方法重绘按钮图形和重写mousePressEvent鼠标点击事件。


效果图:
在这里插入图片描述


步骤:
1、在当前工程目录下新建一个button.h和button.cpp文件用于创建自定义类Button,


button.h

#ifndef BUTTON_H
#define BUTTON_H

#include <QPushButton>
#include <QEvent>
#include <QMouseEvent>
#include <QPainter>
#include <QPaintEvent>
#include <QDebug>


class Button : public QPushButton
{
    Q_OBJECT

public:
    explicit Button(QWidget *parent = nullptr);
   void paintEvent(QPaintEvent *) override;
   void mousePressEvent(QMouseEvent *) override;

signals:
   void sendsignal();

private:
    bool isState;

};

#endif // BUTTON_H

button.cpp

#include "button.h"
#include "mainwindow.h"

Button::Button(QWidget *parent):QPushButton(parent)
{
    isState = false;
}


//重绘按钮
void Button::paintEvent(QPaintEvent *)
{
    QPainter painter(this);
    QPen pen;
    painter.setRenderHint(QPainter::Antialiasing,true);     //抗锯齿
    pen.setWidth(1);        //画笔像素宽度
    pen.setColor(QColor(200,200,200));      //画笔颜色
    painter.setPen(pen);        //设置椭圆边框

    if(!isState)
    {
        painter.setBrush(Qt::gray);         //设置椭圆背景色
        painter.drawEllipse(0,0,this->width(),this->height());      //画椭圆边框
        painter.setBrush(Qt::white);        //设置小圆背景色
        painter.drawEllipse(1,1,20,20);     //画小圆
    }
    else
    {
        painter.setBrush(Qt::green);
        painter.drawEllipse(0,0,this->width(),this->height());
        painter.setBrush(Qt::white);
        painter.drawEllipse(this->width()-20,this->height()-20,20,20);
    }

}


//重写点击按钮事件
void Button::mousePressEvent(QMouseEvent *)
{
    isState = !isState;
    update();       //调用paintEvent()
    emit sendsignal();
}



2、放置一个按钮,将其提升为自定义Button类,并转到槽
在这里插入图片描述


3、在mainwindow的构造函数中绑定按钮和槽函数,每当触发mousePressEvent事件就发送信号到按钮槽函数,执行相应功能。

#include "mainwindow.h"
#include "ui_mainwindow.h"

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);

    isClick = false;

    connect(ui->pushButton,&Button::sendsignal,this,&MainWindow::on_pushButton_clicked);
}


MainWindow::~MainWindow()
{
    delete ui;
}


void MainWindow::on_pushButton_clicked()
{
    if(!isClick)
    {
        qDebug()<< QString::fromLocal8Bit("已打开");
        isClick = true;
    }
    else
    {
        qDebug()<< QString::fromLocal8Bit("已关闭");
        isClick = false;
    }

}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值