QT:鼠标画线(双画布)

widget.h

cpp 复制代码
#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QPoint>   //点
#include <QMouseEvent>  //鼠标事件
#include <QPaintEvent>  //绘图事件

class Widget : public QWidget
{
    Q_OBJECT

public:
    Widget(QWidget *parent = 0);
    ~Widget();

    void mousePressEvent(QMouseEvent *event);  //鼠标按下事件
    void mouseMoveEvent(QMouseEvent *event);   //鼠标移动事件
    void mouseReleaseEvent(QMouseEvent *event);  //鼠标松开事件

    void paintEvent(QPaintEvent *event);    //绘图事件

private:
    bool toSave;
    QPoint pStart,pEnd;  //起点和终点
    QPixmap *px;  //缓冲的画布
};

#endif // WIDGET_H

widget.cpp

cpp 复制代码
#include "widget.h"
#include <QPainter>  //画家

Widget::Widget(QWidget *parent)
    : QWidget(parent)
{
    setFixedSize(800,600);
    px = new QPixmap(this->width(),this->height());  //与主窗口大小一致
    px->fill();   //不填充
}

Widget::~Widget()
{

}

void Widget::mousePressEvent(QMouseEvent *event)
{
    pStart = event->pos();  //起点
}

void Widget::mouseMoveEvent(QMouseEvent *event)
{
    pEnd = event->pos();   //终点
    toSave = false;   //不保存

    //触发绘图事件
    this->update();
}

void Widget::mouseReleaseEvent(QMouseEvent *event)
{
    pEnd = event->pos();   //终点
    toSave = true;    //保存

    this->update();   //触发绘图事件
}

void Widget::paintEvent(QPaintEvent *event)
{
    if(toSave)  //区别移动还是松开
    {
        //当用户松开鼠标,将这根线画到pixmap
        //设定Pixmap作为画布
        QPainter p_pixmap(px);  //两个画家在两个不同的画布上作画
        p_pixmap.drawLine(pStart,pEnd);
    }

    //让Widget成为画布
    QPainter p(this);
    //将之前保留的线画出来
    p.drawPixmap(0,0,*px);
    if(toSave == false)
    {
        //只有鼠标移动的时候,我们才画这根临时的线
       p.drawLine(pStart,pEnd);
    }
}

结果

相关推荐
开始了码10 分钟前
XML文件介绍和QT相关操作
xml·qt
2401_853448232 小时前
tslib及QT移植
qt·tslib
IOT-Power3 小时前
Qt 输入框: 数字/浮点/十六进制数值输入处理
qt
神仙别闹7 小时前
基于QT(C++)实现宠物小精灵对战游戏
c++·qt·宠物
小尧嵌入式7 小时前
音视频入门基础知识
开发语言·c++·qt·算法·音视频
蓑衣夜行8 小时前
QtWebEngine 自动重启方案
开发语言·c++·qt·web·qwebengine
Source.Liu8 小时前
【LibreCAD】点实体源码解析
c++·qt·cad
乌托邦2号8 小时前
Qt5之中文字符串转换
开发语言·qt
IOT-Power9 小时前
QT QSerialPort 串口不稳定,串口是否使用独立线程
qt
IOT-Power10 小时前
QT的解耦方式
qt