VB编写的Modbus RTU协议通讯源程序(2)

2019-03-03 13:10

Private Sub cmdSDO_Click() Dim btSend(8) As Byte

btSend(0) = &H1 '目标站号 btSend(1) = &H5 '功能码

btSend(2) = &H0 'Q1.1地址(0009)高字节 btSend(3) = &H9 'Q1.1地址(0009)低字节 btSend(4) = &HFF '强制值高字节 btSend(5) = &H0 '强制值低字节

Dim crc

Dim btCRCHi As Byte, btCRCLo As Byte

crc = CalCRC16Fast(btSend, 6, btCRCLo, btCRCHi)

btSend(6) = btCRCHi btSend(7) = btCRCLo

ComK3.Output = CVar(btSend)

End Sub

④ “读取IB0”按钮单击事件

'查表知I0.0的modbus地址为0000,从I0.0开始读取连续8位 Private Sub Command1_Click()

'发请求

Dim btSend(8) As Byte

btSend(0) = &H1 '目标站号 btSend(1) = &H2 '功能码

btSend(2) = &H0 'I0.0地址(0000)高字节 btSend(3) = &H0 'i0.0地址(0000)低字节 btSend(4) = &H0 '读取个数高字节 btSend(5) = &H8 '读取个数低字节

Dim crc

Dim btCRCHi As Byte, btCRCLo As Byte

crc = CalCRC16Fast(btSend, 6, btCRCLo, btCRCHi)

btSend(6) = btCRCHi btSend(7) = btCRCLo

ComK3.Output = CVar(btSend)

'注意下面编写的接收过程很简单,要编写实际应用的监控程序来说需要更完善 Dim btReceive As Variant

With ComK3 Do

DoEvents

Loop Until .InBufferCount = 6

.InputLen = 6

btReceive = .Input

If btReceive(1) = &H2 Then '若正确,返回帧的第2个字节为功能码.实际上,此处应首先进行CRC校验

txtReceive.Text = Hex$(btReceive(3)) End If End With End Sub


VB编写的Modbus RTU协议通讯源程序(2).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:Oracle数据库应用开发题库

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: