需求

  1. 双Y轴段曲线;
  2. 拽拖分析已有数据;
  2. 支持悬浮显示当前最近x的各段y坐标;
  3. 优化显示性能以及缓存;
  4. 支持各种有颜色的调整‘;
  5. 读取文件或者下位机数据;

 

注意

  Qt相关的二维折线图,采用其他方式都无法实现多段Y轴(非双Y轴,单Y轴多段),包括QCharts、QCustomPlot、Qwt,其他已有的框架内嵌web可实现,基于需要实时采集数据,内嵌web实时体验并不好,于是写了个基础框架,以便实现实时数据的大量采集。

 

Demo

  
  
  

体验下载地址

  CSDN(粉丝免积分下载):https://download.csdn.net/download/qq21497936/13777399
  QQ群:1047134658(点击“文件”搜索“chartDemo”,群内与博文同步更新)

 

V1.1.0


  

 

Demo部分源码

#ifndef LINECHART2WIDGET_H
#define LINECHART2WIDGET_H #include <QWidget>
#include <QColor>
#include <QPainter>
#include <QMouseEvent>
#include <QPointF> class LineChart2Widget : public QWidget
{
Q_OBJECT
public:
explicit LineChart2Widget(QWidget *parent = nullptr); public:
void addData(QVector<QPointF> vectorPoint);
void setData(QVector<QPointF> vectorPoint);
void clear();
void addData2(QVector<QPointF> vectorPoint);
void setData2(QVector<QPointF> vectorPoint);
void clear2(); protected:
QPointF realConvertToChart(QPointF pointF); // 实际点转为图表点坐标
QPointF chartConvertToReal(QPointF pointF); // 图表点坐标转为实际点
QVector<QPointF> realConvertToChart(QVector<QPointF> vectorPointF); // 实际点转为图表点坐标 QPointF realConvertToChart2(QPointF pointF); // 实际点转为图表点坐标
QPointF chartConvertToReal2(QPointF pointF); // 图表点坐标转为实际点
QVector<QPointF> realConvertToChart2(QVector<QPointF> vectorPointF); // 实际点转为图表点坐标 protected:
void paintEvent(QPaintEvent *event);
void showEvent(QShowEvent *event);
void resizeEvent(QResizeEvent *event);
void mousePressEvent(QMouseEvent *event);
void mouseMoveEvent(QMouseEvent *event);
void mouseReleaseEvent(QMouseEvent *event);
void wheelEvent(QWheelEvent *event); protected:
void drawBackground(QPainter *painter); // 绘制背景
void drawMarginBackground(QPainter *painter); // 绘制边框背景(边框的)
void drawAxis(QPainter *painter); // 绘制坐标轴
void drawLabel(QPainter *painter); // 绘制坐标值
void drawLines(QPainter *painter); // 绘制曲线
void drawCursorRealValue(QPainter *painter); // 绘制实际值
void drawMouseCross(QPainter *painter); // 绘制鼠标的十字线
void drawTwoValue(QPainter *painter); // 绘制双轴的X,Y值(最近接X轴的上一个Y点) private:
double _leftMargin; // 左边距离(坐标轴距离左部边框)
double _rightMargin; // 右边距离(坐标轴距离右部边框)
double _bottomMargin; // 底部距离(坐标轴距离底部边框)
double _topMargin; // 顶部距离(坐标轴距离顶部边框)
double _left; // 左部x坐标
double _right; // 右部x坐标
double _top; // 顶部y坐标
double _bottom; // 底部y坐标
double _width; // 宽度
double _height; // 高度 double _minX; // x轴最小值
double _maxX; // x轴最大值 QColor _backgroundColor; // 背景颜色
QColor _axisColor; // 坐标轴颜色
QColor _axisLabelColor; // 坐标轴文本颜色
QColor _lineColor; // 折线颜色
QColor _dataColor; // 矩形文字颜色
QColor _dataBackgroundColor;// 矩形背景颜色 int _xTickCount; // X轴主tick
int _xTickLength; // X轴主tick长度
int _xSubTickCount; // X轴子tick
int _xSubTickLength; // X轴子tick长度 double _xTickDistance; // 临时变量:
double _xSubTickDistance; // 临时变量:
double _xTickValue; // 临时变量:
double _xSubTickValue; // 临时变量:
double _xTickValueScale; // 临时变量:
double _xSubTickValueScale; // 临时变量: bool _leftButtonPressed; // 临时变量:鼠标左键是否按下
QPointF _originPointF; // 临时变量:记录鼠标左键按下的坐标
QPointF _offsetPointF; // 临时变量:偏移的坐标段 QPointF _zeroPointF; // 零点,用于区分x轴和y轴的坐标
QPointF _nowPointF; // 临时变量:零点 double _scale; // 缩放比例 QVector<QPointF> _vectorPointF; // 一条线的存储位置
QVector<QPointF> _vectorPointF2; // 一条线的存储位置
bool _showCursorRealValue; // 是否显示鼠标当前de的值 bool _canDragYAxis; // Y轴是否允许被拖动
bool _showCrossAxis; // 画十字轴 private:
int _yAxisNumber; // 几段Y轴
int _yAxisSpace; // Y轴间距
double _yAxisHeight; // 每一段Y轴高度
double _offsetY; // 临时变量:
int _yTickCount; // Y轴分的主tick
int _yTickLength; // Y轴主tick长度
int _ySubTickCount; // Y轴两个大tick之间的小tick
int _ySubTickLength; // Y轴子tick长度
double _yTickDistance; // 临时变量:
double _ySubTickDistance; // 临时变量: private:
QString _yAxisContent; // 第一段Y轴内容
double _yTickValue; // 临时变量:
double _ySubTickValue; // 临时变量:
double _yTickValueScale; // 临时变量:
double _ySubTickValueScale; // 临时变量: private:
QString _yAxisContent2; // 第一段Y轴内容
double _yTickValue2; // 临时变量:
double _ySubTickValue2; // 临时变量:
double _yTickValueScale2; // 临时变量:
double _ySubTickValueScale2; // 临时变量: private:
double _minY; // y轴最小值
double _maxY; // y轴最大值
double _minY2; // y轴最小值
double _maxY2; // y轴最大值
double _x; // 十字轴的x坐标
double _y1; // 十字轴的导高值
double _y2; // 十字轴的超出值
}; #endif // LINECHART2WIDGET_H
 

