QT学习记录-自定义开关按钮

本文记录了使用QT创建自定义开关按钮的过程,通过派生QWidget并绘制两个圆形及一个矩形来形成开关样式,简单易用,适用于基础需求。
摘要由CSDN通过智能技术生成

简单的按钮开关实现
自定义类派生于QWidget-在上面画2个圆形和一个矩形,合成一个开关样式,再让其中一个圆形填充不一样的颜色就好了。
switchbutton.h

#ifndef SWITCHBUTTON_H
#define SWITCHBUTTON_H

#include <QWidget>
#include <QEvent>
#include <QPaintEvent>
#include <QPainter>
#include <QMouseEvent>
class SwitchButton : public QWidget
{
    Q_OBJECT
public:
    explicit SwitchButton(QWidget *parent = 0);
signals:
    void isChecked(bool check);
public slots:
protected:
    void paintEvent(QPaintEvent *);
    void mouseReleaseEvent(QMouseEvent *);
private:
    bool hasChecked;
};

#endif // SWITCHBUTTON_H

switchbutton.cpp

#include "switchbutton.h"

SwitchButton::SwitchButton(QWidget *parent) : QWidget(parent),hasChecked(false)
{
    this->setFixedSize(60,30);
}

void SwitchButton::paintEvent(QPaintEvent *)
{
    if(!hasChecked)
    {
        QPainter painter(this);
        painter.setPen(Qt::white);
        painter.setBrush(Qt::white);
        painter.drawEllipse(30,0,30,30);
        painter.drawRect(15,0,30,30);
        painter.setBrush(Qt::blue);
        painter.drawEllipse(0,0,30,30);
    }
    else
    {
        QPainter painter(this);
        painter.setPen(Qt::white);
        painter.setBrush(Qt::white);
        painter.drawEllipse(0,0,30,30);
        painter.drawRect(15,0,30,30);
        painter.setBrush(Qt::blue);
        painter.drawEllipse(30,0,30,30);
    }
}

void SwitchButton::mouseReleaseEvent(QMo
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值