Qt QCustomPlot 点状网格线实现和曲线坐标点拾取

news/2024/4/20 20:44:30/文章来源:https://blog.csdn.net/z609932088/article/details/128121342
头图

Qt QCustomPlot 点状网格线实现和曲线坐标点拾取

文章目录

  • Qt QCustomPlot 点状网格线实现和曲线坐标点拾取
    • 摘要
    • 我想实现的效果
    • 点阵的实现
      • 第一版本,使用QPen Style
      • 第二版本,通过设置背景
      • 第三版本,回到QPen Style
    • 取曲线上的点

关键字: QCustomPlotgridQt拾取背景

摘要

今天被封控在家,但是万恶的资本家是不会让我在家摸鱼的,所以还是给了需求来,所以还是得搞。今天要接着研究QCustomPlot,老实说,这个也是我第一次用,也没有系统的研究过,只是用到了啥现研究,难免哪里问题或者不合理甚至是理解错误的地方。欢迎大家评论区交流。

我想实现的效果

有两个点,第一个是那个类似星星的背景点阵,我暂时先这么称呼它,因为我也不知道专业名称叫啥;第二个就是这个游标了,就是可以精确显示曲线上每个点的信息,其实就是坐标,如下图所示。这里应为我的需求只需要显示对应的值,所以我就吧X轴的数据隐藏掉了。

wwwwwwwwwww

点阵的实现

先来解决第一个点阵的问题,这个其实是最耗时的,因为网上没有现成的代码,没得抄(应该是叫莫得参考)。只能自己慢慢摸索。

第一版本,使用QPen Style

我发现 QCustomPlot 坐标轴和网格有一个接口就是设置QPen,所以打算通过设置坐标轴的网格的画笔来实现这个效果。在看帮助文档里面有一个样式是Qt::DotLine,如下图所示,是不是就可以实现点了。

image-20221130191734673

结果就是发现我还是太淡出了,如果真的可以这么简单,那就好了。

到时很简单,就是两行代码,如下

gCustomplot->yAxis->grid()->setPen(QPen(QColor(188,188,188,188),1,Qt::DotLine));                                                 
gCustomplot->yAxis->grid()->setZeroLinePen(QPen(QColor(188,188,188,188),1,Qt::DotLine));                                     

效果确实差强人意,如下图所示,这密密麻麻的虚线,咋也不想那种心电图上看到的样子,所以还是失败。

在这里插入图片描述

第二版本,通过设置背景

其实就是我发现在设置背景时候,可以通过画刷QBursh来实现背景填充,而我又碰巧发下QBrush中有一个Qt::Dense7Pattern填充很可能可以使用,如下图所示。所以,这个一度让我以为可以解决这个问题,甚至主动报告领导缩短了时间(这个时候其实脑子已经进水了)。

image-20221130192856073

要么说听话要听后半截呢,所以还是有看我后面的但是。但是呢,效果确实更为渣渣,如下图所示。

image-20221130192738222

其实看到这个效果的时候,我就觉得我今晚是要和我的小椅子摩擦摩擦一晚上了,真实麻烦他们给麻烦开门,麻烦到家了,为啥要和领导说可以今天搞定的,真实,阿西。

第三版本,回到QPen Style

就在我一筹莫展,瞎扒拉Qt 帮助文档的时候,发现了一个神奇的东西。Qt::CustomDashLine这个翻译一下不就是自定义虚线吗。哎嗨嗨,如果使用这个自定义虚线结合第一版的网格,是不是就可以试下了。

要么说这帮助文档还得属Qt 了,连怎么用都给你了,如下所示。

image-20221130193650869

