Qt 拖动事件

文章目录

  • 1 自定义控件 TextEdit
  • 2 实现打开文件功能
  • 3 实现鼠标滚轮放大字体

在这里插入图片描述

QEvent::DragEnter

当拖动文件进入到窗口/控件中时,触发该事件,它对应的子类是QDragEnterEvent

QEvent::DragLeave

当拖动文件离开窗口/控件时,触发该事件,它对应的子类是QDragLeaveEvent

QEvent::DragMove

当拖动文件在窗口/控件中移动时,触发该事件,它对应的子类是QDragMoveEvent

QEvent::Drop

当拖动文件在窗口/控件中移动时,触发该事件,它对应的子类是QDragMoveEvent

1 自定义控件 TextEdit

自定义一个标签控件TextEditx,让它继承自QTextEdit,然后重写拖放相关的函数。

添加自定义控件类TextEditX ,在 texteditx.h 文件中

// TextEditX.h
protected:// 重写父类的方法void dragEnterEvent(QDragEnterEvent *e);void dragMoveEvent(QDragMoveEvent *e);void dragLeaveEvent(QDragLeaveEvent *e);void dropEvent(QDropEvent *e);

texteditx.cpp 文件中

// TextEditX.cpp
TextEditX::TextEditX(QWidget *parent) : QTextEdit{parent} {// 部件将接受鼠标拖放事件this->setAcceptDrops(true);
}void TextEditX::dragEnterEvent(QDragEnterEvent *e) {qDebug() << "dragEnterEvent";// 默认情况下,窗口部件不接受拖动e->acceptProposedAction();
}void TextEditX::dragMoveEvent(QDragMoveEvent *e) {qDebug() << "dragMoveEvent";
}void TextEditX::dragLeaveEvent(QDragLeaveEvent *e) {qDebug() << "dragLeaveEvent";
}void TextEditX::dropEvent(QDropEvent *e) {qDebug() << "dropEvent";
}

2 实现打开文件功能

texteditx.cpp文件中

// texteditx.cpp
void TextEditX::dropEvent(QDropEvent *e) {qDebug() << "dropEvent";QList<QUrl> urls = e->mimeData()->urls();if (urls.isEmpty()) {return;}// 获取这个文件名QString fileName = urls.first().toLocalFile();qDebug() << urls.first() << "\n" << fileName;// 打开文件QFile file(fileName);// 打开失败返回 falseif (file.open(QIODevice::ReadOnly)) {setPlainText(file.readAll());}
}

3 实现鼠标滚轮放大字体

texteditx.h 文件中

protected:// 重写滚轮事件void wheelEvent(QWheelEvent *e);

texteditx.cpp 文件中

void TextEditX::wheelEvent(QWheelEvent *e) {if (QApplication::keyboardModifiers() == Qt::ControlModifier) {if (e->angleDelta().y() > 0) {// 滚轮远离使用者, 进行放大this->zoomIn();} else {// 滚轮靠近使用者, 进行缩小this->zoomOut();}} else {// 调用父类的实现, 否则无法实现文本的上下滚动QTextEdit::wheelEvent(e);}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/526058.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

鸿蒙OpenHarmony HDF 驱动开发

目录 序一、概述二、HDF驱动框架三、驱动程序四、驱动配置坚持就有收获 序 最近忙于适配OpenHarmonyOS LiteOS-M 平台&#xff0c;已经成功实践适配平台GD32F407、STM32F407、STM32G474板卡&#xff0c;LiteOS适配已经算是有实际经验了。 但是&#xff0c;鸿蒙代码学习进度慢下…

数字化转型导师坚鹏:科技金融政策、案例及数字化营销

科技金融政策、案例及数字化营销 课程背景&#xff1a; 很多银行存在以下问题&#xff1a; 不清楚科技金融有哪些利好政策&#xff1f; 不知道科技金融有哪些成功案例&#xff1f; 不知道科技金融如何数字化营销&#xff1f; 课程特色&#xff1a; 以案例的方式解读原…

万用表数据导出变化曲线图——pycharm实现视频数据导出变化曲线图

万用表数据导出变化曲线图——pycharm实现视频数据导出变化曲线图 一、效果展示二、环境配置三、代码构思四、代码展示五、代码、python环境包链接 一、效果展示 图1.1 效果展示 &#xff08;左图&#xff1a;万用表视频截图&#xff1b;右图&#xff1a;表中数据变化曲线图&am…

react实战——react旅游网

慕课网react实战 搭建项目问题1.按照官网在index.tsx中引入antd出错&#xff1f;2.typescript中如何使用react-router3.react-router3.1 V63.2 V53.3V6实现私有路由 4.函数式组件接收props参数时定义数据接口&#xff1f;5.使用TypeScript开发react项目&#xff1a;6.要使一个组…

使用Tokeniser估算GPT和LLM服务的查询成本

将LLM集成到项目所花费的成本主要是我们通过API获取LLM返回结果的成本&#xff0c;而这些成本通常是根据处理的令牌数量计算的。我们如何预估我们的令牌数量呢&#xff1f;Tokeniser包可以有效地计算文本输入中的令牌来估算这些成本。本文将介绍如何使用Tokeniser有效地预测和管…

three.js 包围盒

效果&#xff1a; 想要显示包围盒的样子&#xff1b;需要借助 Box3Helper 辅助显示&#xff1b; <template><div><el-container><el-main><div class"box-card-left"><div id"threejs"></div></div><…

探讨系统测试的最佳实践与思维模式!

这是测试活动过程详解系列的最后一篇文章。之前的想法&#xff0c;是对测试过程各重要环节进行拆解&#xff0c;然后介绍这个环节重点要做的事情&#xff0c;为什么要做这些事&#xff0c;以及注意事项。 前面几篇文章分别介绍了单元测试、集成测试、回归测试阶段要解决的问题…

剑指offer经典题目整理(二)

一、斐波那契数列&#xff08;fib&#xff09; 1.链接 斐波那契数列_牛客题霸_牛客网 (nowcoder.com) 2.描述 斐波那契数列就是数列中任意一项数字&#xff0c;都会等于前两项之和&#xff0c;满足f(n) f(n-1) f(n-2) 的一个数列&#xff0c;例如&#xff1a;1 1 2 3 5 8…

Ubuntu平铺左、右、上、下、1/2、1/4窗口(脚本)

前言 之前因为一直在用Ubuntu 18或者Ubuntu 20然后发现装了GNOME插件后&#xff0c;电脑在使用过程中&#xff0c;会时不时的卡死&#xff08;鼠标没问题&#xff0c;键盘输入会有10-20秒的延迟&#xff09;频率基本是一小时一次&#xff0c;因为这种卡顿会很容易打断思路&…

首屏性能优化:提升用户体验的秘籍

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

Chrome中如何导出和导入书签

导出书签 如下图所示&#xff1a; 右上角三点->书签和清单->书签管理器->右上角三点->导出书签 然后你选择保存地址即可。打开后如下&#xff1a; 导入书签 如下图所示&#xff1a; 右上角三点->书签和清单->导入书签和设置->选择以前导出的书签&…

存储引擎的详细介绍

通过查询可得&#xff1a; &#xff08;一&#xff09;InnoDB引擎 简介&#xff1a;具备外键支持功能的事务存储引擎 优点&#xff1a; 1.是mysql的默认事务型存储引擎&#xff0c;它被设计用来处理大量短期事务&#xff08;确保事务完整提交和回 滚&#xff09; 2.除了增加…