.net winform 使用NModbus4建立 modbus tcp通讯

1、使用nuget引入NModbus4。

2、编写TCP访问modbus的方法

public void StartTcpClient(string ipstr,string portstr,ushort adress, ushort readLenth)
        {
            try
            {
                IPAddress myIP =IPAddress.Parse(ipstr);
                int port = int.Parse(portstr);
                IsListen = true;

                
                TcpClient myclient = new TcpClient(ipstr, port);
                ModbusMaster myMaster = ModbusIpMaster.CreateIp(myclient);
                myMaster.Transport.ReadTimeout = 2000;
                myMaster.Transport.Retries = 3;
                myMaster.Transport.WaitToRetryMilliseconds = 250;
                ushort[] value = myMaster.ReadHoldingRegisters(1, adress, readLenth);

            }
            catch (Exception ex)
            {
                Log4netHelper.MyErrorMsgLog("StartTcpClient 方法出错:" + ex.Message);
            }
        }

3、更多参数设置

连接参数设置:

master.Transport.ReadTimeout = 1000;//读取连接(串口)数据超时为

master.Transport.WriteTimeout = 1000;//写入连接(串口)数据超时

master.Transport.Retries = 3;//重试次数

master.Transport.WaitToRetryMilliSeconds = 250;//重试间隔

可读写线圈调用函数:

//读线圈,参数:从站地址 (8位 ) 、起始地址 (16位 ) 、数量 (16位 ) ;返回布尔型数 组
bool[] ReadCoils(byte slaveAddress, ushort startAddress, ushort numberOfPoints);

//读输入离散量,参数:从站地址 (8位 ) 、起始地址 (16位 ) 、数量 (16位 ) ;返回布 尔型数组
bool[] ReadInputs(byte slaveAddress, ushort startAddress, ushort numberOfPoints);

//读保持寄存器,参数:从站地址 (8位 ) 、起始地址 (16位 ) 、数量 (16位 ) ;返回 16位整型数组
ushort[] ReadHoldingRegisters(byte slaveAddress, ushort startAddress, ushort numberOfPoints);

//读输入寄存器,参数:从站地址 (8位 ) 、起始地址 (16位 ) 、数量 (16位 ) ;返回 16位整型数组
ushort[] ReadInputRegisters(byte slaveAddress, ushort startAddress, ushort numberOfPoints);

//写单个线圈,参数:从站地址 (8位 ) ,线圈地址 (16位 ) ,线圈值 (布尔型 ) 
void WriteSingleCoil(byte slaveAddress, ushort coilAddress, bool value);

//写单个寄存器,参数:从站地址 (8位 ) ,寄存器地址 (16位 ) ,寄存器值 (16位 )
 void WriteSingleRegister(byte slaveAddress, ushort registerAddress, ushort value);

//写多个寄存器,参数:从站地址 (8位 ) ,起始地址 (16位 ) ,寄存器值 (16位整型 数组 )
void WriteMultipleRegisters(byte slaveAddress, ushort startAddress, ushort[] data);

//写多个线圈,参数:从站地址 (8位 ) ,起始地址 (16位 ) ,线圈值 (布尔型数组 ) 
void WriteMultipleCoils(byte slaveAddress, ushort startAddress, bool[] data);

//读写多个寄存器,参数:从站地址 (8位 ) ,读起始地址 (16位 ) ,数量 (16位 ) ,写 起始地址 (16位 ) ,写入值 (16位整型数组 ) ;返回 16位整型数组
ushort[] ReadWriteMultipleRegisters(byte slaveAddress, ushort startReadAddress, ushort numberOfPointsToRead, ushort startWriteAddress, ushort[] writeData);
 

 

  • 17
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 VB.NET WinForm 应用程序中,可以使用 `BackgroundWorker` 组件来执行长时间任务,而不会阻塞应用程序界面的响应。下面是一个简单的使用示例: 1. 在 WinForm 窗体设计器中,拖拽一个 `BackgroundWorker` 组件到窗体上。 2. 在窗体中添加一个按钮,用于触发长时间任务。 3. 在按钮的 `Click` 事件处理程序中,启动 `BackgroundWorker` 组件,并在 `DoWork` 事件处理程序中编写长时间任务的代码。 ```vb.net Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click BackgroundWorker1.RunWorkerAsync() ' 启动 BackgroundWorker 组件 End Sub Private Sub BackgroundWorker1_DoWork(sender As Object, e As System.ComponentModel.DoWorkEventArgs) Handles BackgroundWorker1.DoWork ' 执行长时间任务的代码 For i = 1 To 10 System.Threading.Thread.Sleep(1000) ' 模拟长时间任务,每秒钟执行一次 Next End Sub ``` 4. 在 `RunWorkerCompleted` 事件处理程序中,添加长时间任务执行完毕后需要执行的代码。 ```vb.net Private Sub BackgroundWorker1_RunWorkerCompleted(sender As Object, e As System.ComponentModel.RunWorkerCompletedEventArgs) Handles BackgroundWorker1.RunWorkerCompleted ' 长时间任务执行完毕后需要执行的代码 MessageBox.Show("长时间任务执行完毕!") End Sub ``` 需要注意的是,`BackgroundWorker` 组件中的 `DoWork` 事件处理程序是在另一个线程中执行的,所以在这个事件处理程序中不能直接访问 UI 元素,如 Label、Button 等控件,如果需要访问这些控件,需要使用 `Invoke` 方法来进行跨线程访问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值