大致就是先定义个容器,这个容器就是用来存放你自定义虚线的参数的,和面又定义了space的变量,这个看字面意思也就是间隔,空格的意思,那肯定就是空白部分了。再就是把你要显示的长度个间隔按照你的需求,存入到这个容器中。完了通过一个叫setDashPattern()接口放到你的画笔中,就可以绘制自己定义的曲线了。这人家都给说的这么明白了,咱要是再不试一试,那岂不是对不起这文档了。所以撸起代码了,先看下核心代码

 QPen gridPen;                                            /// 自定义一个画笔gridPen.setColor(QColor(188,188,188,188));            /// 设置画笔颜色QVector<qreal> myDothline;                            /// 定义一个容器,用来存放自定义曲线的内容数据qreal space = 25;                                     /// 定义曲线间隔myDothline << 0.2 << space;                           /// 将自定义曲线数据装入数组gridPen.setDashPattern(myDothline);                   /// 将自定义的曲线装在到自定义的画笔中gridPen.setWidth(3);                                  /// 设置线宽gridPen.setCapStyle(Qt::RoundCap);gridPen.setJoinStyle(Qt::RoundJoin);gCustomplot->yAxis->setBasePen(QPen(QColor(0,0,0,0)));// 设置Y轴基础颜色gCustomplot->yAxis->setTickLabels(false);             // 设置不显示刻度值gCustomplot->yAxis->setSubTicks(false);               // 设置不显示子刻度线gCustomplot->yAxis->setTicks(false);                  // 设置不显示刻度线gCustomplot->yAxis->grid()->setPen(gridPen);          // 设置线样式gCustomplot->yAxis->grid()->setZeroLinePen(gridPen);  // 设置0刻线样式

效果就出来了,如下

wwwwwwwwwww

这里需要注意两个参数,就是线宽和这个自定义曲线的长度,即myDothline << 0.2 << space; 中的0.2gridPen.setWidth(3) 中的3这两需要大家不断修改和测试,我开始出来的都是横短线,慢慢修改这两个参数,最终出现了这种看着基本就是小圆点的效果。

所以到这里,基本就完成了我这个点阵背景的需求了。希望对小伙伴你也有一定帮助。

取曲线上的点

这个有的抄,基本调试一下就可以使用。这里就直接上代码(这个也是我抄来的,稍微加入了一点点自己的逻辑)

