0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Qt(C++)使用QChart动态显示3个设备的温度变化曲线

DS小龙哥-嵌入式技术 来源:DS小龙哥-嵌入式技术 作者:DS小龙哥-嵌入式技 2023-06-02 09:06 次阅读

一、介绍

Qt的QChart是一个用于绘制图表和可视化数据的类。提供了一个灵活的、可扩展的、跨平台的图表绘制解决方案,可以用于各种应用程序,如数据分析、科学计算、金融交易等。

QChart支持多种类型的图表,包括折线图、散点图、柱状图、饼图等。它还支持多个数据系列(datasets)在同一个图表中显示,并且可以自定义各种图表属性和样式,如坐标轴标签、标题、图例等。

QChart还支持多种数据源(data sources),可以来自Qt的数据模型(data models)、CSV文件、JSON文件等。数据源可以是任何支持迭代器(iterator)的类型,因此可以轻松地与其他Qt组件集成。

使用QChart可以轻松地创建交互式图表,如鼠标悬停提示(hover tooltip)、数据选择(data selection)等。此外,QChart还支持多种主题(themes)和自定义CSS样式,使得图表外观可以灵活地定制。

out

image-20230529143347595

image-20230529143404140

二、实现代码(1)QMainWindow

以下是使用Qt(C++)的QChart模块显示3个设备的动态温度曲线的代码实现:

【1】实现温度动态更新

mainwindow.h

#ifndef MAINWINDOW_H
 #define MAINWINDOW_H#include < QMainWindow >
 #include < QtCharts/QChart >
 #include < QtCharts/QLineSeries >
 #include < QTimer >
 ​
 QT_CHARTS_USE_NAMESPACE
 ​
 namespace Ui {
 class MainWindow;
 }
 ​
 class MainWindow : public QMainWindow
 {
     Q_OBJECT
 ​
 public:
     explicit MainWindow(QWidget *parent = nullptr);
     ~MainWindow();
 ​
 private slots:
     void updateChartData(); // 更新数据槽函数private:
     Ui::MainWindow *ui;
     QTimer *m_timer; // 定时器
 ​
     QChart *m_chart; // 图表指针
 ​
     QLineSeries *m_series1; // 设备1温度曲线
     QLineSeries *m_series2; // 设备2温度曲线
     QLineSeries *m_series3; // 设备3温度曲线int m_timeCount; // 时间计数
 };
 ​
 #endif // MAINWINDOW_H

mainwindow.cpp

