一、前言
這個作品很多年前就做了,經過了長達七八年的完善,當然也不是全身心的投入完善,也就是根據實際項目的需求不斷完善的,尤其是模拟裝置回複資料的功能,這個在很多用Qt做上位機開發非常實用,畢竟很多軟硬體的項目都是同時開工的,不會說是等硬體或者軟體都完工了才去搞另外一部分,是以軟體工程師就需要根據一開始約定好的通信協定來先把軟體搞起來,沒有硬體實地測試怎麼辦呢,隻能自己寫工具來模拟裝置回複資料咯,基本上都是要求收到什麼資料回複什麼資料,是以這就有了通用的序列槽裝置回複資料的可能。
其實Qt5以後開始內建了QSerialPort類可以用來序列槽通信,我個人測試過很多次,發現總是有莫名其妙的怪怪的問題,後面還是打算直接用第三方的序列槽開源類來做,畢竟成熟穩定,而且經曆過各種項目的長時間的考驗,還是非常可靠的。
基本功能:
- 支援16進制資料發送與接收。
- 支援windows下COM9以上的序列槽通信。
- 實時顯示收發資料位元組大小以及序列槽狀态。
- 支援任意qt版本,親測4.7-5.14。
- 支援序列槽轉網絡資料收發。
進階功能:
- 可自由管理需要發送的資料,每次隻要從下拉框中選擇資料即可,無需重新輸入資料。
- 可模拟裝置回複資料,需要在主界面開啟模拟裝置回複資料。當接收到設定好的指令時,立即回複設定的回複指令。例如指定收到0x16 0x00 0xFF 0x01需要回複0x16 0x00 0xFE 0x01,則隻需要在SendData.txt中添加一條資料16 00 FF 01:16 00 FE 01即可。
- 可定時發送資料和儲存資料到文本檔案:,預設間隔5秒鐘,可更改間隔時間。
- 在不斷接收到大量資料時,可以暫停顯示資料來檢視具體資料,背景依然接收資料但不處理,無需關閉序列槽來檢視已接收到的資料。
- 每次收到的資料都是完整的一條資料,而不是脫節的,做了延時處理。
- 一套源碼随處編譯,無需更改序列槽通信類,已在XP/WIN7/UBUNTU/ARMLINUX系統下成功編譯并運作。
二、代碼思路
第一步:引入第三方序列槽類
include($$PWD/qextserialport/qextserialport.pri)
INCLUDEPATH += $$PWD/qextserialport
第二步:執行個體化類
void frmComTool::on_btnOpen_clicked()
{
if (ui->btnOpen->text() == "打開序列槽") {
com = new QextSerialPort(ui->cboxPortName->currentText(), QextSerialPort::Polling);
comOk = com->open(QIODevice::ReadWrite);
if (comOk) {
//清空緩沖區
com->flush();
//設定波特率
com->setBaudRate((BaudRateType)ui->cboxBaudRate->currentText().toInt());
//設定資料位
com->setDataBits((DataBitsType)ui->cboxDataBit->currentText().toInt());
//設定校驗位
com->setParity((ParityType)ui->cboxParity->currentIndex());
//設定停止位
com->setStopBits((StopBitsType)ui->cboxStopBit->currentIndex());
com->setFlowControl(FLOW_OFF);
com->setTimeout(10);
changeEnable(true);
ui->btnOpen->setText("關閉序列槽");
timerRead->start();
}
} else {
timerRead->stop();
com->close();
com->deleteLater();
changeEnable(false);
ui->btnOpen->setText("打開序列槽");
on_btnClear_clicked();
comOk = false;
}
}
第三步:讀取資料并處理
void frmComTool::readData()
{
if (com->bytesAvailable() <= 0) {
return;
}
QUIHelper::sleep(sleepTime);
QByteArray data = com->readAll();
int dataLen = data.length();
if (dataLen <= 0) {
return;
}
if (isShow) {
QString buffer;
if (ui->ckHexReceive->isChecked()) {
buffer = QUIHelper::byteArrayToHexStr(data);
} else {
//buffer = QUIHelper::byteArrayToAsciiStr(data);
buffer = QString::fromLocal8Bit(data);
}
//啟用調試則模拟調試資料
if (ui->ckDebug->isChecked()) {
int count = App::Keys.count();
for (int i = 0; i < count; i++) {
if (buffer.startsWith(App::Keys.at(i))) {
sendData(App::Values.at(i));
break;
}
}
}
append(1, buffer);
receiveCount = receiveCount + data.size();
ui->btnReceiveCount->setText(QString("接收 : %1 位元組").arg(receiveCount));
//啟用網絡轉發則調用網絡發送資料
if (tcpOk) {
socket->write(data);
append(4, QString(buffer));
}
}
}
三、效果圖
四、開源首頁
以上作品完整源碼下載下傳都在開源首頁,會持續不斷更新作品數量和品質,歡迎各位關注。