void XXXXXXXXXXXX::slot_showTracer(bool isShow)
{mflagIsShowTracer = isShow;if(mflagIsShowTracer){if(!tracer)tracer = new QCPItemTracer(gCustomplot);                                // 生成游标tracer->setPen(QPen(Qt::white));                                            // 圆圈轮廓颜色tracer->setBrush(QBrush(Qt::white));                                        // 圆圈圈内颜色tracer->setStyle(QCPItemTracer::tsCircle);                                  // 圆圈tracer->setSize(5);                                                         // 设置大小tracer->setVisible(false);                                                  // 需要线隐藏,不然不然会触发默认现实Bugif(!tracerLabel)tracerLabel = new QCPItemText(gCustomplot);                             // 生成游标说明tracerLabel->setText("");tracerLabel->setLayer("overlay");                                           // 设置图层为overlay,因为需要频繁刷新//        tracerLabel->setPen(QPen(Qt::green));                                     // 设置游标说明颜色tracerLabel->setColor(QColor(255,0,255));tracerLabel->setPositionAlignment(Qt::AlignLeft | Qt::AlignTop);            // 左上tracerLabel->position->setParentAnchor(tracer->position);                   // 将游标说明锚固在tracer位置处,实现自动跟随tracerLabel->setVisible(false);                                             // 需要线隐藏,不然不然会触发默认现实Bug}else{tracer->setVisible(false);tracerLabel->setVisible(false);}
}

鼠标移动槽函数,这里其实也可以不这么写,可以直接重写QCustomplot的鼠标移动函数。

void XXXXXXXXXXXX::slot_mouseMove(QMouseEvent *e)
{if(mflagIsShowTracer){tracer->setVisible(true);tracerLabel->setVisible(true);double x = gCustomplot->xAxis->pixelToCoord(e->pos().x());                      // 获得鼠标位置处对应的横坐标数据xtracer->setGraph(gCustomplot->graph(0));                                        // 将游标和该曲线图层想连接tracer->setGraphKey(x);                                                         // 将游标横坐标设置成刚获得的横坐标数据xtracer->setInterpolating(false);                                                // 游标的纵坐标可以通过曲线数据线性插值自动获得tracer->updatePosition();                                                       // 使得刚设置游标的横纵坐标位置生效//更新游标说明的内容//        double xValue = tracer->position->key();double yValue = tracer->position->value();tracerLabel->setText(QString("%1 μV").arg(yValue));gCustomplot->replot();                                                          // 重绘}}

这样写成槽函数的话,需要在代码中再关联一下槽函数,这样就实现了拾取点了。

connect(gCustomplot,&QCustomPlot::mouseMove,this,&Turing_Monitor_Kernel::slot_mouseMove);

博客签名2021

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

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

相关文章

VS Code + Vue 开发环境搭建

1、下载并安装 Visual Studio Code 2019 2、Visual Studio Code 2019安装成功后&#xff0c;打开VS Code 工具点击左侧【扩展】菜单&#xff0c;在搜索栏中输入 Chinese 查找中文语言汉化包插件下载安装&#xff0c;然后重启VS Code 3、点击左侧【扩展】菜单&#xff0c;在搜…

WebDAV之葫芦儿·派盘+静读天下

静读天下 支持webdav方式连接葫芦儿派盘。 如今,很多人都喜欢在手机上进行阅读,所以想要获得更好的阅读体验,一款实用的电子书就显得尤为重要了,因此,静读天下这款纯正的本地电子书阅读软件您值得拥有,而且还支持本地电子书备份到葫芦儿派盘。 静读天下是一款备受千万…

【问题思考总结】NAT的公有地址怎么转换为私有地址?【MAC地址和IP地址的转换】

问题起源 在做一道题的时候&#xff0c;涉及到了由内网到外网再到内网时的IP地址转换。在外网的时候&#xff0c;答案说的是不能够用私有IP地址作为源IP地址&#xff0c;然后疑问产生了&#xff1a;如果不能用私有IP地址作为目的地址&#xff0c;他又怎么能够找到那个主机呢&a…

在 Node.js 中操作 Redis

在 Node.js 中操作 Redis Node.js 中可以操作 Redis 的软件包推荐列表&#xff1a;https://redis.io/clients#nodejs。 推荐下面两个&#xff1a; node-redisioredis 这里主要以 ioredis 为例。 ioredis 是功能强大的 Redis 客户端&#xff0c;已被世界上最大的在线商务公司…

MySQL日志管理、备份与恢复

文章目录一、mysql常用日志1、概述①、错误日志②、二进制日志③、中继日志④、慢查询日志⑤、通用查询日志&#xff0c;用来记录MySQL的所有连接和语句&#xff0c;默认是关闭的2、数据库中查询日志状态①、查看二进制日志开启状态②、查看慢查询日志功能是否开启③、查看慢查…

GAN生成漫画脸

最近对对抗生成网络GAN比较感兴趣&#xff0c;相关知识点文章还在编辑中&#xff0c;以下这个是一个练手的小项目~ (在原模型上做了&#xff0c;为了减少计算量让其好训练一些。) 一、导入工具包 import tensorflow as tf from tensorflow.keras import layersimport numpy a…

业务:财务会计业务知识

一、引言 会计是以货币为主要计量单位&#xff0c;对企业、事业、机关、团体及其他经济组织的经济活动进行记录、计算、控制、分析、报告&#xff0c;以提供财务和管理信息的工作。会计的职能主要是反映和控制经济活动过程&#xff0c;保证会计信息的合法、真实、准确和完整&a…

校园论坛网站设计设计与实现

项目描述 临近学期结束&#xff0c;还是毕业设计&#xff0c;你还在做java程序网络编程&#xff0c;期末作业&#xff0c;老师的作业要求觉得大了吗?不知道毕业设计该怎么办?网页功能的数量是否太多?没有合适的类型或系统?等等。这里根据疫情当下&#xff0c;你想解决的问…

网页JS自动化脚本(四)修改元素的尺寸颜色显隐状态

修改元素尺寸 在定位到了元素之后, 我们就可以对元素进行一些修改了,我们先来修改元素泊宽度以及高度 window.onloadfunction(){var theElementdocument.querySelector("img.undertips-link-lefticon");theElement.style.width"100px";theElement.style.…

命令模式

文章目录思考命令模式1.命令模式的本质2.何时选用命令模式3.优缺点4.实现耦合写法命令模式优化耦合写法命令模式实现撤销命令模式实现厨师做菜命令模式实现排队命令模式实现日志持久化思考命令模式 命令模式就是解耦强耦合代码&#xff0c;用户只关心功能的实现&#xff0c;开发…

win11该文件没有与之关联的应用怎么办

win11用户在使用电脑的时候遇到了“该文件没有与之关联的应用”的提示&#xff0c;这是怎么回事呢&#xff1f;应该怎么办呢&#xff1f;出现这个情况应该是注册表被误删了&#xff0c;大家需要新建一个文本文档&#xff0c;然后输入下文提供的指令&#xff0c;之后将其重命名为…

linux不显示当前路径的解决方法

1.输入vim ~/.bashrc进入用户的shell环境变量的配置文件(可以设置环境变量以及通过alias设置别名&#xff09; 2.按下“i”键进入编辑模式(底部显示INSERT&#xff09; 3.修改\w为$PWD&#xff1a; 修改为&#xff1a; 4.按“esc”键后输入":wq"保存并退出&#xff…

Databend 开源周报 #69

Databend 是一款强大的云数仓。专为弹性和高效设计&#xff0c;自由且开源。 即刻体验云服务&#xff1a;https://app.databend.com。 New Features multiple catalog 实现删除用户定义目录 (#8820) meta 新增用于删除 key 和使 key 过期的 cli 命令 (#8858) planner 支…

手把手教你做智能合约开源|多文件合约开源|引用文件开源

本文手把手教你使用 区块链浏览器 验证智能合约的三种方式。 验证单一 Solidity 文件 在开始验证之前&#xff0c;我们需要首先部署智能合约。进入 Remix IDE&#xff0c;创建一个合约新文件。复制粘贴下面的代码&#xff1a; // SPDX-License-Identifier: MITpragma solidit…

JAVA学习-java基础讲义02

java基础讲义02一 进制1.1 进制介绍1.2 二进制1.3 任意进制到十进制转换1.4 十进制到任意进制之间的转换1.5 快速转换法1.6 有符号数据表示法二 Java变量和数据类型1.1 变量概述1.2 数据类型1.3 变量定义三 Java数据类型转换3.1 数据类型转换概述3.2 数据类型转换之自动类型转换…

[附源码]Python计算机毕业设计SSM老年公寓管理系统(程序+LW)

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

爬虫工作流程、请求与响应原理、requests库讲解

爬虫工作流程、请求与响应原理、requests库讲解 爬虫分类主要分为两大板块 web爬虫&#xff08;浏览器爬虫&#xff09; APP爬虫&#xff08;手机端爬虫&#xff09; 在这两大板块中又可以把爬虫归类为聚焦爬虫和通用爬虫 聚焦爬虫&#xff1a;针对某一个接口&#xff08;ur…

使用Conda

0. Anaconda Prompt 命令提示符 0.1 验证conda是否被安装 conda --version0.2 conda管理环境 可以用命令复制和删除环境 参考. 1. Conda管理包 1.1 常用包管理功能 查找包查看包安装包 查找分为精确查找和模糊查找&#xff0c;如下图所示 卸载包更新包 1.2 conda管理环…

三肽Gly-Cys-Gly、88440-55-5

三肽Gly-Cys-Gly 编号&#xff1a;111774 CAS号&#xff1a;88440-55-5 三字母&#xff1a;H2N-Gly-Cys-Gly-COOH 描 述&#xff1a;羧肽酶 U 抑制剂&#xff08;凝血酶可激活的纤维蛋白溶解抑制剂&#xff0c;TAFI&#xff09;&#xff0c;Ki 0.14 μM。编号: 111774 中文名称…

安装 laravel 遇到的错误和解决方案

安装 laravel 遇到的错误和解决方案 纯粹是为了运行下 laravel&#xff0c;遇到了错误记录下&#xff0c;分享给需要的人。 下载 PHP Windows 版 &#xff0c;我选择的版本是 PHP 7.4 (7.4.33)。下载文件以后找个文件夹解压就可以了。Composer 安装&#xff0c;官网 。 勾选以…