#include "mainwindow.h"
 #include "ui_mainwindow.h"
 ​
 MainWindow::MainWindow(QWidget *parent) :
     QMainWindow(parent),
     ui(new Ui::MainWindow),
     m_timer(new QTimer(this)),
     m_chart(new QChart()),
     m_series1(new QLineSeries()),
     m_series2(new QLineSeries()),
     m_series3(new QLineSeries()),
     m_timeCount(0)
 {
     ui- >setupUi(this);
 ​
     // 设置图表标题
     m_chart- >setTitle("Temperature Data");
 ​
     // 创建温度曲线图1并设置属性
     m_series1- >setName(tr("Device 1"));
     m_series1- >setColor(Qt::red);
     m_series1- >setPen(QPen(Qt::red, 2));
     m_chart- >addSeries(m_series1);
 ​
     // 创建温度曲线图2并设置属性
     m_series2- >setName(tr("Device 2"));
     m_series2- >setColor(Qt::green);
     m_series2- >setPen(QPen(Qt::green, 2));
     m_chart- >addSeries(m_series2);
 ​
     // 创建温度曲线图3并设置属性
     m_series3- >setName(tr("Device 3"));
     m_series3- >setColor(Qt::blue);
     m_series3- >setPen(QPen(Qt::blue, 2));
     m_chart- >addSeries(m_series3);
 ​
     // 设置横轴属性
     QValueAxis *axisX = new QValueAxis;
     axisX- >setRange(0, 30);
     axisX- >setTitleText("Time (s)");
     m_chart- >addAxis(axisX, Qt::AlignBottom);
     m_series1- >attachAxis(axisX);
     m_series2- >attachAxis(axisX);
     m_series3- >attachAxis(axisX);
 ​
     // 设置纵轴属性
     QValueAxis *axisY = new QValueAxis;
     axisY- >setRange(0, 60);
     axisY- >setTitleText("Temperature (℃)");
     m_chart- >addAxis(axisY, Qt::AlignLeft);
     m_series1- >attachAxis(axisY);
     m_series2- >attachAxis(axisY);
     m_series3- >attachAxis(axisY);
 ​
     // 定时更新数据
     connect(m_timer, &QTimer::timeout, this, &MainWindow::updateChartData);
     m_timer- >start(1000); // 每隔1秒钟更新一次数据// 将图表添加到ChartView中
     ui- >chartView- >setChart(m_chart);
     ui- >chartView- >setRenderHint(QPainter::Antialiasing);
 }
 ​
 MainWindow::~MainWindow()
 {
     delete ui;
 }
 ​
 void MainWindow::updateChartData()
 {
     // 更新时间计数
     m_timeCount++;
 ​
     // 在温度曲线上增加一个点,模拟温度数据变化
     QPointF p1(m_timeCount, qrand() % 10 + 20);
     QPointF p2(m_timeCount, qrand() % 10 + 30);
     QPointF p3(m_timeCount, qrand() % 10 + 40);
     m_series1- >append(p1);
     m_series2- >append(p2);
     m_series3- >append(p3);
 ​
     // 清除多余的点,只保留最新的30个数据点
     if (m_series1- >count() > 30) {
         m_series1- >removePoints(0, 1);
     }
     if (m_series2- >count() > 30) {
         m_series2- >removePoints(0, 1);
     }
     if (m_series3- >count() > 30) {
         m_series3- >removePoints(0, 1);
     }
 }

在此代码中,定义了一个QTimer定时器对象,用于每隔一段时间更新温度曲线数据。在定时器的timeout信号触发时,调用updateChartData()槽函数来更新温度曲线数据,同时控制数据量不超过30个点。

在updateChartData()函数中,使用了qrand()函数来生成随机的温度数据,模拟动态变化的效果。可以根据实际情况修改此函数的实现方式。

最后,将图表添加到QChartView控件中,并启用抗锯齿功能以提高显示质量。

【2】设置曲线可见范围

为了保证曲线显示一直在可见范围内,可以添加如下代码:

// 使图表自适应大小,确保曲线始终可见
     m_chart- >createDefaultAxes();
     m_chart- >axisX()- >setRange(0, 30);
     m_chart- >axisY()- >setRange(0, 60);

这段代码的作用是让图表自适应大小,并设置横轴范围为0到30,纵轴范围为0到60。这样当新数据点增加到图表之外时,图表会自动调整大小和范围,以确保曲线始终可见。

完整的mainwindow.cpp代码如下所示:

