内容简介:上两周利用周末的时间,分别写了Qt是一个1991年由Qt Company开发的跨平台C++图形用户界面应用程序开发框架。它既可以开发GUI程序,也可用于开发非GUI程序,比如控制台工具和服务器。Qt是面向对象的框架,使用特殊的代码生成扩展(称为元对象编译器(Meta Object Compiler, moc))以及一些宏,Qt很容易扩展,并且允许真正地组件编程。2008年,Qt Company科技被诺基亚公司收购,Qt也因此成为诺基亚旗下的编程语言工具。2012年,Qt被Digia收购。2014年4月,跨平
前言
上两周利用周末的时间,分别写了 基于uFUN开发板的心率计(一)DMA方式获取传感器数据 和 基于uFUN开发板的心率计(二)动态阈值算法获取心率值 ,介绍了AD采集传感器数据和数据的滤波处理获取心率值。这篇文章主要是介绍Qt上位机如何实现波形的显示,串口数据的解析,以及一些小细节实现。这篇文章写完,uFUN心率计这个小项目就算结束了,最近又做了个uFUN开发板的扩展板,在微信群里的朋友都已经看到了,后面会做一些好玩的东西,大家要保持关注哈!
关于Qt
Qt是一个1991年由Qt Company开发的跨平台C++图形用户界面应用程序开发框架。它既可以开发GUI程序,也可用于开发非GUI程序,比如控制台 工具 和服务器。Qt是面向对象的框架,使用特殊的代码生成扩展(称为元对象编译器(Meta Object Compiler, moc))以及一些宏,Qt很容易扩展,并且允许真正地组件编程。2008年,Qt Company科技被诺基亚公司收购,Qt也因此成为诺基亚旗下的编程语言工具。2012年,Qt被Digia收购。2014年4月,跨平台集成开发环境Qt Creator 3.1.0正式发布,实现了对于iOS的完全支持,新增WinRT、Beautifier等插件,废弃了无 Python 接口的GDB调试支持,集成了基于Clang的C/C++代码模块,并对Android支持做出了调整,至此实现了全面支持iOS、Android、WP,它提供给应用程序开发者建立艺术级的图形用户界面所需的所有功能。基本上,Qt 同 X Window 上的 Motif,Openwin,GTK 等图形界 面库和 Windows 平台上的 MFC,OWL,VCL,ATL 是同类型的东西。——来自百度百科
串口数据的解析和显示
pro文件添加串口支持:
QT += serialport
头文件包含:
#include <QSerialPort> #include <QSerialPortInfo>
串口对象的定义:
QSerialPort serial;
启动自动搜索本机串口并添加到下拉框:
foreach(const QSerialPortInfo &info, QSerialPortInfo::availablePorts()) { ui->cbb_com->addItem(info.portName()); //串口号下拉菜单,增加一个条目,为串口号COM4 qDebug() << "串口搜索完成"; }
串口的打开:
serial.setPortName(ui->cbb_com->currentText()); //设置串口号、 serial.setBaudRate(ui->cbb_baud->currentText().toInt()); //设置波特率 serial.setDataBits(QSerialPort::Data8); //设置串口数据位8 serial.setParity(QSerialPort::NoParity); //无校验位 serial.setStopBits(QSerialPort::OneStop); //1位停止位 serial.setFlowControl(QSerialPort::NoFlowControl); if(!serial.open(QIODevice::ReadWrite)) { QMessageBox::critical(NULL, "提示", "串口打开失败"); return; }
串口的关闭:
serial.close();
关联信号与槽函数:
connect(&serial, & QSerialPort::readyRead, this, &Pulse::serialPort_readyRead);
串口通讯协议:
电压值的显示:S+传感器数值+\r\n 心率值的显示:B+心率值+\r\n
槽函数里进行串口数据的解析:
//串口数据接收并解析 void Pulse::serialPort_readyRead() { bool ok1, ok2; static double x; double SensorValue; QByteArray rx_buf= serial.readAll();; int len = rx_buf.length(); // qDebug() << rx_buf << " - " << len; x += 0.1; if(rx_buf.startsWith("S") && rx_buf.endsWith("\r\n")) { int indx1 = rx_buf.indexOf("\r\n"); QString str1 = rx_buf.mid(1, indx1 - 1); SensorValue = str1.toDouble(&ok1) * 3.3 / 4096 ; if(ok1 && !stopFlag) { if(SensorValue > 2.5) SensorValue = 2.5; if(SensorValue < 1.4) SensorValue = 1.4; // qDebug() << " 电压值: "<< SensorValue; QString dis_SIG; dis_SIG.sprintf("%.2f v", SensorValue); ui->lbe_SIG->setText(dis_SIG); ui->widget->graph(0)->addData(x, SensorValue); ui->widget->xAxis->setRange(x, 40, Qt::AlignRight); ui->widget->replot(); // ui->widget->replot(QCustomPlot::rpQueuedReplot); } } else if(rx_buf.startsWith("B") && rx_buf.endsWith("\r\n")) { int index2 = rx_buf.indexOf("\r\n"); QString str2 = rx_buf.mid(1, index2 - 1); BMP = str2.toInt(&ok2); qDebug() << "心率值: "<< str2; if(ok2 && !stopFlag) { QString dis_BPM; ui->lbe_BPM->setText(QString::number(BMP,10) + "/min"); } } else { x = 0; serial.close(); //关闭串口 this->ui->btn_uart_Ctrl->setText("打开串口"); QMessageBox::warning(this, "警告", "串口数据格式错误!"); } rx_buf.clear(); }
关于串口的详细使用,可以参考最开始学习Qt时做的一个练手项目: Qt小项目之串口助手控制LED
QCustomplot绘图库的使用
1.添加库文件到工程
库文件的下载: QCustomPlot-source.tar.gz
或者到官方网站下载最新版的库文件: qcustomplot
主要就两个文件 qcustomplot.h
和 qcustomplot.cpp
,把两个文件添加到Qt工程
2.pro文件添加
qcustomplot包含了一些打印的功能,所以需要包含打印的支持
QT += printsupport
3.UI界面添加Widget绘图窗口
UI界面添加Widget绘图窗口,并右键把它提升为QCustomPlot类,Qt提升控件时,通常提升的类名称中,每个单词的首字母必须大写,否则无法识别,如这里必须写成QCustomPlot而不能写成Qcustomplot或qcustomplot
4.Widget的初始化:
ui->widget->setBackground(QBrush(Qt::white)); //设置背景颜色 ui->widget->axisRect()->setupFullAxesBox();//在坐标轴右侧和上方画线,和X/Y轴一起形成一个矩形 ui->widget->legend->setFont(QFont("Helvetica", 12)); //设置图例字体和大小 ui->widget->legend->setVisible(true); //使能图例可见 ui->widget->xAxis->setLabel("时间"); //设置X轴文字标注 ui->widget->yAxis->setLabel("电压值");//设置Y轴文字标注 ui->widget->yAxis->setRangeLower(1); ui->widget->yAxis->setRangeUpper(3); // ui->widget->yAxis->setRangeLower(-2); //设置y轴最小值 // ui->widget->yAxis->setRangeUpper(3); //设置y轴最大值 // ui->widget->graph(0)->setLineStyle(QCPGraph::lsLine); // ui->widget->graph(0)->setPen(QPen(Qt::blue)); ui->widget->addGraph(); QPen pen(Qt::red, 1.5, Qt::SolidLine, Qt::RoundCap, Qt::RoundJoin); ui->widget->graph(0)->setPen(pen); ui->widget->graph(0)->setName("心跳曲线");
5.实时显示串口发来的电压值
在串口接收的槽函数中实现:
ui->widget->graph(0)->addData(x, SensorValue); ui->widget->xAxis->setRange(x, 40, Qt::AlignRight); ui->widget->replot();
QCustomplot是Qt开发环境下一个很强大而又简单的绘图库,关于QCustomplot库的详细使用方法,可以参考这篇文章: Qt-QCustomplot画静态、动态曲线教程图解
软件自动更新功能的实现
这个上位机包含了一个检测更新的小功能,如果有新版本,点击检查更新会弹出如下窗口,如果点击去下载,会直接跳转到浏览器,创建下载任务。
详细的实现思路和过程,可以看我写的笔记: Qt实现软件自动更新的一种简单方法
软件的下载
有需要这个上位机软件的朋友,可以直接下载: uFun_Pulse_v1.1.exe
总结
这两周利用周末的时间,把uFUN开发板+传感器实现心率计这个小项目的实现过程写完了,整体来看,写的不是很详细,但具体的实现思路介绍的还算清晰,希望能对大家有一些帮助。上位机目前还有一些小BUG待解决,等有点时间,再继续完善。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 吴恩达论文登上Nature Medicine!利用神经网络诊断心率不齐
- 算法要逆天!看视频聊天就可检测心率和压力水平
- php如何实现session,自己实现session,laravel如何实现session
- AOP如何实现及实现原理
- webpack 实现 HMR 及其实现原理
- Docker实现原理之 - OverlayFS实现原理
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Namo Webeditor5.5一看就懂.
吳聲毅 / 金禾資訊 / 20040214 / NT$ 169
一看就懂系列書全以初學者的角度切入,全書以STEP BY STEP方式撰寫,並以豐富的圖片搭配教學,在最後更加上日常生活實例運用講解,一路學來一氣呵成。為了增進學習的效率更採用高級紙品全彩印刷,這麼好的書,您還在等什麼,一看就懂系列書保證是您最佳入門學習好伙伴。 本書特色: 1、一看就懂:Step by Step操作詳盡說明、讓您一看就懂 2、精選範例:精彩實務範例生動活......一起来看看 《Namo Webeditor5.5一看就懂.》 这本书的介绍吧!