Qt Modbus 寄存器读写实例

一.线圈状态寄存器读写

  • 项目效果如下
    在这里插入图片描述

1. 写单个寄存器

  • MODBUS_API int modbus_write_bit(modbus_t *ctx, int coil_addr, int status);
int addr=ui->spinBoxwirte_addr->value();
    int data=ui->spinBoxwirte_data->value();
    int ret = modbus_write_bit(mb,addr,data);

    if(ret!=1)
    {
        QMessageBox::information(this,"失败",
                                 "写状态寄存器失败,地址:"+QString::number(data));
    }else
    {
        label_status->setText("写线圈状态寄存器成功!");
    }

2. 读单个寄存器

  • int modbus_read_bits(modbus_t *ctx, int addr, int nb, uint8_t *dest);
int addr=ui->spinBoxRead_addr->value();
    int data=ui->spinBoxRead_data->value();
    //int modbus_read_bits(modbus_t *ctx, int addr, int nb, uint8_t *dest);
    uint8_t dest[4];
    int ret = modbus_read_bits(mb,addr,1,dest);

    if(ret!=1)
    {
        QMessageBox::information(this,"失败",
                                 "读状态寄存器失败,地址:"+QString::number(data));
    }else
    {
        label_status->setText("读线圈状态寄存器成功!");
        qDebug()<<"读出的数据为:"<<dest[0];
        ui->spinBoxRead_data->setValue(dest[0]);
    }

3. 写多个寄存器

  • int modbus_write_bits(modbus_t *ctx, int addr, int nb, const uint8_t *data);
int addr=ui->spinBoxWriteMore_addr->value();

    //使用正则表达式,来处理字符串的分割
    QString  str = ui->textEdit_xianWrite->toPlainText();

    //用正则表达式进行分割
    QRegExp separator= QRegExp("\t|\n|\r\n|,| |;");

    //进行分割
    QStringList list =  str.split(separator,QString::SkipEmptyParts);

    uint8_t*value=new uint8_t[list.count()];

    for(int i=0;i<list.count();i++)
    {
        value[i]=list[i].toInt();
    }

    //int modbus_write_bits(modbus_t *ctx, int addr, int nb, const uint8_t *data);

    int ret = modbus_write_bits(mb,addr,list.count(),value);

    if(ret!=list.count())
    {
        QMessageBox::information(this,"写多个失败",
                                 "读状态寄存器失败,地址:"+QString::number(addr));
         label_status->setText("写多个线圈状态寄存器失败!");
    }else
    {
        label_status->setText("写多个线圈状态寄存器成功!");
    }

    delete [] value;


4. 读多个寄存器

- int modbus_read_bits(modbus_t *ctx, int addr, int nb, uint8_t *dest);

ui->textEditRead_xian->clear();
    int addr=ui->spinBoxReadMorexian_addr->value();
    int count=ui->spinBoxReadMorexian_num->value();

    uint8_t *values = new uint8_t[count];

    //int modbus_read_bits(modbus_t *ctx, int addr, int nb, uint8_t *dest);
    int ret=modbus_read_bits(mb,addr,count,values);

    if(ret!=count)
    {
        QMessageBox::information(this,"读多个失败",
                                 "读状态寄存器失败,地址:"+QString::number(addr));
         label_status->setText("读多个线圈状态寄存器失败!");
    }else
    {
        label_status->setText("读多个线圈状态寄存器成功!");
        QString str;
        for(int i=0;i<count;i++)
        {
            str+=QString::number(values[i])+"\t";
        }

        ui->textEditRead_xian->setText(str);

    }

    delete [] values;

二.离散输入状态寄存器读写

  • 效果展示如下
    在这里插入图片描述

1. 读单个寄存器

  • int modbus_read_input_bits(modbus_t *ctx, int addr, int nb, uint8_t *dest);
 int addr=ui->spinBoxInput_one_addr->value();
    int data;
    //int modbus_read_input_bits(modbus_t *ctx, int addr, int nb, uint8_t *dest);
    uint8_t dest[4];
    int ret = modbus_read_input_bits(mb,addr,1,dest);

    if(ret!=1)
    {
        QMessageBox::information(this,"失败",
                                 "读单个离散输入寄存器失败,地址:"+QString::number(addr));
    }else
    {
        label_status->setText("读单个离散输入寄存器成功!");
        qDebug()<<"读出的数据为:"<<dest[0];
        ui->spinBoxInput_one_data->setValue(dest[0]);
    }

2. 读多个寄存器

  • int modbus_read_input_bits(modbus_t *ctx, int addr, int nb, uint8_t *dest);
