你现在位置:首页>技术论文>数据通讯>正文
Visual Basic串口通讯调试方法
日期:2005-10-28 23:43:08 来源:本站整理  
点击: 作者:
点击【】放大字体.
现有电子秤一台,使用串口与计算机进行通讯。编写VB程序来访问串口,达到读取电子秤上显示的数据。该电子秤为BE01型仪表,输出为RS-232C标准接口,波特率为300-9600、偶校验、7个数据位、2个停止位。所有字符均发送11位ASCII码,一个起始位。在VB中与串口通讯需要引入控件MSComm串口通讯控件(在Microsoft Comm Control 6.0中)。具体程序如下:控件简称:MSC 
WWW_PLCJS※COM-PLC-技×术_网(可编程控※制器技术门户)

WWW_PLCJS※COM-PLC-技.术_网(可※编程控※制器技术门户)

Dim Out(12) As Byte ’接收var中的值
WWW_PLC※JS_COM-PLC-技.术_网(可编程控※制器技术门户)

Dim var As Variant ’接收MSC.input中的数值
P_L_C_技_术_网——可——编——程——控-制-器-技——术——门——户

Dim nRece As Integer ’计算MSC.inputbuffer的个数
WWW_PLCJS※COM-PLC-技.术_网(可※编程控※制器技术门户)

Dim i As Integer, j As Integer ’随即变量,计算循环
WWW_PLCJ-S_COM-PLC-技.术_网(可-编程控-制器技术-门户)

WWW_PLCJS※COM-PLC-技×术_网(可编程控※制器技术门户)

****************************************************************************
——可——编——程——控-制-器-技——术——门——户

WWW※PLCJS_COM-PL#C-技.术_网(可编※程控※制器技术门户)

Private Sub Form_Load()
WWW※PLCJS_COM-PL#C-技.术_网(可编※程控※制器技术门户)

 ClearText
WWW_P※LCJS_COM-PLC-)技.术_网

 With MSC
WW.W_PLC※JS_C,OM-PL,C-技.术_网

  .CommPort = 1 ’设置Com1为通信端口
WWW※PLCJS_COM-PL#C-技.术_网(可编※程控※制器技术门户)

  .Settings = "9600,E,7,2" ’设置通信端口参数 9600赫兹、偶校验、7个数据位、1个停止位.(这里需要进一步说明的是:.Setting=”BBBB,P,D,S”。
WW.W_PLCJS_COM-PLC-技.术_网

  含义是:B:Baud Rate(波特率);P:Parity(奇偶);D:Data Bit;S:Stop Bit)
W1WW_P4LCJS_COM-PLC-技.术_网

WWW_P※LCJS_CO※M-PLC-技-.术_网

  .InBufferSize = 40 ’设置缓冲区接收数据为40字节
WWcW_PLCJS_COM-PLC-技.术_网

  .InputLen = 1 ’设置Input一次从接收缓冲读取字节数为1
WWW_PLCJS_COM-PLC-技.术_网

  .RThreshold = 1 ’设置接收一个字节就产生OnComm事件
W1WW_P4LCJS_COM-PLC-技.术_网

WWW_P※LCJS_COM-PLC-)技.术_网

 End With
P_L_C_技_术_网——可——编——程——控-制-器-技——术——门——户

WWW※PLCJS_COM-PL#C-技.术_网(可编※程控※制器技术门户)

End Sub
WWW_P※LCJS_CO※M-PLC-技-.术_网

WWW_PLCJ-S_COM-PLC-技.术_网(可-编程控-制器技术-门户)

****************************************************************************
P_L_C_技_术_网——可——编——程——控-制-器-技——术——门——户

WWW_PLCJS※COM-PLC-技×术_网(可编程控※制器技术门户)

Private Sub ClearText()
WWW_PL※CJS_COM-PLC-技.术_网

 Text3.Text = ""
WWW※PLCJS_COM-PL#C-技.术_网(可编※程控※制器技术门户)

 Text2.Text = "5"
WW.W_PLC※JS_C,OM-PL,C-技.术_网

 Text1.Text = ""
WWW_PL※CJS_COM-PLC-技.术_网

End Sub
WWW_PLC※JS_COM-PmLC-技.术_网

WWW_PLCJS@_COM%-PLC-技.术_网

Private Sub Command1_Click()
WWW_PLC※JS_COM-PLC-技.术_网(可编程控※制器技术门户)

 ClearText
WWW_PLCJS※COM-PLC-技.术_网(可※编程控※制器技术门户)

 ’ nRece = 0 ’计数器清零
WWW_PLC※JS_COM-PmLC-技.术_网

 With MSC
WWW_PLC※JS_COM-PmLC-技.术_网

  .InputMode = comInputModeBinary ’设置数据接收模式为二进制形式
WWW_PLCJS@_COM%-PLC-技.术_网

  .InBufferCount = 0 ’清除接收缓冲区
WWW_PLCJS_COM-PLC-技.术_网

  If Not .PortOpen Then
