用VB的MSComm控件实现PC机与多个单片机的通信
2个回答
展开全部
下面是一台电子秤的串口应用,请参考:
输出 RS-232C标准接口,波特率 300-9600、偶校验、7个数据位、2个停止位。所有字符均发送11位ASCII码, 1个起始位。 VB 串口通讯需 引入控 MSComm串口通讯控 ( Microsoft Comm Control 6.0 )。具体程序如 :
控件简称:MSC
Dim Out(12) As Byte '接收var 值
Dim var As Variant '接收MSC.input 数值
Dim nRece As Integer '计算MSC.inputbuffer 个数
Dim i As Integer, j As Integer '随即变量,计算循环
Private Sub Form_Load()
ClearText
With MSC
.CommPort = 1 '设置Com1 通信端口
.Settings = "9600,E,7,2" '设置通信端口参数 9600赫兹、偶校验、7个数据位、1个停止位.(这里需进一步说明 :.Setting=”BBBB,P,D,S”。
含义 :B:Baud Rate(波特率);P:Parity(奇偶);D:Data Bit;S:Stop Bit)
.InBufferSize = 40 '设置缓冲区接收数据 40字节
.InputLen = 1 '设置Input 次从接收缓冲读 字节数 1
.RThreshold = 1 '设置接收 个字节就产生OnComm事
End With
End Sub
Private Sub ClearText()
Text3.Text = ""
Text2.Text = "5"
Text1.Text = ""
End Sub
Private Sub Command1_Click()
ClearText
' nRece = 0 '计数器清零
With MSC
.InputMode = comInputModeBinary '设置数据接收模式 二进制形式
.InBufferCount = 0 '清除接收缓冲区
If Not .PortOpen Then
.PortOpen = True '打开通信端口
End If
End With
End Sub
Private Sub MSC_OnComm()
DelayTime ‘ 延续时间
ClearText
With MSC
Select Case .CommEvent '判断通信事
Case comEvReceive: '收 Rthreshold个字节产生 接收事
SwichVar 1
If Out(1) = 2 Then '判断 否 数据 开始标志
.RThreshold = 0 '关闭OnComm事 接收
End If
Do
DoEvents
Loop Until .InBufferCount >= 3 '循环等待接收缓冲区>=3个字节
' nRece = nRece + 1
For i = 2 To 12
SwichVar i
Text1.Text = Text1.Text & Chr(Out(i))
Next
Text1.Text = LTrim(Text1.Text)
Text2.Text = Text2.Text & CStr(nRece)
.RThreshold = 1 '打开MSComm事 接收
Case Else
' .PortOpen = False
End Select
End With
End Sub
Private Sub DelayTime()
Dim bDT As Boolean
Dim sPrevious As Single, sLast As Single
bDT = True
sPrevious = Timer (Timer 以计算从子夜 现 所经过 秒数, Microsoft Windows ,Timer函数 以返回 秒 数部分)
Do While bDT
If Timer - sPrevious >= 0.3 Then bDT = False
Loop
bDT = True
End Sub
输出 RS-232C标准接口,波特率 300-9600、偶校验、7个数据位、2个停止位。所有字符均发送11位ASCII码, 1个起始位。 VB 串口通讯需 引入控 MSComm串口通讯控 ( Microsoft Comm Control 6.0 )。具体程序如 :
控件简称:MSC
Dim Out(12) As Byte '接收var 值
Dim var As Variant '接收MSC.input 数值
Dim nRece As Integer '计算MSC.inputbuffer 个数
Dim i As Integer, j As Integer '随即变量,计算循环
Private Sub Form_Load()
ClearText
With MSC
.CommPort = 1 '设置Com1 通信端口
.Settings = "9600,E,7,2" '设置通信端口参数 9600赫兹、偶校验、7个数据位、1个停止位.(这里需进一步说明 :.Setting=”BBBB,P,D,S”。
含义 :B:Baud Rate(波特率);P:Parity(奇偶);D:Data Bit;S:Stop Bit)
.InBufferSize = 40 '设置缓冲区接收数据 40字节
.InputLen = 1 '设置Input 次从接收缓冲读 字节数 1
.RThreshold = 1 '设置接收 个字节就产生OnComm事
End With
End Sub
Private Sub ClearText()
Text3.Text = ""
Text2.Text = "5"
Text1.Text = ""
End Sub
Private Sub Command1_Click()
ClearText
' nRece = 0 '计数器清零
With MSC
.InputMode = comInputModeBinary '设置数据接收模式 二进制形式
.InBufferCount = 0 '清除接收缓冲区
If Not .PortOpen Then
.PortOpen = True '打开通信端口
End If
End With
End Sub
Private Sub MSC_OnComm()
DelayTime ‘ 延续时间
ClearText
With MSC
Select Case .CommEvent '判断通信事
Case comEvReceive: '收 Rthreshold个字节产生 接收事
SwichVar 1
If Out(1) = 2 Then '判断 否 数据 开始标志
.RThreshold = 0 '关闭OnComm事 接收
End If
Do
DoEvents
Loop Until .InBufferCount >= 3 '循环等待接收缓冲区>=3个字节
' nRece = nRece + 1
For i = 2 To 12
SwichVar i
Text1.Text = Text1.Text & Chr(Out(i))
Next
Text1.Text = LTrim(Text1.Text)
Text2.Text = Text2.Text & CStr(nRece)
.RThreshold = 1 '打开MSComm事 接收
Case Else
' .PortOpen = False
End Select
End With
End Sub
Private Sub DelayTime()
Dim bDT As Boolean
Dim sPrevious As Single, sLast As Single
bDT = True
sPrevious = Timer (Timer 以计算从子夜 现 所经过 秒数, Microsoft Windows ,Timer函数 以返回 秒 数部分)
Do While bDT
If Timer - sPrevious >= 0.3 Then bDT = False
Loop
bDT = True
End Sub
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询