#include "mainwindow.h"
     #include "ui_mainwindow.h"
     ​
     MainWindow::MainWindow(QWidget *parent) :
         QMainWindow(parent),
         ui(new Ui::MainWindow),
         m_timer(new QTimer(this)),
         m_chart(new QChart()),
         m_series1(new QLineSeries()),
         m_series2(new QLineSeries()),
         m_series3(new QLineSeries()),
         m_timeCount(0)
     {
         ui- >setupUi(this);
     ​
         // 设置图表标题
         m_chart- >setTitle("Temperature Data");
     ​
         // 创建温度曲线图1并设置属性
         m_series1- >setName(tr("Device 1"));
         m_series1- >setColor(Qt::red);
         m_series1- >setPen(QPen(Qt::red, 2));
         m_chart- >addSeries(m_series1);
     ​
         // 创建温度曲线图2并设置属性
         m_series2- >setName(tr("Device 2"));
         m_series2- >setColor(Qt::green);
         m_series2- >setPen(QPen(Qt::green, 2));
         m_chart- >addSeries(m_series2);
     ​
         // 创建温度曲线图3并设置属性
         m_series3- >setName(tr("Device 3"));
         m_series3- >setColor(Qt::blue);
         m_series3- >setPen(QPen(Qt::blue, 2));
         m_chart- >addSeries(m_series3);
     ​
         // 设置横轴属性
         QValueAxis *axisX = new QValueAxis;
         axisX- >setRange(0, 30);
         axisX- >setTitleText("Time (s)");
         m_chart- >addAxis(axisX, Qt::AlignBottom);
         m_series1- >attachAxis(axisX);
         m_series2- >attachAxis(axisX);
         m_series3- >attachAxis(axisX);
     ​
         // 设置纵轴属性
         QValueAxis *axisY = new QValueAxis;
         axisY- >setRange(0, 60);
         axisY- >setTitleText("Temperature (℃)");
         m_chart- >addAxis(axisY, Qt::AlignLeft);
         m_series1- >attachAxis(axisY);
         m_series2- >attachAxis(axisY);
         m_series3- >attachAxis(axisY);
     ​
         // 使图表自适应大小,确保曲线始终可见
         m_chart- >createDefaultAxes();
         m_chart- >axisX()- >setRange(0, 30);
         m_chart- >axisY()- >setRange(0, 60);
     ​
         // 定时更新数据
         connect(m_timer, &QTimer::timeout, this, &MainWindow::updateChartData);
         m_timer- >start(1000); // 每隔1秒钟更新一次数据// 将图表添加到ChartView中
         ui- >chartView- >setChart(m_chart);
         ui- >chartView- >setRenderHint(QPainter::Antialiasing);
     }
     ​
     MainWindow::~MainWindow()
     {
         delete ui;
     }
     ​
     void MainWindow::updateChartData()
     {
         // 更新时间计数
         m_timeCount++;
     ​
         // 在温度曲线上增加一个点,模拟温度数据变化
         QPointF p1(m_timeCount, qrand() % 10 + 20);
         QPointF p2(m_timeCount, qrand() % 10 + 30);
         QPointF p3(m_timeCount, qrand() % 10 + 40);
         m_series1- >append(p1);
         m_series2- >append(p2);
         m_series3- >append(p3);
     ​
         // 清除多余的点,只保留最新的30个数据点
         if (m_series1- >count() > 30) {
             m_series1- >removePoints(0, 1);
         }
         if (m_series2- >count() > 30) {
             m_series2- >removePoints(0, 1);
         }
         if (m_series3- >count() > 30) {
             m_series3- >removePoints(0, 1);
         }
     }

【3】实现鼠标交互拖动

要实现折线图的横坐标可以拖动,可以设置QChartView的交互模式为拖拽,在构造函数中添加如下代码:

// 设置 ChartView 交互模式为拖拽
     ui- >chartView- >setRubberBand(QChartView::HorizontalRubberBand);
     ui- >chartView- >setRenderHint(QPainter::Antialiasing);
     ui- >chartView- >setDragMode(QGraphicsView::ScrollHandDrag);

这样用户就可以通过鼠标左键在横轴上拖拽来改变曲线图的可见范围。同时,还需要在mainwindow.cpp中添加横坐标的范围更新函数updateAxisRange(),用于在拖拽时更新横坐标的范围。

完整的mainwindow.cpp代码如下所示:

