小视频免费在线观看_夜夜b_男女隐私免费视频_国产一级性生活视频_久久综合入口_精品国内视频

技術頻道

利用VB的MSComm控件編程實現PC與三菱PLC FX系列通信

編寫PC的通信程序可采用匯編語言編寫,或采用各種高級語言編寫,或采用工控組態軟件,或直接采用PLC廠家的通信軟件(如三菱的MELSE MEDOC等)

下面利用VB6.0以一個簡單的例子來說明編寫通信程序的要點。假設PC要求從PLC中讀入從D123開始的4個字節的數據(D123D124),其傳輸應答過程及報文如圖7-16所示。

7-16 傳輸應答過程及命令報文

命令報文中10F6HD123的地址,04H表示要讀入4個字節的數據。校驗和SUM30H31H30H46H36H30H34H03 H174H,溢出部分不計,故SUMH=7,SUAIL=4,相應的ASC碼為“37H”,“34H”。應答報文中4個字節的十六進制數,其相應的ASC碼為8個字節,故應答報文長度為12個字節。

根據PCFX系列PLC的傳輸應答過程,利用VBMSComm控件可以編寫如下通信程序實現PCFX系列PLC之間的串行通信,以完成數據的讀取。MSComm控件可以采用輪詢或事件驅動的方法從端口獲取數據。在這個例子中使用了輪詢方法。

1)通信口初始化

Private Sub Initialize()

MSComm1CommPort =1

MSComm1Settings = “9600,E,7,1”

MSComm1InBufferSize = 1024

MSCommlOutBuffersize = 1024

MSComm1InputLen = 0

MSCommlInputMode = comInputText

MSComm1Handshaking = comNone

MSComm1PortOpen = True

End Sub

2)請求通信與確認

Private Function MakeHandshaking()As Boolean

Dim InPackage As String

MSCommlOutBufferCount = 0

MSCommlInBufferCount = 0

MSCommlOutPut = Chr(&H5

Do

DoEvents

Loop Until MSCommlInBufferCount = 1

InPackage = MSCommlInput

If InPackage = Chr(&H6 Then

MakeHandShaking = True

Else

MakeHandshaking = False

End If

End Function

3)發送命令報文

Private Sub SendFrame ()

Dim Outstring As String

MSCommlOutBufferCount = 0

MSCommlInBufferCount = 0

Outstrin = Chr(&H2)+on10F604Chr(&H3)+74

MSCommlOutput = Outstring

End Sub

4)讀取應答報文

Private Sub ReceiveFrame()

Dim Instring As String

Do

DoEvents

Loop Until MSCommlInBufferCount = 12

InString = MSCommlInpult

End Sub

文章版權歸西部工控xbgk所有,未經許可不得轉載。

主站蜘蛛池模板: 成人小视频在线 | 亚洲精品一区二区三区蜜桃久 | 在线视频中文 | 网友自拍第一页 | 国产精品免费在线 | 精品一区二区三区国产 | 97自拍偷拍视频 | 精品一区久久 | 黄色毛片一级视频 | 91精品综合久久久久久 | 九九热在线观看 | 伊人久久综合 | 欧美在线视频a | 一区二区国产精品视频 | 国产91在线 | 亚洲 | 国产精品三级久久久久久电影 | 国产成人精品一区二区三区在线 | 国产精品国色综合久久 | 国产主播福利在线 | 国产精品178页 | 日韩黄色影视 | 久久九九久精品国产 | 五月av| 中文字幕资源在线 | 国产精品久久久久久久久搜平片 | 国产精品久久久久一区二区 | 欧美不卡一区二区 | 亚洲午夜视频在线观看 | 国产成人一区二区三区 | 欧美在线视频网 | 日韩视频一区二区在线 | av网站观看 | 欧美一级做a爰片久久高潮 亚洲一级一级 | 成人在线一区二区三区 | 欧美黄色aa| 在线观看中文字幕亚洲 | 嫩草影院在线观看视频 | 国产精品一区二区三区在线 | 久久婷婷成人综合色 | 最近中文字幕在线观看视频 | 国产在线一区二区三区 |