ui->textEdit_input->clear();
    int addr=ui->spinBoxInput_more_addr->value();
    int count=ui->spinBoxInput_more_num->value();

    //int modbus_read_input_bits(modbus_t *ctx, int addr, int nb, uint8_t *dest);
    uint8_t *dest=new uint8_t[count];
    int ret = modbus_read_input_bits(mb,addr,count,dest);

    if(ret!=count)
    {
        QMessageBox::information(this,"失败",
                                 "读多个离散输入寄存器失败,地址:"+QString::number(addr));
    }else
    {
        label_status->setText("读多个离散输入寄存器成功!");
        QString str;
        for(int i=0;i<count;i++)
        {
            str+= QString::number(dest[i])+"\t";
        }

        ui->textEdit_input->setText(str);

    }

三.保持寄存器读写

  • 效果如下:
    在这里插入图片描述

1. 写单个寄存器

  • int modbus_write_register(modbus_t *ctx, int reg_addr, const uint16_t value);
 //int modbus_write_register(modbus_t *ctx, int reg_addr, const uint16_t value);
    int addr=ui->spinBoxHoldRegWrite_addr->value();
    int value=ui->spinBoxHoldRegW_data->value();

    int ret =modbus_write_register(mb,addr,value);

    if(ret!=1)
    {
        QMessageBox::information(this,"失败","保持寄存器写单个失败");
    }else
    {
        QMessageBox::information(this,"成功","保持寄存器写单个成功!!!");
    }

2. 读单个寄存器

- int modbus_read_registers(modbus_t *ctx, int addr, int nb, uint16_t *dest);

int addr=ui->spinBox_HoldR_addr->value();
    uint16_t dest[4];
    //int modbus_read_registers(modbus_t *ctx, int addr, int nb, uint16_t *dest);
    int ret = modbus_read_registers(mb,addr,1,dest);

    if(ret!=1)
    {
        QMessageBox::information(this,"失败","保持寄存器读单个失败");
    }else
    {
        QMessageBox::information(this,"成功","保持寄存器读单个成功!!!");
        ui->spinBox_HoldR_data->setValue(dest[0]);
    }

四.输入寄存器读写

  • 项目效果
    在这里插入图片描述

1. 读单个寄存器

- int modbus_read_input_registers(modbus_t *ctx, int addr, int nb, uint16_t *dest);

 int addr=ui->spinBoxInput_one_addr->value();
    int data;
    //int modbus_read_input_bits(modbus_t *ctx, int addr, int nb, uint8_t *dest);
    uint8_t dest[4];
    int ret = modbus_read_input_registers(mb,addr,1,dest);

    if(ret!=1)
    {
        QMessageBox::information(this,"失败",
                                 "读单个离散输入寄存器失败,地址:"+QString::number(addr));
    }else
    {
        label_status->setText("读单个离散输入寄存器成功!");
        qDebug()<<"读出的数据为:"<<dest[0];
        ui->spinBoxInput_one_data->setValue(dest[0]);
    }

2. 读多个寄存器

  • int modbus_read_input_registers(modbus_t *ctx, int addr, int nb, uint16_t *dest);
ui->textEdit_input->clear();
    int addr=ui->spinBoxInput_more_addr->value();
    int count=ui->spinBoxInput_more_num->value();

    //int modbus_read_input_bits(modbus_t *ctx, int addr, int nb, uint8_t *dest);
    uint8_t *dest=new uint8_t[count];
    int ret = modbus_read_input_registers(mb,addr,count,dest);

    if(ret!=count)
    {
        QMessageBox::information(this,"失败",
                                 "读多个离散输入寄存器失败,地址:"+QString::number(addr));
    }else
    {
        label_status->setText("读多个离散输入寄存器成功!");
        QString str;
        for(int i=0;i<count;i++)
        {
            str+= QString::number(dest[i])+"\t";
        }

        ui->textEdit_input->setText(str);

    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Qt中使用Modbus RTU进行寄存器读写操作可以通过以下步骤实现: 1. 首先,在头文件mainwindow.h中包含所需的Modbus相关头文件,例如QModbusRtuSerialMaster、QModbusClient等\[1\]。 2. 定义一个枚举类型RegisterType,用于指定寄存器的类型,包括Invalid、DiscreteInputs、Coils、InputRegisters和HoldingRegisters\[2\]。 3. 在主窗口类的函数sendModbus()中,实现写报文的功能。首先设置寄存器的起始地址regStartAddr,然后创建一个QModbusDataUnit对象writeUnit,指定寄存器类型为HoldingRegisters,并设置起始地址和寄存器数量。接下来,设置要写入的值,例如将number设置为0x08,然后调用modbusDevice的sendWriteRequest函数发送写请求。如果请求未完成,可以使用connect函数连接finished信号,以便在请求完成后进行处理\[3\]。 总结起来,使用Qt进行Modbus RTU寄存器读写操作需要包含相关头文件,定义寄存器类型枚举,然后在相应的函数中实现读写操作。 #### 引用[.reference_title] - *1* *3* [关于QT Modbus RTU 的总结](https://blog.csdn.net/qq_45555020/article/details/111034252)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Qt ModbusTCP ModbusRTU 使用同步读和异步写](https://blog.csdn.net/u010058695/article/details/116701572)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值