VB程序以串口方式访问电子秤实例 点击:1460 | 回复:12



没有笔名12345678

    
  • 精华:0帖
  • 求助:0帖
  • 帖子:76帖 | 149回
  • 年度积分:3
  • 历史总积分:1099
  • 注册:2007年3月24日
发表于:2007-11-25 15:05:00
楼主
 VB程序以串口方式访问电子秤实例

http://hexun.com/tingfeng365

现有电子秤一台,使用串口与计算机进行通讯。编写VB程序来访问串口,达到读取电子秤上显示的数据。该电子秤为BE01型仪表,输出为RS-232C标准接口,波特率为300-9600、偶校验、7个数据位、2个停止位。所有字符均发送11位ASCII码,一个起始位。在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函数可以返回一秒的小数部分)
组态王6.53破 解版下载
力控6.0完美破 解
开物2000破 解版
 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 = MSC.Input
 Out(nNum) = var(0)

End Sub
(设置接收数据模式采用二进制形式,即 InputMode=comInputModeBinary,但用Input属性读取数据时,不能直接赋值给 Byte 类型变量,只能通过先赋值给一个 Variant 类型变量,返回一个二进制数据的数组,再转换保存到Byte类型数变量中。) 
mcgs6.2破 解软件下载
http://tingfeng365.blog.hexun.com/
紫金桥监控组态软件6.0 正式版破 解



浪迹&天涯

  • 精华:16帖
  • 求助:0帖
  • 帖子:553帖 | 623回
  • 年度积分:0
  • 历史总积分:3716
  • 注册:2007年10月18日
发表于:2008-02-25 19:54:00
1楼

新手xg

  • 精华:0帖
  • 求助:0帖
  • 帖子:4帖 | 64回
  • 年度积分:0
  • 历史总积分:77
  • 注册:2007年6月01日
发表于:2008-05-21 17:51:13
2楼

是好东西!

非常感谢楼主的!

我行我素-2008

  • 精华:0帖
  • 求助:1帖
  • 帖子:6帖 | 92回
  • 年度积分:7
  • 历史总积分:372
  • 注册:2004年8月03日
发表于:2008-05-22 15:29:20
3楼

学习.

感谢楼主的无私精神

LEEHOM

  • 精华:0帖
  • 求助:0帖
  • 帖子:19帖 | 132回
  • 年度积分:0
  • 历史总积分:317
  • 注册:2007年10月30日
发表于:2008-07-22 10:12:49
4楼

不错,蛮详细的....

newchp

  • 精华:3帖
  • 求助:0帖
  • 帖子:113帖 | 3966回
  • 年度积分:0
  • 历史总积分:9364
  • 注册:2006年7月15日
发表于:2008-08-04 19:06:52
5楼
楼主不厚道,倾而不实,下不了^^^^^^^^^^^^^^^^^^^^^^^^^

KingLion

  • 精华:2帖
  • 求助:0帖
  • 帖子:86帖 | 1155回
  • 年度积分:0
  • 历史总积分:2681
  • 注册:2002年2月26日
发表于:2008-10-14 14:32:07
6楼
很好的东西!支持!!!

学习的路上

  • 精华:0帖
  • 求助:0帖
  • 帖子:1帖 | 16回
  • 年度积分:0
  • 历史总积分:459
  • 注册:2005年11月10日
发表于:2008-11-03 10:38:41
7楼

支持!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

中原龙

  • 精华:0帖
  • 求助:0帖
  • 帖子:9帖 | 831回
  • 年度积分:0
  • 历史总积分:1291
  • 注册:2007年7月09日
发表于:2008-12-25 16:15:21
8楼
很好的东西!支持!!!

hengzhun

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 8回
  • 年度积分:0
  • 历史总积分:9
  • 注册:2012年5月22日
发表于:2012-05-22 03:12:49
9楼

是采集电子秤数据,电子秤的程序是禁止访问的!哈

hengzhun

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 8回
  • 年度积分:0
  • 历史总积分:9
  • 注册:2012年5月22日
发表于:2012-05-22 03:33:36
10楼
怎么给删了,老大。电子秤程序是禁止访问的【OIML】有规定,外部程序只能是采集【接收】数据。现在的电子秤有直通电脑Excel表格保存管理的功能了。还费什么事呀!

竹子

  • 精华:0帖
  • 求助:9帖
  • 帖子:19帖 | 606回
  • 年度积分:0
  • 历史总积分:2154
  • 注册:2009年11月26日
发表于:2012-05-22 06:22:11
11楼

嘻嘻,刚好也在学VB,大家一起研究呀

 

青岛黄工

  • [版主]
  • 精华:3帖
  • 求助:54帖
  • 帖子:108帖 | 4776回
  • 年度积分:0
  • 历史总积分:24297
  • 注册:2007年4月02日
发表于:2012-05-22 09:26:09
12楼

谢谢楼主的分享。。。。。。。。。。。。


热门招聘
相关主题

官方公众号

智造工程师