QCustomPlot系列(4)

您所在的位置:网站首页 横轴日期纵轴数据折线图 QCustomPlot系列(4)

QCustomPlot系列(4)

2024-06-19 18:20| 来源: 网络整理| 查看: 265

先看两个小知识: 1、显示数据散点:ui->customPlot->graph(0)->setScatterStyle(QCPScatterStyle(QCPScatterStyle::ssDisc, 5));//散点

2、连接散点的方式:customPlot->graph(0)->setLineStyle(QCPGraph::lsStepLeft); 有好几种:折线连接、左端点阶梯连接、右端点阶梯连接等。

 

 

QCustomPlot支持以数值、日期、时间做X轴。

数值就不说了,只讲一下:1、日期,2、时间

1、日期做X轴,可以显示出:年-月-日-时-分-秒-毫秒, 

X轴的数据以1970-01-01 00:00:00至当前时间的总秒数,关于“总秒数”可参考:qint64 QDateTime::currentSecsSinceEpoch()。 如果想在X轴显示出毫秒数,那么只能把X值用到小数位,可以用 “总毫秒数”:qint64  QDateTime::currentMSecsSinceEpoch() 除以1000.0f来设置X值。

例如:

若某个点的X值=0,则该点在图中的X坐标会显示为1970-01-01 00:00:00 若某个点的X值=5,则该点在图中的X坐标会显示为1970-01-01 00:00:05 若某个点的X值=3601,则该点在图中的X坐标会显示为1970-01-01 01:00:01   (3601秒为1个小时零1秒) 若某个点的X值=1596415566,则该点在图中的X坐标会显示为2020-08-03 08:46:06

示例:

QVector time(200), value(200); for(int i = 0; i < time.count(); i++) { time[i] = QDateTime::currentSecsSinceEpoch() + i;//方法1:以此刻的时间做X轴(总秒数),一秒一个值 //time[i] = QDateTime::currentMsecsSinceEpoch() / 1000.0 + i;//方法2 value[i] = qrand() % 10 - 5;//[-5, 5]随机数做y值 }//生成模拟数据 ui->customPlot_2->setInteractions(QCP::iRangeDrag | QCP::iRangeZoom | QCP::iSelectPlottables);//添加鼠标拖放支持、滚轮缩放支持 ui->customPlot_2->addGraph(); ui->customPlot_2->graph(0)->setData(time, value);//设置数据源 ui->customPlot_2->graph(0)->rescaleAxes(); QSharedPointer dateTicker(new QCPAxisTickerDateTime);//日期做X轴 dateTicker->setDateTimeFormat("yy-MM-dd hh:mm:ss");//日期格式(可参考QDateTime::fromString()函数) ui->customPlot_2->xAxis->setTicker(dateTicker);//设置X轴为时间轴

 

 

2、时间做X轴

时间做X轴可以显示:日-时-分-秒-毫秒,举几个例子: X值为0时,代表第0天0时0分0秒0毫秒, X值为1时,代表第0天0时0分1秒0毫秒 X值为2.389时,代表第0天0时0分2秒389毫秒 X值为3601时,代表第0天1时0分1秒0毫秒 以此类推。

#pragma execution_character_set("utf-8")//避免中文乱码 QVector time(20), value(20); for(int i = 0; i < time.count(); i++) { time[i] = 3600 * 24 * 3 + 3600 * 2 + i * 0.1;//模拟从第3天2点整开始,每100ms一个数 value[i] = qrand() % 10 - 5; } ui->customPlot_2->setInteractions(QCP::iRangeDrag | QCP::iRangeZoom | QCP::iSelectPlottables); ui->customPlot_2->addGraph(); ui->customPlot_2->graph(0)->setData(time, value); ui->customPlot_2->graph(0)->rescaleAxes(); ui->customPlot_2->graph(0)->setLineStyle(QCPGraph::lsStepLeft);//左端点阶梯线样式 ui->customPlot_2->graph(0)->setScatterStyle(QCPScatterStyle(QCPScatterStyle::ssDisc, 5));//显示散点 QSharedPointer dateTicker(new QCPAxisTickerTime); dateTicker->setTimeFormat("%h:%m:%s.%z\n第%d天");//时间格式,参考本函数的帮助文档 ui->customPlot_2->xAxis->setTicker(dateTicker);

 

 

 

 

 



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3