QT读取串口数据并显示

效果图:
在这里插入图片描述
ui界面:(选中框是QWidget,放入ui后需要将它提升为QChartView)
在这里插入图片描述
代码区.h:

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>
#include <QSerialPort>           //提供访问串口的功能
#include <QSerialPortInfo>    //提供系统中存在的串口的信息
#include<QtCharts>
QT_CHARTS_USE_NAMESPACE
namespace Ui {
class MainWindow;
}

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    explicit MainWindow(QWidget *parent = nullptr);
    void createXY();
    ~MainWindow();
protected:
    void readyReadData();


private slots:
      void updata_plot();

    void on_pushButton_clicked();

    void on_pushButtonoff_clicked();

private:
     QTimer *timer_plot;
     //曲线
         QSplineSeries* line;
         //曲线点的最大数量
         int line_max = 100;

         //绘图变量和坐标
         QChart* chart;
         //QValueAxis *axisX;
         //QValueAxis *axisY;
         QVector<QPointF> list;//保存心跳点
         double tim=0;//时间

         //int t=0;


    //创建串口对象
    QSerialPort serial;
    int heartnum=10;
    QByteArray array;
    int timeid;
    Ui::MainWindow *ui;
};

#endif // MAINWINDOW_H

.cpp

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include<QDebug>
#include<QTimer>
//#include <QSerialPort>        //提供访问串口的功能
//#include <QSerialPortInfo>    //提供系统中存在的串口的信息
#include<QPen>
#include<QPainter>

MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    timer_plot = new QTimer(this);
    connect(timer_plot,SIGNAL(timeout()),this,SLOT(updata_plot()));
    line = new QSplineSeries(this);
    chart = new QChart();
    chart->addSeries(line);
    //QPointF p1(0,180);

    //list.push_back(p1);
    //通过QSerialPortInfo查找可用串口
    foreach(const QSerialPortInfo &info, QSerialPortInfo::availablePorts())
    {
        qWarning() << info.portName();
    }

    //设置串口名COM1
    serial.setPortName("COM5");
    //设置波特率
    serial.setBaudRate(QSerialPort::Baud9600);
    //设置数据位数8位
    serial.setDataBits(QSerialPort::Data8);
    //设置无奇偶校验
    serial.setParity(QSerialPort::NoParity);
    //设置停止位1位
    serial.setStopBits(QSerialPort::OneStop);
    //设置没有流控制
    serial.setFlowControl(QSerialPort::NoFlowControl);
    //读写方式打开串口
    serial.open(QIODevice::ReadWrite);
    // 连接信号和槽
    //connect(&serial,&QSerialPort::readyRead,this,&MainWindow::readyReadData);
    connect(&serial,&QSerialPort::readyRead,
            [=]()
    {
        QByteArray buffer = serial.readAll();
       char *m=buffer.data();
      QString str=m;
      heartnum=str.mid(4,6).toInt();
       ui->textEdit->setText(m);
      //t=t+5;
      QPointF p(tim,heartnum);
      list.push_back(p);
    }
    );
    //serial.close();
}
void MainWindow::updata_plot()
{
       line->replace(list);//替换更新
       line->setName("heart");//设置曲线名称
       line->setPen(QColor(255, 0, 0));//设置曲线颜色
       line->setUseOpenGL(true);//openGl 加速
       chart->setTitle("呼吸曲线");//设置图标标题
       chart->removeSeries(line);
       chart->addSeries(line);
       chart->createDefaultAxes();//设置坐标轴
        //chart->axisX()->setRange(0,180);
       chart->axisY()->setRange(0,180);

       ui->widget->setChart(chart);
       tim+=0.05;
}

MainWindow::~MainWindow()
{
    delete ui;
}

void MainWindow::on_pushButton_clicked()
{
    timer_plot->start(50);//启动定时器
}