#include "mainwindow.h"
     #include "ui_mainwindow.h"
     ​
     MainWindow::MainWindow(QWidget *parent) :
         QMainWindow(parent),
         ui(new Ui::MainWindow),
         m_timer(new QTimer(this)),
         m_chart(new QChart()),
         m_series1(new QLineSeries()),
         m_series2(new QLineSeries()),
         m_series3(new QLineSeries()),
         m_timeCount(0)
     {
         ui- >setupUi(this);
     ​
         // 设置图表标题
         m_chart- >setTitle("Temperature Data");
     ​
         // 创建温度曲线图1并设置属性
         m_series1- >setName(tr("Device 1"));
         m_series1- >setColor(Qt::red);
         m_series1- >setPen(QPen(Qt::red, 2));
         m_chart- >addSeries(m_series1);
     ​
         // 创建温度曲线图2并设置属性
         m_series2- >setName(tr("Device 2"));
         m_series2- >setColor(Qt::green);
         m_series2- >setPen(QPen(Qt::green, 2));
         m_chart- >addSeries(m_series2);
     ​
         // 创建温度曲线图3并设置属性
         m_series3- >setName(tr("Device 3"));
         m_series3- >setColor(Qt::blue);
         m_series3- >setPen(QPen(Qt::blue, 2));
         m_chart- >addSeries(m_series3);
     ​
         // 设置横轴属性
         QValueAxis *axisX = new QValueAxis;
         axisX- >setRange(0, 30);
         axisX- >setTitleText("Time (s)");
         m_chart- >addAxis(axisX, Qt::AlignBottom);
         m_series1- >attachAxis(axisX);
         m_series2- >attachAxis(axisX);
         m_series3- >attachAxis(axisX);
     ​
         // 设置纵轴属性
         QValueAxis *axisY = new QValueAxis;
         axisY- >setRange(0, 60);
         axisY- >setTitleText("Temperature (℃)");
         m_chart- >addAxis(axisY, Qt::AlignLeft);
         m_series1- >attachAxis(axisY);
         m_series2- >attachAxis(axisY);
         m_series3- >attachAxis(axisY);
     ​
         // 使图表自适应大小,确保曲线始终可见
         m_chart- >createDefaultAxes();
         m_chart- >axisX()- >setRange(0, 30);
         m_chart- >axisY()- >setRange(0, 60);
     ​
         // 设置 ChartView 交互模式为拖拽
         ui- >chartView- >setRubberBand(QChartView::HorizontalRubberBand);
         ui- >chartView- >setRenderHint(QPainter::Antialiasing);
         ui- >chartView- >setDragMode(QGraphicsView::ScrollHandDrag);
     ​
         // 定时更新数据
         connect(m_timer, &QTimer::timeout, this, &MainWindow::updateChartData);
         m_timer- >start(1000); // 每隔1秒钟更新一次数据// 将图表添加到ChartView中
         ui- >chartView- >setChart(m_chart);
     }
     ​
     MainWindow::~MainWindow()
     {
         delete ui;
     }
     ​
     void MainWindow::updateChartData()
     {
         // 更新时间计数
         m_timeCount++;
     ​
         // 在温度曲线上增加一个点,模拟温度数据变化
         QPointF p1(m_timeCount, qrand() % 10 + 20);
         QPointF p2(m_timeCount, qrand() % 10 + 30);
         QPointF p3(m_timeCount, qrand() % 10 + 40);
         m_series1- >append(p1);
         m_series2- >append(p2);
         m_series3- >append(p3);
     ​
         // 清除多余的点,只保留最新的30个数据点
         if (m_series1- >count() > 30) {
             m_series1- >removePoints(0, 1);
         }
         if (m_series2- >count() > 30) {
             m_series2- >removePoints(0, 1);
         }
         if (m_series3- >count() > 30) {
             m_series3- >removePoints(0, 1);
         }
     ​
         // 更新横轴范围
         updateAxisRange();
     }
     ​
     void MainWindow::updateAxisRange()
     {
         // 获取横轴范围
         qreal minX = std::numeric_limits< qreal >::max();
         qreal maxX = std::numeric_limits< qreal >::min();
         foreach (QAbstractSeries *series, m_chart- >series()) {
             QXYSeries *xySeries = static_cast< QXYSeries* >(series);
             QPointF p1 = xySeries- >at(0);
             QPointF p2 = xySeries- >at(xySeries- >count() - 1);
     ​
             if (p1.x() < minX) {
                 minX = p1.x();
             }
             if (p2.x() > maxX) {
                 maxX = p2.x();
             }
         }
     ​
         // 更新横轴范围
         m_chart- >axisX()- >setRange(minX, maxX);
     }

