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. Linux环境搭建和编码

    喜欢(594) 浏览(17681)
  2. 使用hexo搭建个人博客

    喜欢(533) 浏览(16178)
  3. MarkDown在线编辑器

    喜欢(514) 浏览(18221)
  4. vscode搭建windows C++开发环境

    喜欢(596) 浏览(111132)
  5. 聊天项目(28) 分布式服务通知好友申请

    喜欢(507) 浏览(8364)

最新评论

  1. 无锁并发队列 TenThousandOne:_head  和 _tail  替换为原子变量。那里pop的逻辑,val = _data[h] 可以移到循环外面吗
  2. 解决博客回复区被脚本注入的问题 secondtonone1:走到现在我忽然明白一个道理,无论工作也好生活也罢,最重要的是开心,即使一份安稳的工作不能给我带来事业上的积累也要合理的舍弃,所以我还是想去做喜欢的方向。
  3. 处理网络粘包问题 zyouth: //消息的长度小于头部规定的长度,说明数据未收全,则先将部分消息放到接收节点里 if (bytes_transferred < data_len) { memcpy(_recv_msg_node->_data + _recv_msg_node->_cur_len, _data + copy_len, bytes_transferred); _recv_msg_node->_cur_len += bytes_transferred; ::memset(_data, 0, MAX_LENGTH); _socket.async_read_some(boost::asio::buffer(_data, MAX_LENGTH), std::bind(&CSession::HandleRead, this, std::placeholders::_1, std::placeholders::_2, shared_self)); //头部处理完成 _b_head_parse = true; return; } 把_b_head_parse = true;放在_socket.async_read_some前面是不是更好
  4. C++ 线程池原理和实现 mzx2023:两种方法解决,一种是改排序算法,就是当线程耗尽的时候,使用普通递归,另一种是当在线程池commit的时候,判断线程是否耗尽,耗尽的话就直接当前线程执行task
  5. 利用指针和容器实现文本查询 越今朝:应该添加一个过滤功能以解决部分单词无法被查询的问题: eg: "I am a teacher."中的teacher无法被查询,因为在示例代码中teacher.被解释为一个单词从而忽略了teacher本身。

B站

个人微信

个人公众号