WWW_PLC※JS_COM-PLC-技.术_网(可编程控※制器技术门户)

   .PortOpen = True ’打开通信端口
WWW.PLCJS.COM——可编程控制器技术门户

  End If
W1WW_P4LCJS_COM-PLC-技.术_网

 End With
WWW※PLCJS_COM-PL#C-技.术_网(可编※程控※制器技术门户)

End Sub
WW.W_PLCJS_COM-PLC-技.术_网

WWW_P※LCJS_COM-PLC-)技.术_网

Private Sub MSC_OnComm()
W1WW_P4LCJS_COM-PLC-技.术_网

 DelayTime ‘用来延续时间
WW.W_PLC※JS_C,OM-PL,C-技.术_网

 ClearText
WWW_PLCJS※COM-PLC-技.术_网(可※编程控※制器技术门户)

 With MSC
plcjs.技.术_网

  Select Case .CommEvent ’判断通信事件
plcjs.技.术_网

  Case comEvReceive: ’收到Rthreshold个字节产生的接收事件
P_L_C_技_术_网——可——编——程——控-制-器-技——术——门——户

   SwichVar 1
——可——编——程——控-制-器-技——术——门——户

   If Out(1) = 2 Then ’判断是否为数据的开始标志
WWW※PLCJS_COM-PL#C-技.术_网(可编※程控※制器技术门户)

    .RThreshold = 0 ’关闭OnComm事件接收
WWW_PLCJS_COM-PLC-技.术_网

   End If
WWW※PLCJS_COM-PL#C-技.术_网(可编※程控※制器技术门户)

   Do
WWcW_PLCJS_COM-PLC-技.术_网

    DoEvents
WWW_PLCJ-S_COM-PLC-技.术_网(可-编程控-制器技术-门户)

   Loop Until .InBufferCount >= 3 ’循环等待接收缓冲区>=3个字节
WWW_PLCJ-S_COM-PLC-技.术_网(可-编程控-制器技术-门户)

   ’ nRece = nRece + 1
P.L.C.技.术.网——可编程控制器技术门户

   For i = 2 To 12
P_L_C_技_术_网——可——编——程——控-制-器-技——术——门——户

    SwichVar i
plcjs.技.术_网

    Text1.Text = Text1.Text & Chr(Out(i))
WWW_PLCJS※COM-PLC-技×术_网(可编程控※制器技术门户)

   Next
WWcW_PLCJS_COM-PLC-技.术_网

   Text1.Text = LTrim(Text1.Text)
WWW_PLCJS_COM-PLC-技.术_网

   Text2.Text = Text2.Text & CStr(nRece)
WWW_P※LCJS_COM-PLC-)技.术_网

   .RThreshold = 1 ’打开MSComm事件接收
WW.W_PLC※JS_C,OM-PL,C-技.术_网

  Case Else
WWW_PLCJS※COM-PLC-技×术_网(可编程控※制器技术门户)

   ’ .PortOpen = False
P.L.C.技.术.网——可编程控制器技术门户

  End Select
WWW_PL※CJS_COM-PLC-技.术_网

 End With
WWW_PLCJS※COM-PLC-技×术_网(可编程控※制器技术门户)

P.L.C.技.术.网——可编程控制器技术门户

End Sub
WW.W_PLC※JS_C,OM-PL,C-技.术_网

W1WW_P4LCJS_COM-PLC-技.术_网

****************************************************************************
WWW_PLCJS※COM-PLC-技.术_网(可※编程控※制器技术门户)

——可——编——程——控-制-器-技——术——门——户

Private Sub DelayTime()
WWW_PLCJS※COM-PLC-技.术_网(可※编程控※制器技术门户)

WWW_PLC※JS_COM-PLC-技.术_网(可编程控※制器技术门户)

 Dim bDT As Boolean
——可——编——程——控-制-器-技——术——门——户

 Dim sPrevious As Single, sLast As Single
WWW_P※LCJS_COM-PLC-)技.术_网

WWW_PLCJS@_COM%-PLC-技.术_网

 bDT = True
plcjs.技.术_网

WWW_PLCJS_COM-PLC-技.术_网

 sPrevious = Timer (Timer可以计算从子夜到现在所经过的秒数,在Microsoft Windows中,Timer函数可以返回一秒的小数部分)
plcjs.技.术_网

WWW_P※LCJS_CO※M-PLC-技-.术_网

 Do While bDT
WWW_PLCJS※COM-PLC-技.术_网(可※编程控※制器技术门户)

  If Timer - sPrevious >= 0.3 Then bDT = False
WWW_PL※CJS_COM-PLC-技.术_网

 Loop
WWW_PLCJS※COM-PLC-技.术_网(可※编程控※制器技术门户)

 bDT = True
plcjs.技.术_网

P.L.C.技.术.网——可编程控制器技术门户

End Sub
WWW_PLC※JS_COM-PmLC-技.术_网

WW.W_PLC※JS_C,OM-PL,C-技.术_网

