Qt 鼠标事件

鼠标事件

鼠标事件包括鼠标左键点击,右键点击,双击,滚动滚轮等。我们先创建一个QApplication项目,类名字为Widget,基类选择QWidget。在widget.ui里添加一个QTextEdit, 依次实现这些功能。

鼠标按下与移动

先在Widget的构造函数中,我们先给鼠标设置一个小手的样式

  1. Widget::Widget(QWidget *parent) :
  2. QWidget(parent),
  3. ui(new Ui::Widget)
  4. {
  5. ui->setupUi(this);
  6. //创建光标对象
  7. QCursor cursor;
  8. //修改鼠标形状
  9. cursor.setShape(Qt::OpenHandCursor);
  10. //设置鼠标
  11. setCursor(cursor);
  12. }

我们将鼠标设置为打开的手的形象。
我们在鼠标左键按下时,获取鼠标和窗口左上角的位置偏移量,并且设置光标为CloseHandCursor形象。
鼠标右键按下时,设置为别的资源图标

  1. void Widget::mousePressEvent(QMouseEvent *event)
  2. {
  3. //如果是鼠标左键按下
  4. if(event->button() == Qt::LeftButton){
  5. QCursor cursor;
  6. cursor.setShape(Qt::ClosedHandCursor);
  7. QApplication::setOverrideCursor(cursor);
  8. offset = event->globalPos() - pos();
  9. }else if(event->button() == Qt::RightButton){
  10. QCursor cursor(QPixmap(":/res/mouse.png"));
  11. QApplication::setOverrideCursor(cursor);
  12. }
  13. }

然后我们实现释放事件,在释放鼠标时,将鼠标恢复为原来的OpenHandCursor形象

  1. void Widget::mouseReleaseEvent(QMouseEvent *event)
  2. {
  3. //释放事件
  4. QApplication::restoreOverrideCursor();
  5. }

双击实现窗口放大

我们通过实现双击左键,让窗口最大化,如果已经最大化,则让窗口再变回正常模式。

  1. void Widget::mouseDoubleClickEvent(QMouseEvent *event)
  2. {
  3. if(event->button() == Qt::LeftButton){
  4. if(windowState() != Qt::WindowFullScreen){
  5. setWindowState(Qt::WindowFullScreen);
  6. }else{
  7. setWindowState(Qt::WindowNoState);
  8. }
  9. }
  10. }

拖动鼠标移动窗口

因为之前我们在鼠标左键点击后保存了窗口和鼠标的偏移量,我们可以在鼠标移动的过程中,根据偏移量和鼠标的位置,重设窗口的位置,进而实现窗口随着鼠标拖动而移动的效果。

  1. void Widget::mouseMoveEvent(QMouseEvent *event)
  2. {
  3. //移动过程中判断鼠标是左键点击并且移动,那么要用buttons,返回的是鼠标状态的集合
  4. if(event->buttons() & Qt::LeftButton){
  5. //获取窗口应当移动到的位置
  6. QPoint windowpos = event->globalPos() - offset;
  7. this->move(windowpos);
  8. }
  9. }

滚轮事件

我们可以在Widget里添加textEdit,然后在鼠标滚轮滚动的时候,根据滚轮的方向缩放textEdit的文字.

  1. void Widget::wheelEvent(QWheelEvent *event)
  2. {
  3. //鼠标滚动远离使用者放大textedit
  4. if(event->delta() > 0){
  5. qDebug() << "catch wheel event delta > 0" << endl;
  6. ui->textEdit->zoomIn();
  7. }else {
  8. qDebug() << "catch wheel event delta < 0" << endl;
  9. ui->textEdit->zoomOut();
  10. }
  11. }

在鼠标滚轮向前滚动的时候delta大于0,是放大textEdit,向后滚动的时候delta小于0,是缩小textEdit.

总结

源码连接:
https://gitee.com/secondtonone1/qt-learning-notes

热门评论

热门文章

  1. C++ 类的继承封装和多态

    喜欢(588) 浏览(4965)
  2. windows环境搭建和vscode配置

    喜欢(587) 浏览(2817)
  3. Linux环境搭建和编码

    喜欢(594) 浏览(12183)
  4. 解密定时器的实现细节

    喜欢(566) 浏览(3475)
  5. slice介绍和使用

    喜欢(521) 浏览(2479)

最新评论

  1. C++ 并发三剑客future, promise和async Yunfei:大佬您好,如果这个线程池中加入的异步任务的形参如果有右值引用,这个commit中的返回类型推导和bind绑定就会出现问题,请问实际工程中,是不是不会用到这种任务,如果用到了,应该怎么解决?
  2. Qt MVC结构之QItemDelegate介绍 胡歌-此生不换:gpt, google
  3. 聊天项目(9) redis服务搭建 pro_lin:redis线程池的析构函数,除了pop出队列,还要free掉redis连接把
  4. 答疑汇总(thread,async源码分析) Yagus:如果引用计数为0,则会执行 future 的析构进而等待任务执行完成,那么看到的输出将是 这边应该不对吧,std::future析构只在这三种情况都满足的时候才回block: 1.共享状态是std::async 创造的(类型是_Task_async_state) 2.共享状态没有ready 3.这个future是共享状态的最后一个引用 这边共享状态类型是“_Package_state”,引用计数即使为0也不应该block啊

个人公众号

个人微信