最近免费中文字幕大全免费版视频-蜜臀av夜夜澡人人爽人人-777天堂麻豆爱综合视频-伊人蕉久中文字幕无码专区-亚洲国产综合精品 在线 一区

產(chǎn)品列表PRODUCTS LIST

聯(lián)系信息

  • 電話:
    13521418576
  • 傳真:
    010-62979724
首頁 > 技術(shù)與支持 > Visual Basic串口通訊調(diào)試方法
Visual Basic串口通訊調(diào)試方法
點擊次數(shù):5240 更新時間:2009-12-25

Visual Basic串口通訊調(diào)試方法

  現(xiàn)有電子秤一臺,使用串口與計算機進行通訊。編寫VB程序來訪問串口,達到讀取電子秤上顯示的數(shù)據(jù)。該電子秤為BE01型儀表,輸出為RS-232C標準接口,波特率為300-9600、偶校驗、7個數(shù)據(jù)位、2個停止位。所有字符均發(fā)送11位ASCII碼,一個起始位。在VB中與串口通訊需要引入控件MSComm串口通訊控件(在Microsoft Comm Control 6.0中)。具體程序如下:控件簡稱:MSC

Dim Out(12) As Byte '接收var中的值
Dim var As Variant '接收MSC.input中的數(shù)值
Dim nRece As Integer '計算MSC.inputbuffer的個數(shù)
Dim i As Integer, j As Integer '隨即變量,計算循環(huán)

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

Private Sub Form_Load()
 ClearText
 With MSC
  .CommPort = 1 '設置Com1為通信端口
  .Settings = "9600,E,7,2" '設置通信端口參數(shù) 9600赫茲、偶校驗、7個數(shù)據(jù)位、1個停止位.(這里需要進一步說明的是:.Setting=”BBBB,P,D,S”。
  含義是:B:Baud Rate(波特率);P:Parity(奇偶);D:Data Bit;S:Stop Bit)

  .InBufferSize = 40 '設置緩沖區(qū)接收數(shù)據(jù)為40字節(jié)
  .InputLen = 1 '設置Input一次從接收緩沖讀取字節(jié)數(shù)為1
  .RThreshold = 1 '設置接收一個字節(jié)就產(chǎn)生OnComm事件

 End With

End Sub

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

Private Sub ClearText()
 Text3.Text = ""
 Text2.Text = "5"
 Text1.Text = ""
End Sub

Private Sub Command1_Click()
 ClearText
 ' nRece = 0 '計數(shù)器清零
 With MSC
  .InputMode = comInputModeBinary '設置數(shù)據(jù)接收模式為二進制形式
  .InBufferCount = 0 '清除接收緩沖區(qū)
  If Not .PortOpen Then
   .PortOpen = True '打開通信端口
  End If
 End With
End Sub

Private Sub MSC_OnComm()
 DelayTime ‘用來延續(xù)時間
 ClearText
 With MSC
  Select Case .CommEvent '判斷通信事件
  Case comEvReceive: '收到Rthreshold個字節(jié)產(chǎn)生的接收事件
   SwichVar 1
   If Out(1) = 2 Then '判斷是否為數(shù)據(jù)的開始標志
    .RThreshold = 0 '關閉OnComm事件接收
   End If
   Do
    DoEvents
   Loop Until .InBufferCount >= 3 '循環(huán)等待接收緩沖區(qū)>=3個字節(jié)
   ' 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可以計算從子夜到現(xiàn)在所經(jīng)過的秒數(shù),在Microsoft Windows中,Timer函數(shù)可以返回一秒的小數(shù)部分)

 Do While bDT
  If Timer - sPrevious >= 0.3 Then bDT = False
 Loop
 bDT = True

End Sub

(通信傳輸速率為9600bps,則zui快速度1.04ms發(fā)送一個字節(jié),儀表每秒發(fā)送50幀數(shù)據(jù),每幀數(shù)據(jù)有4個字節(jié),即每秒發(fā)送200個字節(jié),平均5.0ms 發(fā)送一個字節(jié),連續(xù)讀取串口數(shù)據(jù)時要在程序中添加循環(huán)等待程序)

Private Sub SwichVar(ByVal nNum As Integer)

 DelayTime
 var = Null
 var = MSC.Input
 Out(nNum) = var(0)

End Sub

(設置接收數(shù)據(jù)模式采用二進制形式,即 InputMode=comInputModeBinary,但用Input屬性讀取數(shù)據(jù)時,不能直接賦值給 Byte 類型變量,只能通過先賦值給一個 Variant 類型變量,返回一個二進制數(shù)據(jù)的數(shù)組,再轉(zhuǎn)換保存到Byte類型數(shù)變量中。)

Private Sub Text1_Change()

 Text3.Text = CText(Text1.Text) - CText(Text2.Text)

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
 

主站蜘蛛池模板: 成人国产精品秘?鲁鲁3D| 亚洲精品屋v一区二区| 浪潮av激情高潮国产精品| 中文综合在线观| 无码一区二区三区av免费 | 把腿张开老子臊烂你多p视频 | 国产电影一区二区三区| 亚洲精品无码专区在线观看| 亚洲精品第一国产综合野草社区| 亚洲的天堂av无码| 中文字幕丰满孑伦无码精品| 88久久精品无码一区二区毛片| 精品人妻av区乱码| 亚瑟国产精品久久| 黄网站色视频免费国产| 男女做爰无遮挡性视频| 免费国产午夜视频在线| 日本一区二区三区不卡免费| 色窝窝免费一区二区三区| 久9re热视频这里只有精品| 国产一区二区三区不卡av| 欧洲美熟女乱又伦av影片| 国产精品久久欧美久久一区 | 日日躁夜夜躁狠狠躁| 中文字幕av无码不卡| 国产精品污www在线观看| 亚洲综合图色40p| 成人性生交大免费看| 天天射寡妇射| 躁躁躁日日躁| 野外少妇愉情中文字幕| 精品香蕉一区二区三区| 国产av夜夜欢一区二区三区| 精品人妻少妇一区二区| 风流少妇按摩来高潮| 欧美交换国产一区内射| 久久精品久久久久观看99水蜜桃| 超碰97人人射妻| 亚洲人成人网站18禁| 亚洲 欧美 清纯 校园 另类| 一区二区三区四区在线不卡高清 |