QT串口实时检测 您所在的位置:网站首页 串口被使用 QT串口实时检测

QT串口实时检测

#QT串口实时检测| 来源: 网络整理| 查看: 265

本人做项目时需要将下位机发送的数据进行可视化,方便调试,于是写了一个基于QT的串口调试助手。注意到上位机软件每次插拔串口之后不能动态加载串口设备需要重启上位机,以及串口通信时下位机串口断开上位机无法识别的问题,增加了实时检测串口变化的功能。具体代码如下。

首先是串口热插拔检测。QT提供了QAbstractNativeEventFilter这个类对本地事件进行处理。QT的官方文档是这样解释这个类的:

The QAbstractNativeEventFilter class provides an interface for receiving native events, such as MSG or XCB event structs 再往下继续查看能发现QT为这个类提供了一个纯虚函数

[pure virtual] bool QAbstractNativeEventFilter::nativeEventFilter(const QByteArray &eventType, void *message, long *result)

可以看到它的三个参数分别是事件类型,消息和结果。也就是说我们只要在自己的程序里重写这个纯虚函数就能得到获取本地事件的消息。有了以上的知识我们就能开始写代码了。具体代码如下。 首先需要引用头文件并且主窗口需要继承该类。

#include class Myserial : public QMainWindow,public QAbstractNativeEventFilter

同时为了解析本地事件的消息提取其中usb串口设备的消息,需要先注册usb设备。

static const GUID GUID_DEVINTERFACE_LIST[] = { // GUID_DEVINTERFACE_USB_DEVICE { 0xA5DCBF10, 0x6530, 0x11D2, { 0x90, 0x1F, 0x00, 0xC0, 0x4F, 0xB9, 0x51, 0xED } }, // // GUID_DEVINTERFACE_DISK // { 0x53f56307, 0xb6bf, 0x11d0, { 0x94, 0xf2, 0x00, 0xa0, 0xc9, 0x1e, 0xfb, 0x8b } }, // // GUID_DEVINTERFACE_HID, // { 0x4D1E55B2, 0xF16F, 0x11CF, { 0x88, 0xCB, 0x00, 0x11, 0x11, 0x00, 0x00, 0x30 } }, // // GUID_NDIS_LAN_CLASS // { 0xad498944, 0x762f, 0x11d0, { 0x8d, 0xcb, 0x00, 0xc0, 0x4f, 0xc3, 0x35, 0x8c } }, // // GUID_DEVINTERFACE_COMPORT // { 0x86e0d1e0, 0x8089, 0x11d0, { 0x9c, 0xe4, 0x08, 0x00, 0x3e, 0x30, 0x1f, 0x73 } }, // // GUID_DEVINTERFACE_SERENUM_BUS_ENUMERATOR // { 0x4D36E978, 0xE325, 0x11CE, { 0xBF, 0xC1, 0x08, 0x00, 0x2B, 0xE1, 0x03, 0x18 } }, // // GUID_DEVINTERFACE_PARALLEL // { 0x97F76EF0, 0xF883, 0x11D0, { 0xAF, 0x1F, 0x00, 0x00, 0xF8, 0x00, 0x84, 0x5C } }, // // GUID_DEVINTERFACE_PARCLASS // { 0x811FC6A5, 0xF728, 0x11D0, { 0xA5, 0x37, 0x00, 0x00, 0xF8, 0x75, 0x3E, 0xD1 } }, }; //注册插拔事件 HDEVNOTIFY hDevNotify; DEV_BROADCAST_DEVICEINTERFACE NotifacationFiler; ZeroMemory(&NotifacationFiler,sizeof(DEV_BROADCAST_DEVICEINTERFACE)); NotifacationFiler.dbcc_size = sizeof(DEV_BROADCAST_DEVICEINTERFACE); NotifacationFiler.dbcc_devicetype = DBT_DEVTYP_DEVICEINTERFACE; for(int i=0;iwinId()),&NotifacationFiler,DEVICE_NOTIFY_WINDOW_HANDLE); if(!hDevNotify) { GetLastError(); qDebug() wParam) { case DBT_DEVICEARRIVAL: if(lpdb->dbch_devicetype == DBT_DEVTYP_PORT) { PDEV_BROADCAST_PORT pDevInf = PDEV_BROADCAST_PORT(lpdb); // QString device_name = "插入设备(name):"+QString::fromWCharArray(pDevInf->dbcc_name,int(pDevInf->dbcc_size)).toUtf8(); QString port = QString::fromWCharArray(pDevInf->dbcp_name); qDebug()dbcc_name,int(pDevInf->dbcc_size)).toUtf8(); QString port = QString::fromWCharArray(pDevInf->dbcp_name); qDebug()OpenButton->setText("打开串口"); PortisOpen = false; delete my_serialport; // 其他处理...... } }

我这里是检测串口只要出现问题就断开连接。当然你可以自定义自己的错误处理方式。 最后需要将信号和槽连接。

connect(my_serialport, SIGNAL(error(QSerialPort::SerialPortError)), this, SLOT(pSerialPort_onErrorOccurred(QSerialPort::SerialPortError)));

可以看到当串口故障时,上位机能检测到故障。 在这里插入图片描述 顺便本人使用的是qt5.9.9。



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有