为了更新横坐标的范围,需要在MainWindow中添加了一个新函数updateAxisRange()。该函数会在数据更新时被调用来计算最新的横轴范围,以更新折线图的显示。

三、实现代码(2)QWidget

当前这份完整代码实现了一个动态折线图的绘制,是一个典型的Qt Charts应用程序。通过使用QLineSeries类、QValueAxis类和QChart类来创建并显示温度随时间变化的折线图。

第一步:先创建了主窗口,其中包含一个QChartView控件,用于显示温度曲线图。在构造函数中,设置了一些基本属性,比如标题、横纵坐标的范围和名称等,并为每个设备创建了一个QLineSeries对象,用于存储温度数据。

第二步:将这些QLineSeries对象添加到QChart对象中。接着,将QValueAxis对象添加到QChart中,设置其范围和名称,并将QLineSeries对象与其关联。最后,将QChart对象添加到QChartView中,以便在界面上显示折线图。

第三步:在updateChartData()函数中,定时器每隔1秒钟触发一次,用于更新温度数据,并通过调用QLineSeries类的append()函数向QLineSeries对象中添加新的温度数据点。同时,使用removePoints()函数删除旧的数据点,以保持折线图中显示的数据点不超过30个。在添加或删除数据时,使用updateAxisRange()函数更新横坐标的范围,以便将折线图自适应地缩放到当前数据范围内。

第四步:重载了updateAxisRange()函数,根据QLineSeries对象的数据点计算出横坐标的最小值和最大值,并通过调用QChart类的axisX()->setRange()函数更新QValueAxis对象的范围。

【1】widget.cpp代码

