QT-实现串口命令发送列表(三)

2- 读取配置文件生成命令列表

实现思路:

第一步先实现QT文件读取功能,设计参数列表读取文件

使用c语言的文件读写,使用格式输入输出,方便存取数据

第二步读取配置文件生成命令列表

读取配置文件内容动态生成命令列表

第一步先实现QT文件读取功能,设计参数列表读取文件

因为逛了一圈Qfile, 感觉不熟悉,不太好实现格式输入输出,文件保存使用c语言实现。封装用c++.

My_config_file.h

#include "stdio.h"

 

#define FILENAME "config.txt"

#define FILETYPE_A "a+"

#define FILETYPE_W "w+"

#define FILETYPE_R "r+"

 

 

 

//按格式写

#define cprintf(fmt, ...) fprintf(config_file.get_cfp(), fmt, ##__VA_ARGS__)

//按格式读

#define cscanf(fmt, ...)  fscanf(config_file.get_cfp(), fmt, ##__VA_ARGS__)

 

class my_config_file

{

public:

    my_config_file();

 

    FILE *fp=NULL;

 

    //初始化

    int cmd_config_init(char *filename,char *type);

 

    //关闭

    void cmd_config_close();

 

    //是否到文件尾巴

    int cfeof();

 

    FILE *get_cfp();

};

 

extern my_config_file config_file;

 

#endif // MY_CONFIG_FILE_H

My_config_file.cpp

#include "my_config_file.h"

my_config_file config_file;

my_config_file::my_config_file()

{

 

}

 

//初始化

int my_config_file::cmd_config_init(char *filename,char *type)

{

    if( (fp=fopen(filename, type)) == NULL )

    {

        printf("Fail to open file!\n");

        return 0;

    }

    return 1;

}

//关闭

void my_config_file::cmd_config_close()

{

    if(fp!=NULL)

    fclose(fp);

}

 

 

 

FILE *my_config_file::get_cfp()

{

    return fp;

}

 

//是否到文件尾巴

int my_config_file::cfeof()

{

    if(fp==NULL)

    return 1;

    return feof(fp);

}

Mainwindow.cpp

#include "mainwindow.h"

#include "ui_mainwindow.h"

#include <QMap>

#include <QString>

#include "QDebug"

#include <QFile>

#include <QTextStream>

#include "my_config_file.h"

//定义配置项

typedef struct

{

    char name[100];

    char comd[100];

 

}AT_CMD_S;

 

 

MainWindow::MainWindow(QWidget *parent) :

    QMainWindow(parent),

    ui(new Ui::MainWindow)

{

    ui->setupUi(this);

 

    printf("save...\n");

 

    AT_CMD_S at_cmd1={0};

    AT_CMD_S at_cmd2={0};

 

        int n=10;

        config_file.cmd_config_init(FILENAME,FILETYPE_W);

        while(n--)

        {

 

           cprintf("%d %s %s\n",n,"AT","ST+CSQ?");

 

        }

        config_file.cmd_config_close();

 

        printf("read...\n");

        config_file.cmd_config_init(FILENAME,FILETYPE_R);

 

        while( !config_file.cfeof() )

        {

 

 

            cscanf("%d %s %s\n",&n,at_cmd2.name,at_cmd2.comd);

 

            printf("read n:%d :%s - %s\n",n,at_cmd2.name,at_cmd2.comd);

 

 

        }

        config_file.cmd_config_close();

 

 

 

}

 

MainWindow::~MainWindow()

{

    delete ui;

}

效果:

 

 

第二步读取配置文件生成命令列表

有了上面的文件读取接口,实现动态生成命令列表就变得很简单了

 

我们重新封装一下第一讲实现列表的功能,传入两个字符给 按键 和 编辑框

void MainWindow::add_widget(QString name,QString comd)

{

    //创建widget

    my_widget *mwidget =new my_widget(this);

    mwidget->Button->setText(name);

    mwidget->ineEdit->setText(comd);

 

    //把item添加到listWidget

    ui->listWidget->addItem(mwidget->item);

 

    //将item与widget联系

    ui->listWidget->setItemWidget(mwidget->item, mwidget);

 

    global::Mwidget_List.append(mwidget);

 

}

Mainwindow中直接读取文件并添加列表

MainWindow::MainWindow(QWidget *parent) :

    QMainWindow(parent),

    ui(new Ui::MainWindow)