(通信传输速率为9600bps,则最快速度1.04ms发送一个字节,仪表每秒发送50帧数据,每帧数据有4个字节,即每秒发送200个字节,平均5.0ms 发送一个字节,连续读取串口数据时要在程序中添加循环等待程序)
WWW_PLCJS_COM-PLC-技.术_网

——可——编——程——控-制-器-技——术——门——户

Private Sub SwichVar(ByVal nNum As Integer)
WWW_P※LCJS_COM-PLC-)技.术_网

WWcW_PLCJS_COM-PLC-技.术_网

 DelayTime
WWW_PL※CJS_COM-PLC-技.术_网

 var = Null
WWW_P※LCJS_COM-PLC-)技.术_网

 var = MSC.Input
WWW_PLCJS※COM-PLC-技×术_网(可编程控※制器技术门户)

 Out(nNum) = var(0)
WW.W_PLCJS_COM-PLC-技.术_网

WWW_PLC※JS_COM-PLC-技.术_网(可编程控※制器技术门户)

End Sub
WWW_PL※CJS_COM-PLC-技.术_网

WWW_P※LCJS_COM-PLC-)技.术_网

(设置接收数据模式采用二进制形式,即 InputMode=comInputModeBinary,但用Input属性读取数据时,不能直接赋值给 Byte 类型变量,只能通过先赋值给一个 Variant 类型变量,返回一个二进制数据的数组,再转换保存到Byte类型数变量中。)
P_L_C_技_术_网——可——编——程——控-制-器-技——术——门——户

WWW_PLCJS※COM-PLC-技×术_网(可编程控※制器技术门户)

Private Sub Text1_Change()
W1WW_P4LCJS_COM-PLC-技.术_网

WWW_PLCJS@_COM%-PLC-技.术_网

 Text3.Text = CText(Text1.Text) - CText(Text2.Text)
——可——编——程——控-制-器-技——术——门——户

WWW_PLCJS@_COM%-PLC-技.术_网

End Sub
WWW_PLC※JS_COM-PLC-技.术_网(可编程控※制器技术门户)

WWW_P※LCJS_CO※M-PLC-技-.术_网

****************************************************************************
WWW_P※LCJS_COM-PLC-)技.术_网

WWW.PLCJS.COM——可编程控制器技术门户

Private Function CText(ByVal str As String) As Currency
WWW_PL※CJS_COM-PLC-技.术_网

WWW_PL※CJS_COM-PLC-技.术_网

 If str <> "" Then
WWW_PL※CJS_COM-PLC-技.术_网

  CText = CCur(Val(str))
WWcW_PLCJS_COM-PLC-技.术_网

 Else
WWW_PLCJS※COM-PLC-技.术_网(可※编程控※制器技术门户)

  CText = 0
P_L_C_技_术_网——可——编——程——控-制-器-技——术——门——户

 End If
WWW.PLCJS.COM——可编程控制器技术门户

WWW_PLCJS_COM-PLC-技.术_网

End Function 
P.L.C.技.术.网——可编程控制器技术门户

P.L.C.技.术.网——可编程控制器技术门户

  (仪表每秒发送50帧数据,微机收到一帧完整数据至少需要20 ms时间,然后再进行数据处理。如果微机在下一帧数据接收前即20ms内能将数据计算处理完毕,则接收缓冲区内只会保存有一帧数据,不会存有两帧以上数据,接收缓冲区的大小不会影响实时监测效果(接收缓冲区>4字节),这时完全可以实现实时监测或实时控制;如果微机在20ms内不能将数据计算处理完毕,接收缓冲区设置得又很大,在数据计算处理完毕前,接收缓冲区内就会保存有两帧以上数据,而且一次工作时间越长,缓冲区内滞留数据帧就越多,数据采集和数据处理之间产生逐渐增大的额外时间差,当接收缓冲区充满后,时间差不再增大,固定在某一值,部分数据因不能及时采集到接收缓冲区中,数据产生丢失现象,真实工作情况就会和微机处理结果产生较大的时间差,对实时监测和实时控制很不利,这种情况下接收缓冲区的大小就会影响实时监测效果,所以接收缓冲区设置不能过大,以保证数据处理的实时性。) 小结:本文所用的仪表为梅特勒公司出产的BE01型电子秤,其输出的每个编码均为标准的ASCII码。其他的仪表存在发射的编码中含有BCD压缩码,而且分为高低位,需要接收后对其进行解码换算,之后还要将高位和低位数字进行相加,即可以将其BCD码换算成实数。另还存在误差的可能:判断最大值,仪表在刚开始工作时有干扰,会传导一些乱码,位移传感器有参数偏差,最大值一般都略大于50毫米,所以取51为极限最大值,取-51为极限最小值。暂时先写这些,当然其他的情况可以依此类推! 
出自:[]
评论内容
载入中...
载入中...
P
L
C



|










|


P
L
C









·最新招聘信息
·最新求职信息
·推荐产品
·推荐厂商
·栏目热门排行
·站内热门排行