QT:鼠标画线(双画布)

这篇具有很好参考价值的文章主要介绍了QT:鼠标画线(双画布)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

widget.h

#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

#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);
    }
}

结果

qt 鼠标画线,qt文章来源地址https://www.toymoban.com/news/detail-820792.html

到了这里,关于QT:鼠标画线(双画布)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Qt - Qt5事件处理(鼠标事件)

    鼠标事件 ​ 鼠标事件包括鼠标的移动,鼠标键按下,松开,单击,双击等 使用鼠标事件时,加入对应头文件 常见的鼠标事件如下: QMouseEvent类包含了用于描述鼠标事件的参数。 当在一个窗口里按住鼠标按键、或移动、或释放就会产生鼠标事件QMouseEvent。 鼠标移动事件只会

    2023年04月09日
    浏览(43)
  • QT学习日记12——Qt中的鼠标事件

    学习视频链接 最新QT从入门到实战完整版|传智教育_哔哩哔哩_bilibili https://www.bilibili.com/video/BV1g4411H78N?p=31vd_source=0471cde1c644648fafd07b54e303c905 目录 一、鼠标进入和出去事件 1.1 新建 C++ 文件 1.2 编写代码 1.3 操作 1.4 运行结果 二、鼠标点击、释放和移动事件 2.1 修改代码 2.2 运行结

    2024年02月11日
    浏览(54)
  • 【Qt】Qt无边框窗口(鼠标点击自定义标题栏)可拖动

    隐藏掉标题栏后,默认情况下窗口无法被鼠标拖动的,需要自己处理鼠标事件,移动窗口达到拖动效果,但是又不想要鼠标点击整个窗口都可以拖动,只需要鼠标点击自定义的标题栏时可拖动 具体步骤如下: 类外初始化 通过鼠标点击事件,判断鼠标是否在标题栏,如果是,

    2024年02月12日
    浏览(45)
  • Qt 设置鼠标形状

    设置窗口鼠标形状  v oid QWindow:: setCursor (const QCursor cursor ) 鼠标光标位于此窗口上时将采用此形状,除非设置了覆盖光标。Qt预定义了一系列有用的鼠标形状。列表如下: setCursor( const QCursor cursor )使用: 如果未设置光标形状,或者在调用 unsetCursor() 之后,则使用父窗口的光标

    2024年02月13日
    浏览(38)
  • QT鼠标控制

    每一个setOverrideCursor()都必须最后有一个对应的restoreOverrideCursor()跟着,否则栈将永远不会被清空。 QT中setOverrideCursor 和restoreOverrideCursor函数 clipCursor 函数 (winuser.h)

    2024年02月11日
    浏览(29)
  • qt鼠标事件

    鼠标移动事件,只要移动鼠标,就会触发这个函数,其中,正常情况下,只有当鼠标在QWidget界面点击鼠标后,才会捕捉到鼠标的坐标,那如何实现,在不点击鼠标的情况下,也可以捕捉到鼠标移动事件呢? 代码如下: 比如在主窗口QWidget下有一个父窗口Lable,在鼠标进入Lab

    2024年02月09日
    浏览(41)
  • Qt 鼠标进入离开事件

    QEvent::Enter ​ 鼠标进入事件,当鼠标进入到窗口/控件内部时,触发该事件,它对应的子类是 QEnterEvent QEvent::Leave ​ 鼠标离开事件,当鼠标离开到窗口/控件内部时,触发该事件 自定义一个标签控件 LabelX ,让它继承自 QLabel ,然后重写父类的 enterEvent 和 leaveEvent 。 代码如下:

    2024年01月24日
    浏览(38)
  • 【QT】鼠标常用事件

    新建项目 加标签控件 当鼠标进去,显示【鼠标进入】,离开时显示【鼠标离开】 将QLable提升成自己的控件,然后再去捕获 添加文件 改继承的类名 提升类 同一个父类,可以提升 效果 现在代码就和Qlabel对应起来了。 在.h中声明,.cpp中实现 测试 鼠标的移动、按下、松开事件

    2024年02月06日
    浏览(39)
  • qt鼠标常用事件

    和上一个案例相同,也是做了提升,换了相同父类,但是方式有所不同 先在widget.ui中加入label标签,此时其父类为QLabel,然后想实现鼠标在QLabel上的捕获。所以我们需要把QLabel提升为自己的框架,然后自定义框架后,我们就可以自己捕获信息了。然后添加新文件mylabel.h和mylabel.cpp,

    2024年02月02日
    浏览(39)
  • Qt 隐藏鼠标指针

    Qt 可以设置在软件窗口下的鼠标样式或者隐藏鼠标指针,通过setCursor可以实现,该接口可以在以下几个类中设置 这里以 QWidget 下来举例说明。 1.如果只希望在某个 widget 中不显示鼠标指针,那么在该 widget 的构造函数中调用 2.如果希望整个应用程序不显示鼠标指针,那么在实

    2024年02月11日
    浏览(49)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包