Qt下 圆形按钮的绘制

关于Qt下绘制按钮的文章不少,这里简单介绍一个怎么绘制圆形⭕️的按钮并在点击时候改变颜色的方法。先上图,如下:

==》1 圆形按钮初始状态(未被点击且鼠标未移动到按钮上)

   

==》2 当鼠标移动到按钮上时的状态

==》3、点击圆形按钮时的状态



其他的不多说了,直接上代码吧,具体细节请代码中的注释信息:

 
#ifndef MAINWINDOW_H
#define MAINWINDOW_H
#include <QMainWindow>
#include"QPainter"
class QPainter;
class QMouseEvent;
class QRectF;
class MainWindow : public QMainWindow
{
    Q_OBJECT
public:
    MainWindow(QWidget *parent = 0);
    ~MainWindow();
signals:
    void cursorchanged(QPaintEvent *event);
public:
    void paintEvent(QPaintEvent *);//绘图
    void mousePressEvent(QMouseEvent *event);
    void mouseReleaseEvent(QMouseEvent* event);
    void mouseMoveEvent(QMouseEvent *);//鼠标移动事件==》可以用于做触摸式的动作
public:
    QPaintEvent *m_paintevent;
    QPainter painter;
    int m_pressflag;//判断按钮是否被点击
    int m_touchflag;//鼠标滑动到按钮上
    QRectF rectbutton;//圆形按钮的外接矩形
};
#endif // MAINWINDOW_H


#include "mainwindow.h"
#include"QPainter"
#include"QMouseEvent"
#include"QRectF"
#include"QDebug"
MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
{
    this->setFixedSize(500,500);//设置父窗口的大小
    m_pressflag = false;
    m_touchflag = false;
    rectbutton = QRectF(20,20,50,50);
    setMouseTracking(true);//设置鼠标可跟踪
    connect(this,SIGNAL(cursorchanged(QPaintEvent* )),this,SLOT(paintEvent(QPaintEvent*)));
}
MainWindow::~MainWindow()
{
}
//绘图事件
void MainWindow::paintEvent(QPaintEvent *)
{
    painter.begin(this);
    painter.setPen(QPen(Qt::blue,4));//设置画笔形式
    if(!m_pressflag && !m_touchflag){
        painter.drawEllipse(rectbutton);//画圆形状按钮==>矩形的内切圆
    }
    else if(m_pressflag)
    {
        painter.setBrush(Qt::red);
    }
    else if (!m_pressflag && m_touchflag)
    {
        //painter.begin(this);
        painter.setBrush(Qt::black);
    }
    painter.drawEllipse(rectbutton);
    painter.end();
    update();
}
//鼠标点击事件
void MainWindow::mousePressEvent(QMouseEvent *event)
{
    if(rectbutton.contains(event->pos())){
        qDebug()<<"buttton was clicked!";
        m_pressflag = !m_pressflag;
    }
}
//鼠标释放事件
void MainWindow::mouseReleaseEvent(QMouseEvent* event)
{
}
//鼠标移动事件
void MainWindow::mouseMoveEvent(QMouseEvent *event)
{//鼠标移动事件==》可以用于做触摸式的动作
    QPoint n = event->pos();
    qDebug()<<n;//鼠标移动位置
    if(rectbutton.contains(n))
    {
        qDebug()<<"button was touched";
        m_touchflag = true;
    }
    else
    {
        m_touchflag =false;
    }
    emit cursorchanged(m_paintevent);//这个地方的信号函数的用法新手请注意,老司机请忽略
    qDebug()<<"signal was emitted";
}

 
  好了,本文到此结束。有更好方法或者建议的请评论和留言。


 
 
 





  • 6
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

键盘会跳舞

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值