#include "widget.h"
     #include "ui_widget.h"
     ​
     Widget::Widget(QWidget *parent)
         : QWidget(parent)
         , ui(new Ui::Widget)
     {
         ui- >setupUi(this);
     ​
         this- >setWindowTitle("温度数据可视化采集系统");
     ​
         m_timer=new QTimer(this);
         m_chart=new QChart();
     ​
         m_series1=new QLineSeries();
         m_series2=new QLineSeries();
         m_series3=new QLineSeries();
     ​
         m_timeCount=0;
     ​
         // 创建温度曲线图1并设置属性
         m_series1- >setName(tr("设备1"));
     //    m_series1- >setColor(Qt::red);
     //    m_series1- >setPen(QPen(Qt::red, 2));
         m_chart- >addSeries(m_series1);
     ​
         // 创建温度曲线图2并设置属性
         m_series2- >setName(tr("设备2"));
     //    m_series2- >setColor(Qt::green);
     //    m_series2- >setPen(QPen(Qt::green, 2));
         m_chart- >addSeries(m_series2);
     ​
         // 创建温度曲线图3并设置属性
         m_series3- >setName(tr("设备3"));
     //    m_series3- >setColor(Qt::blue);
     //    m_series3- >setPen(QPen(Qt::blue, 2));
         m_chart- >addSeries(m_series3);
     ​
         // 设置横轴属性
         QValueAxis *axisX = new QValueAxis;
         axisX- >setRange(0, 30);
         axisX- >setTitleText("时间 (s)");
         m_chart- >addAxis(axisX, Qt::AlignBottom);
         m_series1- >attachAxis(axisX);
         m_series2- >attachAxis(axisX);
         m_series3- >attachAxis(axisX);
     ​
         // 设置纵轴属性
         QValueAxis *axisY = new QValueAxis;
         axisY- >setRange(0, 60);
         axisY- >setTitleText("温度 (℃)");
         m_chart- >addAxis(axisY, Qt::AlignLeft);
         m_series1- >attachAxis(axisY);
         m_series2- >attachAxis(axisY);
         m_series3- >attachAxis(axisY);
     ​
         // 使图表自适应大小,确保曲线始终可见
           m_chart- >createDefaultAxes();
           m_chart- >axisX()- >setRange(0, 30);
           m_chart- >axisY()- >setRange(0, 60);
     ​
     ​
         // 定时更新数据
         connect(m_timer, &QTimer::timeout, this, &Widget::updateChartData);
     ​
         // 将图表添加到ChartView中
         QChartView* chartView = new QChartView(m_chart);
     ​
         // 设置 ChartView 交互模式为拖拽
         chartView- >setRubberBand(QChartView::HorizontalRubberBand);
         chartView- >setRenderHint(QPainter::Antialiasing);
         chartView- >setDragMode(QGraphicsView::ScrollHandDrag);
     ​
         chartView- >setRenderHint(QPainter::Antialiasing);
     ​
         //将视图添加到布局
         ui- >view_verticalLayout- >addWidget(chartView);
     }
     ​
     ​
     ​
     Widget::~Widget()
     {
         delete ui;
     }
     ​
     ​
     void Widget::updateChartData()
     {
         // 更新时间计数
         m_timeCount++;
     ​
         // 在温度曲线上增加一个点,模拟温度数据变化
         QPointF p1(m_timeCount, qrand() % 10 + 20);
         QPointF p2(m_timeCount, qrand() % 10 + 30);
         QPointF p3(m_timeCount, qrand() % 10 + 40);
         m_series1- >append(p1);
         m_series2- >append(p2);
         m_series3- >append(p3);
     ​
         // 清除多余的点,只保留最新的30个数据点
         if (m_series1- >count() > 30) {
             m_series1- >removePoints(0, 1);
         }
         if (m_series2- >count() > 30) {
             m_series2- >removePoints(0, 1);
         }
         if (m_series3- >count() > 30) {
             m_series3- >removePoints(0, 1);
         }
     ​
         // 更新横轴范围
         updateAxisRange();
     }
     ​
     ​
     void Widget::updateAxisRange()
     {
         // 获取横轴范围
         qreal minX = std::numeric_limits< qreal >::max();
         qreal maxX = std::numeric_limits< qreal >::min();
         foreach (QAbstractSeries *series, m_chart- >series()) {
             QXYSeries *xySeries = static_cast< QXYSeries* >(series);
             QPointF p1 = xySeries- >at(0);
             QPointF p2 = xySeries- >at(xySeries- >count() - 1);
     ​
             if (p1.x() < minX) {
                 minX = p1.x();
             }
             if (p2.x() > maxX) {
                 maxX = p2.x();
             }
         }
     ​
         // 更新横轴范围
         m_chart- >axisX()- >setRange(minX, maxX);
     }
     ​
     ​
     ​
     //开始采集
     void Widget::on_pushButton_start_clicked()
     {
         m_timer- >start(1000); // 每隔1秒钟更新一次数据
     }
     ​
     ​
     //停止采集
     void Widget::on_pushButton_stop_clicked()
     {
         m_timer- >stop(); //停止定时器
     }

【2】widget.h代码

#ifndef WIDGET_H
     #define WIDGET_H#include < QWidget >// 包含line chart需要的头文件
     #include < QtCharts/QChart >
     #include < QtCharts/QLineSeries >
     #include < QtCharts/QChartView >
     #include < QtCore/QRandomGenerator >
     #include < QValueAxis >
     #include < QScatterSeries >
     #include < QTimer >// 引用命名空间
     QT_CHARTS_USE_NAMESPACE
     ​
     QT_BEGIN_NAMESPACE
     namespace Ui { class Widget; }
     QT_END_NAMESPACE
     ​
     class Widget : public QWidget
     {
         Q_OBJECT
     ​
     public:
         Widget(QWidget *parent = nullptr);
         ~Widget();
     private slots:
         void updateChartData(); // 更新数据槽函数
         void updateAxisRange();
     ​
         void on_pushButton_start_clicked();
     ​
         void on_pushButton_stop_clicked();
     ​
     private:
         Ui::Widget *ui;
     ​
         QTimer *m_timer; // 定时器
     ​
         QChart *m_chart; // 图表指针
     ​
         QLineSeries *m_series1; // 设备1温度曲线
         QLineSeries *m_series2; // 设备2温度曲线
         QLineSeries *m_series3; // 设备3温度曲线int m_timeCount; // 时间计数
     };
     #endif // WIDGET_H