若该文为原创文章,转载请注明原文出处
本文章博客地址:https://blog.csdn.net/qq21497936/article/details/111660400

项目实战:Qt多段Y轴折线图框架(双Y轴段折线、支持拽拖、浮动游标显示X值各段Y值、支持大量实时显示下位机数据)的更多相关文章

  1. HighCharts之2D柱状图、折线图的组合多轴图

    HighCharts之2D柱状图.折线图的组合多轴图 1.实例源码 SomeAxis.html: <!DOCTYPE html> <html> <head> < ...

  2. C#使用struct直接转换下位机数据

    编写上位机与下位机通信的时候,涉及到协议的转换,比较多会使用到二进制.传统的方法,是将数据整体获取到byte数组中,然后逐字节对数据进行解析.这样操作工作量比较大,对于较长数据段更容易计算位置出错. ...

  3. iOS Charts 折线图框架的基本使用

    1. 导入框架 通过 cocoapods 管理应用程序时,在 Podfile 文件中,use_frameworks! 的使用区别如下: 使用 use_frameworks! 时 dynamic fra ...

  4. excel制作折线图太麻烦?试试这些折线图在线生成工具

    折线图是以折线的上升或下降来表示统计数量的增减变化的统计图,叫作折线统计图.用折线的起伏表示数据的增减变化情况,不仅可以表示数量的多少,而且可以反映数据的增减变化情况.并且折线图也是目前最方便的一种统 ...

  5. android项目实战 --ListView 头部ViewPager广告轮询图效果

    看开源框架:https://github.com/tianshaojie/AndroidFine,里面有如下效果,特记录学习下,以后项目中用也好能够立刻想起来.   如上面所示,是常见项目中的图片轮训 ...

  6. 【SSH网上商城项目实战03】使用EasyUI搭建后台页面框架

    转自:https://blog.csdn.net/eson_15/article/details/51312490 前面两节,我们整合了SSH并且抽取了service和action部分的接口,可以说基 ...

  7. ucharts的区域图、折线图(有x轴的),修改x轴显示为隔一个显示

    1.原本的显示方式: 2.想要的效果: 3.这边我使用的是uchart的组件,在uni_modules > qiun-data-charts > js_sdk > u-charts, ...

  8. highcharts 柱状图 折线图 混合 双纵轴显示

    $(function () { $('#container').highcharts({ chart: { zoomType: 'xy' }, title: { text: '' }, colors: ...

  9. 项目实战:Qt多通道数据采集系统(通道配置、电压转换、采样频率、通道补偿值、定时采集、导出exel和图表、自动XY轴、隐藏XY轴、实时隐藏显示通道)

    需求   1.通道使能.选择.更改通道名称.设置显示颜色  2.采样率可设置(Sa/s/chj)  3.单位换算,按照给定的进行换算  4.对通道可进行设置补偿值  5.通道取消可动态显示和隐藏,并可 ...

  10. JavaScript数据可视化编程学习(一)Flotr2,包含简单的,柱状图,折线图,饼图,散点图

    一.基础柱状图 二.基础的折线图 三.基础的饼图 四.基础的散点图 一.基础柱状图 如果你还没有想好你的数据用什么类型的图表来展示你的数据,你应该首先考虑是否可以做成柱状图.柱状图可以表示数据的变化过 ...

随机推荐

  1. [转帖]查看请求在nginx中消耗的时间

    需求:查看请求在nginx中消耗的时间,不包括程序响应时间. 1.声明日志的格式,在nginx配置文件nginx.conf里的http下添加如下内容: log_format test '$remote ...

  2. 【转帖】Java Full GC (Ergonomics) 的排查

    文章目录 1. Full GC (Ergonomics) 1.1 Java 进程一直进行 Full GC 1.2 Full GC 的原因 1.3 检查堆占用 2. 代码检查 3. 解决方式 1. Fu ...

  3. [转帖]文件系统读写性能fio测试方法及参数详解

    简介 Fio 是一个 I/O 工具,用来对硬件进行压力测试和验证,磁盘IO是检查磁盘性能的重要指标,可以按照负载情况分成照顺序读写,随机读写两大类. Fio支持13种不同的I/O引擎,包括:sync, ...

  4. docker 发布web项目到linux

    一.准备工作 1.连接到Liunx的工具 MobaXterm 填好Ip 直接点ok就行 输入用户名和密码进入系统 2.已发布的.netcore网站或微服务 在要发布的项目上右键---->添加-- ...

  5. docker上部署启动RabbitMQ

    在docker上部署启动RabbitMQ及使用 一.docker上部署启动RabbitMQ 1.查询rabbitmq镜像 docker search rabbitmq:management 2.拉取r ...

  6. Go Plugin介绍

    以下内容来自官方文档. go version: 1.17.5 综述 plugin包实现了Go插件的加载和符号解析. Go插件是一个包括了可导出函数和变量的main包(可以没有main()函数),构建时 ...

  7. Gin 框架之Cookie与Session

    目录 一.Cookie和Session的由来 二.Cookie简介 1. 什么是Cookie 2. Cookie规范 3. 安全性 4. Cookie 关键配置 三.Session简介 1. 什么是S ...

  8. 加速tortoisegit的show log,减少等待时间

    KMSID: 81703 是否同步到KM: 是 是否原创: 是 标签: 游戏开发 允许复制: 是 允许评论: 是 允许导出PDF: 是 职业库分类KMS: 游戏-游戏程序 查看权限KMS:网易正式员工 ...

  9. python入门之后须掌握的知识点(模块化编程、时间模块)【一】

    相关文章: 全网最详细超长python学习笔记.14章节知识点很全面十分详细,快速入门,只用看这一篇你就学会了! python入门合集: python快速入门[一]-----基础语法 python快速 ...

  10. 【编写环境一】遇到常见python函数处理方式

    1.python实现两个一维列表合并成一个二维列表 >>> list1 = [1,2,3,4,4] >>> list2 = [2,3,4,5,2] >> ...