收藏 分享(赏)

VB控件MSComm串口通讯实例教程.doc

上传人:yjrm16270 文档编号:6539403 上传时间:2019-04-16 格式:DOC 页数:6 大小:38KB
下载 相关 举报
VB控件MSComm串口通讯实例教程.doc_第1页
第1页 / 共6页
VB控件MSComm串口通讯实例教程.doc_第2页
第2页 / 共6页
VB控件MSComm串口通讯实例教程.doc_第3页
第3页 / 共6页
VB控件MSComm串口通讯实例教程.doc_第4页
第4页 / 共6页
VB控件MSComm串口通讯实例教程.doc_第5页
第5页 / 共6页
点击查看更多>>
资源描述

1、现有电子秤一台,使用串口与计算机进行通讯。编写 VB 程序来访问串口,达到读取电子秤上显示的数据。该电子秤为 BE01 型仪表,输出为 RS-232C 标准接口,波特率为300-9600、偶校验、7 个数据位、2 个停止位。所有字符现有电子秤一台,使用串口与计算机进行通讯。编写 VB 程序来访问串口,达到读取电子秤上显示的数据。该电子秤为 BE01 型仪表,输出为 RS-232C 标准接口,波特率为300-9600、偶校验、7 个数据位、2 个停止位。所有字符均发送 11 位 ASCII 码,一个起始位。在 VB 中与串口通讯需要引入控件 MSComm 串口通讯控件(在 Microsoft C

2、omm Control 6.0 中)。具体程序如下:控件简称:MSCDim 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()ClearTextWith MSC.CommPort = 1 设置 Com1 为通信端口.Settings = “9600,E,7,2“ 设置通信端口参数 9600 赫兹、偶校验、7 个

3、数据位、2 个停止位.(这里需要进一步说明的是:.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 WithEnd Sub*Private Sub ClearText()Text3.Text = “Text2.Text = “5“Text1.Text = “End S

4、ubPrivate Sub Command1_Click()ClearText nRece = 0 计数器清零With MSC.InputMode = comInputModeBinary 设置数据接收模式为二进制形式.InBufferCount = 0 清除接收缓冲区If Not .PortOpen Then.PortOpen = True 打开通信端口End IfEnd WithEnd SubPrivate Sub MSC_OnComm()DelayTime 用来延续时间ClearTextWith MSCSelect Case .CommEvent 判断通信事件Case comEvRece

5、ive: 收到 Rthreshold 个字节产生的接收事件SwichVar 1If Out(1) = 2 Then 判断是否为数据的开始标志.RThreshold = 0 关闭 OnComm 事件接收End IfDoDoEventsLoop Until .InBufferCount = 3 循环等待接收缓冲区=3 个字节 nRece = nRece + 1For i = 2 To 12SwichVar iText1.Text = Text1.Text & Chr(Out(i)NextText1.Text = LTrim(Text1.Text)Text2.Text = Text2.Text &

6、CStr(nRece).RThreshold = 1 打开 MSComm 事件接收Case Else .PortOpen = FalseEnd SelectEnd WithEnd Sub*Private Sub DelayTime()Dim bDT As BooleanDim sPrevious As Single, sLast As SinglebDT = TruesPrevious = Timer (Timer 可以计算从子夜到现在所经过的秒数,在 Microsoft Windows 中,Timer 函数可以返回一秒的小数部分)Do While bDTIf Timer - sPreviou

7、s = 0.3 Then bDT = FalseLoopbDT = TrueEnd Sub(通信传输速率为 9600bps,则最快速度 1.04ms 发送一个字节,仪表每秒发送 50 帧数据,每帧数据有 4 个字节,即每秒发送 200 个字节,平均 5.0ms 发送一个字节,连续读取串口数据时要在程序中添加循环等待程序)Private Sub SwichVar(ByVal nNum As Integer)DelayTimevar = Nullvar = MSC.InputOut(nNum) = var(0)End Sub(设置接收数据模式采用二进制形式,即 InputMode=comInput

8、ModeBinary,但用Input 属性读取数据时,不能直接赋值给 Byte 类型变量,只能通过先赋值给一个 Variant 类型变量,返回一个二进制数据的数组,再转换保存到 Byte 类型数变量中。)Private Sub Text1_Change()Text3.Text = CText(Text1.Text) - CText(Text2.Text)End Sub*Private Function CText(ByVal str As String) As CurrencyIf str 4 字节),这时完全可以实现实时监测或实时控制;如果微机在20ms 内不能将数据计算处理完毕,接收缓冲区

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

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 实用文档 > 简明教程

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报