【3】UI文件代码

image-20230529143214460

< ?xml version="1.0" encoding="UTF-8"? >
    < ui version="4.0" >
     < class >Widget< /class >
     < widget class="QWidget" name="Widget" >
      < property name="geometry" >
       < rect >
        < x >0< /x >
        < y >0< /y >
        < width >600< /width >
        < height >444< /height >
       < /rect >
      < /property >
      < property name="windowTitle" >
       < string >Widget< /string >
      < /property >
      < layout class="QVBoxLayout" name="verticalLayout" >
       < item >
        < widget class="QWidget" name="widget" native="true" >
         < property name="minimumSize" >
          < size >
           < width >100< /width >
           < height >100< /height >
          < /size >
         < /property >
         < layout class="QVBoxLayout" name="verticalLayout_2" >
          < property name="spacing" >
           < number >0< /number >
          < /property >
          < property name="leftMargin" >
           < number >0< /number >
          < /property >
          < property name="topMargin" >
           < number >0< /number >
          < /property >
          < property name="rightMargin" >
           < number >0< /number >
          < /property >
          < property name="bottomMargin" >
           < number >0< /number >
          < /property >
          < item >
           < layout class="QVBoxLayout" name="view_verticalLayout"/ >
          < /item >
         < /layout >
        < /widget >
       < /item >
       < item >
        < widget class="QWidget" name="widget_2" native="true" >
         < property name="maximumSize" >
          < size >
           < width >16777215< /width >
           < height >40< /height >
          < /size >
         < /property >
         < layout class="QHBoxLayout" name="horizontalLayout" >
          < property name="spacing" >
           < number >0< /number >
          < /property >
          < property name="leftMargin" >
           < number >0< /number >
          < /property >
          < property name="topMargin" >
           < number >0< /number >
          < /property >
          < property name="rightMargin" >
           < number >0< /number >
          < /property >
          < property name="bottomMargin" >
           < number >0< /number >
          < /property >
          < item >
           < widget class="QPushButton" name="pushButton_start" >
            < property name="text" >
             < string >开始采集< /string >
            < /property >
           < /widget >
          < /item >
          < item >
           < widget class="QPushButton" name="pushButton_stop" >
            < property name="text" >
             < string >停止采集< /string >
            < /property >
           < /widget >
          < /item >
         < /layout >
        < /widget >
       < /item >
      < /layout >
     < /widget >
     < resources/ >
     < connections/ >
    < /ui >

【4】pro工程文件

QT       += core gui
    QT       += charts

    greaterThan(QT_MAJOR_VERSION, 4): QT += widgets

    CONFIG += c++11

    # The following define makes your compiler emit warnings if you use
    # any Qt feature that has been marked deprecated (the exact warnings
    # depend on your compiler). Please consult the documentation of the
    # deprecated API in order to know how to port your code away from it.
    DEFINES += QT_DEPRECATED_WARNINGS

    # You can also make your code fail to compile if it uses deprecated APIs.
    # In order to do so, uncomment the following line.
    # You can also select to disable deprecated APIs only up to a certain version of Qt.
    #DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000    # disables all the APIs deprecated before Qt 6.0.0

    SOURCES += \\
        main.cpp \\
        widget.cpp

    HEADERS += \\
        widget.h

    FORMS += \\
        widget.ui

    # Default rules for deployment.
    qnx: target.path = /tmp/$${TARGET}/bin
    else: unix:!android: target.path = /opt/$${TARGET}/bin
    !isEmpty(target.path): INSTALLS += target

审核编辑 黄宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Qt
    Qt
    +关注

    关注

    1

    文章

    306

    浏览量

    37949
  • 可视化
    +关注

    关注

    1

    文章

    1195

    浏览量

    20960
  • 温度变化
    +关注

    关注

    0

    文章

    5

    浏览量

    6480