void MainWindow::on_pushButtonoff_clicked()
{
   timer_plot->stop();//关闭定时器
}

  • 13
    点赞
  • 108
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 使用Qt的UI界面设计串口数据采集,主要分为以下几个步骤: 1. 打开串口:通过Qt提供的QSerialPort类,可以很方便地实现串口的打开,设置波特率、数据位、校验位等参数。 2. 接收数据:通过QSerialPort的信号readyRead(),可以实现串口数据的接收。在该信号的槽函数中,可以读取串口缓冲区中的数据,并进行处理。 3. 数据处理:对于接收到的串口数据,可以根据具体需求进行处理,例如解析数据显示数据等。可以使用Qt提供的控件(如QLabel、QTextEdit)来显示数据。 4. 发送数据:如果需要向串口发送数据,可以通过QSerialPort的write()函数来实现。可以在UI界面上添加一个发送按钮,通过点击按钮来发送数据。 5. 关闭串口:在程序退出或不需要使用串口时,需要关闭串口以释放资源。可以在UI界面上添加一个关闭串口的按钮,点击该按钮触发关闭串口的操作。 在UI界面设计上,可以使用Qt Designer工具来创建串口数据采集的界面。可以设计一个包含打开串口按钮、发送按钮、接收区域等控件的界面。通过设置控件的属性、信号与槽的连接,实现与串口通信相关的功能。 总结来说,使用Qt的UI界面设计串口数据采集需要先打开串口,接收并处理串口数据,同时可以发送串口数据,最后关闭串口以释放资源。设计上可以使用Qt Designer工具创建界面,通过设置控件属性和信号与槽的连接来实现功能。 ### 回答2: 在Qt中设计串口数据采集的UI界面可以通过以下步骤实现: 首先,通过Qt Creator创建一个新的Qt项目,并选择“MainWindow”作为主窗口类型。 接下来,在UI界面中添加所需的控件,可以包括一个按钮来打开或关闭串口,一个下拉菜单用于选择串口波特率,一个文本框来显示串口接收到的数据等。 然后,在主窗口类中添加相关的槽函数来处理控件的事件响应。比如,添加一个槽函数来处理打开或关闭串口的按钮点击事件,可以使用Qt提供的串口类(QSerialPort)来实现串口的打开和关闭操作。在打开串口时,需要设置串口的波特率以及其他参数,如数据位、停止位和校验位等。 接着,在主窗口类的构造函数中初始化串口类实例,并连接相关的信号和槽函数。比如,连接串口的readyRead()信号与一个槽函数,用于读取串口接收到的数据,并在文本框中显示出来。 最后,在UI界面的其他控件事件响应函数中,可以添加一些额外的逻辑来实现串口数据的采集,如将接收到的数据保存到文件中、进行数据处理或显示等。 需要注意的是,由于串口数据读取是一个耗时操作,为了避免界面卡顿,可以将串口读取相关的逻辑放在一个单独的线程中运行,然后通过信号和槽机制与主界面进行通信。可以使用Qt提供的多线程类(QThread)来实现。 综上所述,通过以上步骤可以实现使用Qt的UI界面设计串口数据采集的功能。这样设计的界面用户可以方便地打开/关闭串口,选择波特率,实时显示串口接收到的数据,并且可以进行数据采集以及其他操作。 ### 回答3: 在使用Qt进行串口数据采集的UI界面设计时,首先需要使用Qt提供的QSerialPort类来实现串口的打开、读写、关闭等操作。 在UI界面设计方面,可以使用Qt的图形设计工具Qt Designer来创建界面,或者手动编写代码实现。以下是一个简单的示例: 1. 首先,在Qt Designer中创建一个主窗口界面,并添加串口设置相关的控件,如按钮、下拉框、文本框等。可以设置按钮用来打开串口读取数据等操作。 2. 在主窗口的类文件中,需要引入QSerialPort类的头文件,以及其它相关的Qt类文件。 3. 在打开串口的按钮点击事件中,实例化QSerialPort对象,并设置串口的名称、波特率、数据位、校验位和停止位等参数。然后,调用QSerialPort的open函数打开串口。 4. 在循环读取数据的函数中,通过QSerialPort的read函数读取串口接收到的数据,并将数据显示在相应的文本框中或者进行其它业务逻辑处理。 5. 最后,在关闭串口的槽函数中,调用QSerialPort的close函数关闭串口。 通过以上步骤,可以设计一个简单的Qt界面,用于串口数据的采集。当用户点击相应按钮时,可以打开串口读取数据,并在界面上显示或者进行进一步处理。在设计时,还可以添加错误处理、自动刷新等功能,以提高用户体验。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值