Qt之QCustomPlot的二次封装:实现支持多数据线条的时间轴实时动态曲线显示的widget类

前言

在这里读了不少关于Qt图表的文章,遇到了不少大神的文章让我受益匪浅,但遇到更多的是不接地气的事例。一看文章便知道作者肯定没干过工程的,写Qt代码还是基于“玩票儿”或者学习,和真正用于工程实践的东西严重脱节的。
所以从今天开始,我会陆续对Qt的一些关于图表方面的知识一边学习,一边进行介绍,和很多博主不同的是,文章产生的相关代码,是一定可以直接拿到工程实践中方便使用的。
废话不多说,今天就介绍一个基于QCustomPlot第三方图表类而实现的时间轴实时曲线图表。

开发环境的搭建

我使用的Qt版本是:Qt 5.8.0(MSVC 2015,32bit),Qt Creator 4.2.1。如何安装就不多介绍了。
第三方控件QCustomPlot是我从官方网站上下载的,大家可以去下载,也可以从本文的附件里获得,下面就简单介绍一下如何让你的工程支持QCustomPlot。
新建一个Qt Widget Application工程。

现在我们把QCustomPlot.h和QCustomPlot.cpp拷贝到工程的目录里面,记住,是你的开发目录,不是build开头的那个编译生成的文件夹,然后将其加入到工程中。
然后在pro文件中的greaterThan(QT_MAJOR_VERSION, 4): QT += widgets后面加一个词:printsupport
到这里,你的工程就支持QCustomPlot类了,是不是很简单,接下来我就对如何封装一个支持多曲线实时显示的图表控件做下介绍。

关键步骤介绍

新建一个Qt 设计师界面类

这个类就是我们要进行二次封装的载体,很多人直接拿代码实现界面。个人认为,除非你是大牛,否则作为入门不深的开发者,还是老老实实的直接靠拖拽来实现自己的Widget吧,提升复用啥的也方便,笨人有笨办法,先学会走再想着飞,否则你就算实现了,也不知道怎么在工程里使用。
Qt设计师界面类是入门不深的开发者的福音

我给我新建的Widget类取名叫TimeDynamicListForm,然后在他的上面拖入一个Widget,我给它起个名字叫custom_plot_widget,然后栅格化,让它铺满整个Form。
在这里插入图片描述
选中custom_plot_widget,右键“提升为”,将其提升成QCustomPlot,头文件默认即可,然后点击“添加”,然后再点“提升”,编译一下,如果没有错,说明你搭的环境成功了。
在这里插入图片描述
为了进一步验证,在mainwindow里面拽出来一个Widget,然后把它提升为咱们自定义的TimeDynamicListForm,方法和刚才提升QCustomPlotL类似,这也是以后我们复用自定义widget的方法,再次编译,如果你得到了这样界面,说明准备工作已经完成了。
在这里插入图片描述
好了,准备工作就绪,下面我对实现动态实时显示的关键代码进行介绍。

InitTimeAxis函数:初始化横坐标,让其作为时间轴

void TimeDynamicListForm::InitTimeAxis(int temp_tick_count,double max_second)
{
   
    QSharedPointer<QCPAxisTickerDateTime> date_time_ticker(new QCPAxisTickerDateTime);

    date_time_ticker->setDateTimeFormat("hh:mm:ss");//显示格式

    tick_count=temp_tick_count;
    date_time_ticker->setTickCount(tick_count);//刻度数设置
    date_time_ticker->setTickStepStrategy(QCPAxisTicker::tssMeetTickCount);

    ui->custom_plot_widget->xAxis->setTickLabelRotation(1);//刻度线稍微倾斜,节省空间,参数是角度

    ui->custom_plot_widget->xAxis->setTicker(date_time_ticker);//将其作用于x坐标轴

    //1作为最小单位刻度
    ui->custom_plot_widget->xAxis->setSubTickLength(1);

    max_second_count=max_second;//max_second_count是类成员变量,这里只赋值,在其他函数中使用
}

第一个参数是设置刻度的数量的;第二个参数是设置最大要显示的秒数,这个函数只是赋了值,会在其他函数中使用。
在mainwindow中调用完后编译,效果是这样的:
在这里插入图片描述

