QCustomPlot系列(4)-时间轴做X轴-散点图-阶梯图

先看两个小知识:
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值。

示例:

QVector time(200), value(200);
    for(int i = 0; i < time.count(); i++)
    {
        time[i] = QDateTime::currentSecsSinceEpoch() + i;//以此刻的时间做X轴(总秒数),一秒一个值
        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轴为时间轴

QCustomPlot系列(4)-时间轴做X轴-散点图-阶梯图_第1张图片

 

 

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);

QCustomPlot系列(4)-时间轴做X轴-散点图-阶梯图_第2张图片

 

 

 

 

 

你可能感兴趣的:(QT,QT/QCustomPlot)