admin 管理员组

文章数量: 1086019


2024年3月19日发(作者:shell脚本awk死循环语句)

VB串口编程

现有电子秤台使用串口和计算机进行通讯编写VB来访问串口达到读取电子秤上显示

数据该电子秤为BE01型仪表输出为RS-232C标准接口波特率为300-9600、偶校验、7

个数据位、2个停止位所有均发送11位ASCII码个起始位在VB中和串口通讯需要引入

Control控件MSComm串口通讯Control控件(在Microsoft Comm Control 6.0中)具

体如下:Control控件简称:MSC

Dim Out(12) As Byte '接收var中值

Dim var As Variant '接收中数值

Dim nRece As Integer '计算uffer个数

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

= ""

= "5"

= ""

End Sub

Private Sub Command1_Click

ClearText

' nRece = 0 '计数器清零

With MSC

.InputMode = comInputModeBinary '设置数据接收模式为 2进制形式

.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

= & Chr(Out(i))

Next

= LTrim()

= & 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

(通信传输速率为9600bps则最快速度1.04ms发送个字节仪表每秒发送50帧数据每

帧数据有4个字节即每秒发送200个字节平均5.0ms 发送个字节连续读取串口数据时要

在中添加循环等待)

Private Sub SwichVar(ByVal nNum As Integer)

DelayTime

var = Null

var =

Out(nNum) = var(0)

End Sub

(设置接收数据模式采用 2进制形式即 InputMode=comInputModeBinary但用

Input属性读取数据时不能直接赋值给 Byte 类型变量只能通过先赋值给个 Variant 类型

变量返回个 2进制数据再转换保存到Byte类型数变量中)

Private Sub Text1_Change

= CText() - CText()

End Sub

****************************************************************************

Private Function CText(ByVal str As String) As Currency

If str <> "" Then

CText = CCur(Val(str))

Else

CText = 0

End If

End Function


本文标签: 串口 接收 字节 数据 设置