SetValueState函数:设置线条的个数、标题等

void TimeDynamicListForm::SetValueState(QStringList temp_title_list, QList<QColor> color_list)
{
   
    cur_line_count=temp_title_list.count();

    int count=color_list.count();

    if(cur_line_count!=count)
    {
   
        return;
    }

    if(cur_line_count>MAX_TIME_DYNAMIC_LINES_COUNT)
    {
   
        cur_line_count=MAX_TIME_DYNAMIC_LINES_COUNT;
    }

    title_list.clear();

    for(int i=0;i<cur_line_count
  • 7
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
### 回答1: 在Qt5中使用QCustomPlot显示实时曲线可以分为以下几个步骤: 1. 首先,需要在Qt项目中添加QCustomPlot库。可以通过在.pro文件中添加`LIBS += -lqcustomplot`来链接该库。 2. 在界面上添加一个QCustomPlot控件,可以通过Qt设计器拖放方式或者手动添加。 3. 创建一个来处理数据的更新和绘图操作。这个需要继承QObject和QCustomPlot,并且实现一个槽函数用于接收新的数据。我们可以将这个称为RealtimePlot。 4. 在RealtimePlot的构造函数中初始化QCustomPlot控件,并设置相关属性,如坐标范围、轴标签等。 5. 在RealtimePlot实现绘制曲线的方法,可以使用QCPGraph对象来表示曲线,并使用addData()方法来添加新的数据点。 6. 在RealtimePlot实现一个槽函数,用于接收新的数据。当有新的数据到达时,将其添加到QCustomPlot控件中,并调用replot()方法进行重绘。 7. 在主窗口中创建一个实例对象,以便在主窗口中显示实时曲线。可以将RealtimePlot作为主窗口的成员变量,然后在构造函数中初始化。 8. 在主窗口中启动一个定时器,可以使用QTimer来定时获取新的数据并发送给RealtimePlot对象。 以上就是使用Qt5QCustomPlot显示实时曲线的基本步骤,具体的实现方式可能会依据个人或项目的需求略有不同。 ### 回答2: 在Qt5中,可以使用QCustomPlot库来显示实时曲线。 首先,需要在项目中引入QCustomPlot库。可以将该库的头文件和源文件添加到项目中,并在.pro文件中添加相应的配置。 接下来,在要显示实时曲线的窗口中创建一个QCustomPlot对象,作为曲线的绘图区域。 然后,可以通过QTimer来定时更新曲线数据。创建一个QTimer对象,并设置其定时器的时间间隔。 在定时器的槽函数中,可以更新曲线数据。首先,获取QCustomPlot的坐标轴对象,然后使用addData()函数添加新的数据点。可以通过setDataRange()函数来设置坐标轴的范围。 最后,调用replot()函数来刷新曲线显示。 下面是一个简单的示例: ``` // MainWindow.h #ifndef MAINWINDOW_H #define MAINWINDOW_H #include <QMainWindow> #include "qcustomplot.h" class MainWindow : public QMainWindow { Q_OBJECT public: MainWindow(QWidget *parent = nullptr); ~MainWindow(); private: QCustomPlot *m_plot; QTimer *m_timer; QVector<double> m_data; int m_count; private slots: void updateData(); }; #endif // MAINWINDOW_H // MainWindow.cpp #include "mainwindow.h" MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent) { m_plot = new QCustomPlot(this); setCentralWidget(m_plot); m_timer = new QTimer(this); connect(m_timer, SIGNAL(timeout()), this, SLOT(updateData())); m_timer->start(1000); // 定时器间隔为1秒 m_data.resize(100); m_count = 0; } MainWindow::~MainWindow() { delete m_timer; } void MainWindow::updateData() { m_data.removeFirst(); m_data.append(qrand() % 100); m_plot->graph(0)->setData(QVector<double>::fromStdVector(m_data.toStdVector())); m_plot->xAxis->setRange(0, m_count); m_plot->replot(); m_count++; } ``` 通过以上代码,就可以在Qt5中使用QCustomPlot显示实时曲线了。可以根据实际需求进行相应的调整,例如添加不同的曲线、设置坐标轴、定时器间隔等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值