收藏 人收藏

    评论

    相关推荐

    Qt(C++)使用QChart静态显示3设备温度变化曲线

    QChart模块是Qt Charts库的基础,提供了用于创建和显示各种类型图表的类和接口。Qt Charts库是一功能丰富、易于使用的数据
    的头像 发表于 05-29 14:47 2805次阅读
    <b class='flag-5'>Qt</b>(<b class='flag-5'>C++</b>)使用<b class='flag-5'>QChart</b>静态<b class='flag-5'>显示</b><b class='flag-5'>3</b><b class='flag-5'>个</b><b class='flag-5'>设备</b>的<b class='flag-5'>温度</b><b class='flag-5'>变化</b><b class='flag-5'>曲线</b>

    Labview,matlab混合编程如何动态显示曲线

    Labview,matlab混合编程如何动态显示曲线,如一阶阶跃响应
    发表于 04-27 21:44

    FPGA 1602动态显示办法

    我只会FPGA做静态显示,但是不知道该怎样动态显示。求解决是不是在模块内设置一变量啊,然后那个变量怎么变化,然后1602上面也变化。“电压
    发表于 12-24 16:40

    labview怎么动态显示波形?

    本帖最后由 sunxuan 于 2015-1-11 15:08 编辑 请问一下labview怎么动态显示二维数组,比如说(12,15),(9,7),(3,9),(20,23),(15,18),这五
    发表于 01-11 15:07

    LED点阵显示牌的设计与动态显示控制

    LED点阵显示牌的设计与动态显示控制
    发表于 10-27 16:29 75次下载
    LED点阵<b class='flag-5'>显示</b>牌的设计与<b class='flag-5'>动态显示</b>控制

    动态显示电路的改进

    本文主要讲述的是动态显示电路的改进。
    发表于 04-22 15:32 21次下载

    数码管动态显示实验

    数码管动态显示实验一、实验目的在实际的单片机系统中,往往需要多位显示动态显示是一种最常见的多位显示方法,应用非常广泛。本实验要求实验两
    发表于 03-23 10:45 1w次阅读

    数码管(动态显示)【C语言版】

    数码管(动态显示)【C语言版】数码管(动态显示)【C语言版】数码管(动态显示)【C语言版】数码管(动态显示)【C语言版】
    发表于 12-29 15:51 0次下载

    动态显示-译码器片选实现【汇编版】

    动态显示-译码器片选实现【汇编版】动态显示-译码器片选实现【汇编版】动态显示-译码器片选实现【汇编版】
    发表于 12-29 15:51 0次下载

    C#教程之用树型列表动态显示菜单

    C#教程之用树型列表动态显示菜单,很好的C#资料,快来学习吧。
    发表于 04-20 09:59 11次下载

    MIN数码管动态显示

    数码管动态显示,MIN数码管动态显示,MIN。
    发表于 05-03 10:48 9次下载

    TFT曲线显示动态曲线的原理和方法

    TFT曲线显示动态曲线的原理和方法
    发表于 09-20 14:27 17次下载
    TFT<b class='flag-5'>曲线</b><b class='flag-5'>显示</b><b class='flag-5'>动态</b><b class='flag-5'>曲线</b>的原理和方法

    数码管的静态与动态显示和74HC138及点阵的动态显示详细资料说明

    本文档的主要内容详细介绍的是数码管的静态与动态显示和74HC138及点阵的动态显示详细资料说明。
    发表于 04-12 18:27 5次下载
    数码管的静态与<b class='flag-5'>动态显示</b>和74HC138及点阵的<b class='flag-5'>动态显示</b>详细资料说明

    基于89C51单片机的1602液晶动态显示源程序

    基于89C51单片机的1602液晶动态显示源程序
    发表于 05-16 10:33 1次下载

    基于QT5+OpenCV+OpenVINO C++的应用打包过程

    我用QT C++写了一YOLOv5模型推理演示应用。
    的头像 发表于 01-26 10:17 1330次阅读
    基于<b class='flag-5'>QT</b>5+OpenCV+OpenVINO <b class='flag-5'>C++</b>的应用打包过程