{

    ui->setupUi(this);

   

    AT_CMD_S at_cmd2={0};

 

    printf("read...\n");

    config_file.cmd_config_init(FILENAME,FILETYPE_R);

 

    //读取文件

    while( !config_file.cfeof() )

    {

        int n=0;

        cscanf("%d %s %s\n",&n,at_cmd2.name,at_cmd2.comd);

 

        //设置文本和按钮的文本

 

        QString btn_str(at_cmd2.name);

        QString edit_str(at_cmd2.comd);

        //添加命令

        add_widget(btn_str,edit_str);

 

 

    }

    config_file.cmd_config_close();

 

 

 

}

我们在配置文件中手动添加几条指令

 

程序运行效果,全部读出生成命令列表。完美。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的QT程序,可以实现发送串口命令后持续监听串口回复状态: ```cpp #include "mainwindow.h" #include "ui_mainwindow.h" #include <QSerialPort> #include <QSerialPortInfo> #include <QThread> #include <QMutex> #include <QWaitCondition> #include <QDebug> QMutex mutex; // 互斥锁 QWaitCondition cond; // 条件变量 bool has_data = false; // 标志位,表示是否有新的数据到达 QByteArray recv_data; // 串口接收数据缓冲区 MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent) , ui(new Ui::MainWindow) { ui->setupUi(this); // 查找可用的串口 QList<QSerialPortInfo> infos = QSerialPortInfo::availablePorts(); for (QSerialPortInfo info : infos) { ui->comboBoxPortName->addItem(info.portName()); } // 设置串口参数 ui->comboBoxBaudRate->setCurrentIndex(ui->comboBoxBaudRate->findText("9600")); ui->comboBoxDataBits->setCurrentIndex(ui->comboBoxDataBits->findText("8")); ui->comboBoxParity->setCurrentIndex(ui->comboBoxParity->findText("None")); ui->comboBoxStopBits->setCurrentIndex(ui->comboBoxStopBits->findText("1")); // 连接信号槽 connect(ui->pushButtonOpen, &QPushButton::clicked, this, &MainWindow::onOpenButtonClicked); connect(ui->pushButtonClose, &QPushButton::clicked, this, &MainWindow::onCloseButtonClicked); connect(ui->pushButtonSend, &QPushButton::clicked, this, &MainWindow::onSendButtonClicked); connect(&m_serialPort, &QSerialPort::readyRead, this, &MainWindow::onReadyRead); } MainWindow::~MainWindow() { delete ui; } // 打开串口 void MainWindow::onOpenButtonClicked() { m_serialPort.setPortName(ui->comboBoxPortName->currentText()); m_serialPort.setBaudRate(ui->comboBoxBaudRate->currentText().toInt()); m_serialPort.setDataBits((QSerialPort::DataBits)ui->comboBoxDataBits->currentText().toInt()); m_serialPort.setParity((QSerialPort::Parity)ui->comboBoxParity->currentIndex()); m_serialPort.setStopBits((QSerialPort::StopBits)ui->comboBoxStopBits->currentIndex()); if (m_serialPort.open(QIODevice::ReadWrite)) { ui->statusBar->showMessage("打开串口成功!"); } else { ui->statusBar->showMessage("打开串口失败!"); } } // 关闭串口 void MainWindow::onCloseButtonClicked() { m_serialPort.close(); ui->statusBar->showMessage("关闭串口!"); } // 发送串口命令 void MainWindow::onSendButtonClicked() { QString cmd = ui->lineEditCmd->text(); m_serialPort.write(cmd.toLatin1()); ui->statusBar->showMessage("发送命令:" + cmd); } // 监听串口回复状态 void MainWindow::onReadyRead() { QByteArray data = m_serialPort.readAll(); if (!data.isEmpty()) { mutex.lock(); recv_data.append(data); has_data = true; cond.wakeAll(); mutex.unlock(); } } // A线程,用于发送串口命令并等待回复状态 void MainWindow::run() { QString cmd = ui->lineEditCmd->text() + "\r\n"; while (true) { // 发送命令 m_serialPort.write(cmd.toLatin1()); ui->statusBar->showMessage("发送命令:" + cmd); // 等待回复状态 mutex.lock(); while (!has_data) { cond.wait(&mutex); } ui->statusBar->showMessage("收到回复:" + recv_data); recv_data.clear(); has_data = false; mutex.unlock(); // 等待一段时间后再次发送命令 QThread::sleep(1); } } ``` 这个程序使用QT串口实现串口通信,并使用QT的多线程机制实现在主线程中发送串口命令并在子线程中等待串口回复状态。程序使用互斥锁和条件变量等同步机制来保证线程之间的正确协作。需要注意的是,在QT中,如果需要在子线程中执行一段代码,需要继承QThread类并重写其run()方法。在这个程序中,我们将发送串口命令并等待回复状态的代码放在了run()方法中,并在主线程中启动了一个新的子线程来执行这个方法。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值