基于VB的PLC與計(jì)算機(jī)間串行通信實(shí)現(xiàn)
?。猧nput:將對方傳送至輸入緩沖區(qū)的字符讀入到程序。
*output:將字符寫入輸出緩沖區(qū)。
*inbuffercount:傳回接收緩沖區(qū)中的字符數(shù)。
?。猳utbuffercount:傳回輸出緩沖區(qū)中的字符數(shù)。
?。猧nputlen:設(shè)定串行端口讀入字符串的長度。
?。猧nputmode:設(shè)定接收數(shù)據(jù)的方式。
?。猺threshold:設(shè)定引發(fā)接收事件的字符數(shù)。
?。猚ommevent:傳回ONcomm事件發(fā)生時(shí)的數(shù)值碼
?。猳ncomm事件:無論是錯(cuò)誤或事件發(fā)生,都會(huì)觸發(fā)此事件。
?。?) 控件參數(shù)的初始化
初始化程序如下:
mscomm.comport=2 `使用串口com2
mscomm.settings=9600, e, 7, 2 `波特率9600,偶校驗(yàn),7位數(shù)據(jù)位,2位停止位
mscomm.portopen=true `打開通信端口,準(zhǔn)備通信
?。?) 計(jì)算校驗(yàn)碼fcs,計(jì)算fcs的vb自定義函數(shù)如下:
function fcs(byval inputSTr as string) as string
dim slen, i, xorresult as integer
dim tempfes as string
slen=len(inputstr) `求輸入字符串長度
xorresult = 0
for i = 1 to slen
xorresult = xorresult xor asc(mid$(inputstr, i, 1)) `按位異或
next i
tempfes=hex$(xorresult) `轉(zhuǎn)化為16進(jìn)制
if len(tempfes)=1then tempfes =“0”+tempfes
fcs = tempfes
end function
?。?) 計(jì)算機(jī)與PLC通信程序
主要是一個(gè)自定義函數(shù)。
function readdata(byval inputstr as string, byval num as integer) as string
dim outputstr as string
dim instring as string
dim returnstr as string
dim endstring as string
dim fcsstring as string
dim returnfcsstring as string)
mscomm.inbuffercount=0
utputstr=inputstr+fcs(inputstr)+“*” `給出命令幀
mscomm.output=outputstr+chr$(13) `向PLC傳送命令幀
do
doevents
loop while mscomm.inbuffercount 15
instring=mscomm.input `獲取PLC的響應(yīng)幀
`結(jié)束碼判斷
endstring = mid$(instring, len(instring) -
num- 5, 2)
評論