QT QCharts QScatterSeries 空心点阵图,鼠标移动到上面显示数值,鼠标移开数值消失
在最近接到的需求是这样的,画一个折线图,关键点使用空心的圆点标识出来,鼠标移动到关键点上,显示出当前数值;鼠标移走数值消失。
我们遇到这个需求的时候,第一时间就会想到使用 QLineSeries 画折线图。首先初始化
- QChart *chart = new QChart();
- chart->legend()->setVisible(false);
- ui->chartView->setChart(chart);
- ui->chartView->setRenderHint(QPainter::Antialiasing);
- chart->setBackgroundBrush(QBrush(QColor(248, 251, 255)));
将每个点添加到QLineSeries序列中。然后就会形成折线图。如下:
- QChart *chart = ui->chartView->chart();
- chart->removeAllSeries();
- chart->removeAxis(chart->axisX());
- chart->removeAxis(chart->axisY());
- //折线图
- QLineSeries *series0 = new QLineSeries();
- QPen pen;
- pen.setStyle(Qt::SolidLine);
- pen.setWidth(4);
- pen.setColor(QColor(21, 100, 255));
- series0->setPen(pen);//折现序列的线条设置
- QLineSeries *series0 = (QLineSeries *)ui->chartView->chart()->series().at(0);
- series0->clear();
- qsrand(QTime::currentTime().second());
- qreal t=0, y1, intv=1;
- qreal rd;
- int cnt=16;
- for (int i=0; i<cnt; i++)
- {
- rd = (qrand() % 100);
- y1=rd;
- series0->append(t, y1);
- t+=intv;
- }
这是完成了第一步,画出来了折线图。但是对于那些圆点要显示出来的话我们可以考虑使用QScatterSeries来画一些离散的点。
- QScatterSeries *series1 = new QScatterSeries();
- series1->setMarkerShape(QScatterSeries::MarkerShapeCircle);//圆形的点
- series1->setBorderColor(QColor(21, 100, 255)); //离散点边框颜色
- series1->setBrush(QBrush(QColor(21, 100, 255)));//离散点背景色
- series1->setMarkerSize(12); //离散点大小
- QLineSeries *series0 = (QLineSeries *)ui->chartView->chart()->series().at(0);
- QScatterSeries *series1 = (QScatterSeries *)ui->chartView->chart()->series().at(1);
- series0->clear();
- series1->clear();
- qsrand(QTime::currentTime().second());
- qreal t=0, y1, intv=1;
- qreal rd;
- int cnt=16;
- for (int i=0; i<cnt; i++)
- {
- rd = (qrand() % 100);
- y1=rd;
- series0->append(t, y1);
- series1->append(t, y1);
- t+=intv;
- }
然后我们添加了一些离散的点,效果如下图:
很显然,虽然添加了离散的圆形的点,但是并没有满足我们的需求,因为需求是空心的圆点。而且控件也没提供相关函数可以设置成空心。但是这里面有3个函数值得注意
- series1->setBorderColor(QColor(21, 100, 255)); //离散点边框颜色
- series1->setBrush(QBrush(QColor(21, 100, 255)));//离散点背景色
- series1->setMarkerSize(12); //离散点大小
因为可以设置一个点的大小,边框和颜色。那我们如果想实现一个空心的离散点就可以这样做:
以同一个位置为圆心,画两个半径不同的实心圆。下面的圆半径大,颜色就是边框的颜色蓝色;上面的圆形半径小,颜色设置为白色。这样两个圆形叠加起来的效果,视觉上就是一个空心的圆形。按照这个思路,我们需要使用2个QScatterSeries序列
series0 : 半径较大,背景为蓝色,充当边框。
series1:半径较小,北京为白色,充电圆心。
- //散点图(用于边框)
- QScatterSeries *series1 = new QScatterSeries();
- series1->setMarkerShape(QScatterSeries::MarkerShapeCircle);//圆形的点
- series1->setBorderColor(QColor(21, 100, 255)); //边框颜色
- series1->setBrush(QBrush(QColor(21, 100, 255)));//背景颜色
- series1->setMarkerSize(12); //点大小
- //散点图(用于中心)
- QScatterSeries *series2 = new QScatterSeries();
- series2->setMarkerShape(QScatterSeries::MarkerShapeCircle);//圆形的点
- series2->setBorderColor(Qt::white);//边框颜色
- series2->setBrush(QBrush(Qt::white));//背景颜色
- series2->setMarkerSize(6);//点大小
- chart->addSeries(series1);
- chart->addSeries(series2);
- QLineSeries *series0 = (QLineSeries *)ui->chartView->chart()->series().at(0);
- QScatterSeries *series1 = (QScatterSeries *)ui->chartView->chart()->series().at(1);
- QScatterSeries *series2 = (QScatterSeries *)ui->chartView->chart()->series().at(2);
- series0->clear();
- series1->clear();
- series2->clear();
- qsrand(QTime::currentTime().second());
- qreal t=0, y1, intv=1;
- qreal rd;
- int cnt=16;
- for (int i=0; i<cnt; i++)
- {
- rd = (qrand() % 100);
- y1=rd;
- series0->append(t, y1);
- series1->append(t, y1);
- series2->append(t, y1);
- t+=intv;
- }
效果如下:
做完这些,我们还有最后一个需求就是鼠标移动到这些离散的点上,要显示出当前点的数值。由于框架并没有提供相关的api,所以我们要自己完成这项工作。我们可以想象,显示的数值需要使用QLabel承载,当鼠标移动到这些点上,QLabel就show,移开就hide。那么怎么确定鼠标是否移动到这些离散点上呢?查阅文档,我们发现QCatterSeries有这样一个信号
他的意思就是,这是一个信号,当鼠标移动到上面,或者从上面移开就会发射这个信号,其中point是移动到哪个点上,当移动到上面,state=true;否则state就为false。
我们可以连接这个信号到我们自己的槽函数
connect(series2, &QScatterSeries::hovered, this, &TDMTrendChartForm::slotPointHoverd);//用于鼠标移动到点上显示数值
- void TDMTrendChartForm::slotPointHoverd(const QPointF &point, bool state)
- {
- if (state) {
- m_valueLabel->setText(QString::asprintf("%1.0f%", point.y()));
- QPoint curPos = mapFromGlobal(QCursor::pos());
- m_valueLabel->move(curPos.x() - m_valueLabel->width() / 2, curPos.y() - m_valueLabel->height() * 1.5);//移动数值
- m_valueLabel->show();//显示出来
- }
- else
- m_valueLabel->hide();//进行隐藏
- }
======================================================================================
补充:完善了代码。增加鼠标悬浮在离散点上,应该显示渐变的边框。
这样我们就完成了相关功能。完整代码可以在这里下载:https://download.csdn.net/download/xiezhongyuan07/10675931
======================================================================================
--------------------- 本文来自 漫步繁华街 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/xiezhongyuan07/article/details/82760103?utm_source=copy
QT QCharts QScatterSeries 空心点阵图,鼠标移动到上面显示数值,鼠标移开数值消失的更多相关文章
- jq实现鼠标移动到 图片上放大,移开图片缩小效果(打算封装成插件)
先看代码 <script> $(function() { $('div').mouseover(function() { $('img').animate({ opacity: '0.9' ...
- WPF 鼠标移动到图片变大,移开还原,单击触发事件效果
<Grid> <Canvas x:Name="LayoutRoot"> <Image Cursor=" ...
- 鼠标划过用户名时在鼠标右下角显示div展示用户资料
最近做一个网站论坛,为了方便会员之间相互了解,又不想再做一个页面展示用户资料,就想到了鼠标划过用户名时在鼠标右下角显示div展示用户资料这个效果, 这里要注意的该方法不是给每个用户名的旁边都绑定一个d ...
- 一个用 js 实现点阵图的编辑器演示
这是个客户的需求,具体大概是可以在一个 24*8 的点阵图上自由绘制图形,然后数据的存储是按列依次记录,用0和1分别表示是否选中,最终串成一个字符串. 整体需求难度并不复杂,所以在写demo的时候就尽 ...
- Qt实战之开发软件数据获取助手(eventFilter处理鼠标按下,event处理鼠标松开)
前段时间,受朋友委托,需要做一个能够获取别人软件文本框中内容的助手.当然这需要调用win api来解决问题.一开始,我想都没想,就用getWindowText()....居然没用,好郁闷.于是查msd ...
- 自己定义View之Chart图标系列(1)——点阵图
近期要做一些图表类的需求,一開始就去github上看了看,发现开源的图表框架还是蛮多的.可是非常少有全然符合我的需求的.另外就是使用起来比較麻烦.所以就决定自己来造轮子了~~~ 今天要介绍的就是And ...
- Android实现二值点阵图识别
好好学习,天天向上 本文已收录至我的Github仓库DayDayUP:github.com/RobodLee/DayDayUP,欢迎Star 前言 我这几天在做一个东西,就是一张像二维码这样的 n*n ...
- 小问题总结:鼠标点击到输入框(input)里的时候,输入框的提示消失,鼠标再移开,输入框提示出现
问题如标题: 鼠标点击到输入框(input)里的时候,输入框的提示消失,鼠标再移开,输入框提示出现.如图所示: 做法如下: <input type="text" name ...
- CSS3鼠标悬停图片上浮显示描述代码
效果:http://hovertree.com/texiao/css3/20/ 效果图: 代码如下: <!doctype html> <html lang="zh" ...
随机推荐
- Dubbo的特点
1.介绍 DUBBO有良好的连通性.健壮性.伸缩性.升级性.结合dubbo可以相对于单体系统提升系统整体的扩展性 2. 连通性 注册中心负责服务地址的注册与查找,相当于目录服务,服务提供者和消费者只在 ...
- hdoj2191 珍惜现在,感恩生活(01背包 || 多重背包)
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=2191 思路 由于每种大米可能不止一袋,所以是多重背包问题,可以直接使用解决多重背包问题的方法,也可以将 ...
- Request常用方法(转)
原文地址:http://www.lihuai.net/program/python/1617.html Python Requests库:HTTP for Humans 时间: 2014/12/30 ...
- 内核启动文件系统后第一个执行的文件(inittab启动脚本分析)
Linux 开机脚本启动顺序: 第一步:启动内核 第二步:执行init (配置文件/etc/inittab) 第三步:启动相应的脚本,执行inittab脚本,并且执行里面的脚本/etc/init.d ...
- Fiddler手机抓包,相关细节回顾
目录 0. 准备工作 1. Fiddler配置 2. iPhone配置 3. 抓包示例 上篇Fiddler教程,我们教了大家Fiddler安装配置及如何使用Fiddler进行基本的Http抓包及模拟请 ...
- 【Naive Splay Template】
写小作业的时候重新复习了一下splay 只支持插入,删除,查k大,查节点数.没有迭代器. T类型需要重载==和<,要调用拷贝构造函数. template<class T> class ...
- Atcoder681 Typical DP Contest E.数 数位dp
写什么递归....非递归多好写 令$f[i][j]$表示前$i$位的和在模$d$意义下为$j$的方案数,然后转移即可 复杂度$O(10000 * 100 * 10)$ 注意非递归建议高位摆第$n$位. ...
- 2018-2019-2 20162318《网络对抗技术》Exp3 免杀原理与实践
一.实验内容 1.正确使用msf编码器,msfvenom生成如jar之类的其他文件,veil-evasion),加壳工具),使用shellcode编程 2.通过组合应用各种技术实现恶意代码免杀(如果成 ...
- 撩课-Java每天5道面试题第13天
撩课Java+系统架构点击开始学习 96.JDBC操作数据库的步骤 ? .加载数据库驱动 .创建并获取数据库链接 .创建jdbc statement对象 .设置sql语句 .设置sql语句中的参数(使 ...
- [java][jboss]改变jboss部署目录(虚拟目录)
原文: [java][jboss]改变jboss部署目录(虚拟目录) 在开发过程中,有时候我们希望将程序放在我们的源代码目录中,比如d:\code下,而不是放在jboss的deploy下,怎么办? 我 ...