亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ab.bas

?? 采用vb與使用很廣泛的AB PLC產品通訊
?? BAS
字號:
Option Explicit
Dim tns%, comunicating

Private Sub CalcCRC (mes$)
Dim byt%, res&

  'Calculate CRC checksum for message then add
  'to end of message. Check for 10h byte 'DLE'
  'within message and change to 'DLE DLE'.
  
  byt% = 3
  Do
   res& = res& Xor Asc(Mid(mes$, byt%, 1))
   rotate res&
   'test for 'DLE' and double up to DLE DLE
   If Asc(Mid(mes$, byt%, 1)) = 16 Then
    'add extra DLE
    mes$ = Left$(mes$, byt%) + Chr(16) + Right$(mes$, Len(mes$) - byt%)
    byt% = byt% + 1 'don't include in CRC
   End If
   byt% = byt% + 1
  Loop While (byt% <= Len(mes$) - 2)
  res& = res& Xor 3 'ETX byte
  rotate res&

  'add CRC checksum to message
  mes$ = mes$ + Chr(res& Mod 256) + Chr(Int(res& / 256))

End Sub

Function ReadTable (start, n%())
Dim st, com$

  'read from PLC CIF data table, Micrologix=N7 SLC500=N9
  'the length of the block read is determined by the size
  'of the array passed.

  If comunicating Then Exit Function

  comunicating = True

  'clear buffer
  ab.Comm1.InputLen = 0
  com$ = ab.Comm1.Input
  
  'construct message
  com$ = Chr(16) + Chr(2) + Chr(0) + Chr(0)
  com$ = com$ + Chr(1) + Chr(0) + Chr(tns%) + Chr(0)
  com$ = com$ + Chr(start) + Chr(0) + Chr(UBound(n%) * 2)
  com$ = com$ + Chr(16) + Chr(3)
  
 'calc crc checksum and add to command
  CalcCRC com$
  
  'increment transaction number and check for rollover
  tns% = tns% + 1
  If tns% = 256 Then tns% = 0
  
  'send command
  ab.Comm1.Output = com$

  'wait for acknowledgment
  st = Timer
  Do
   DoEvents
  Loop While st + 3 > Timer And ab.Comm1.InBufferCount < 2

 'remove acknowledgment from buffer
  ab.Comm1.InputLen = 2
  com$ = ab.Comm1.Input
  
  'check for good acknowledgement
  If com$ <> Chr(16) + Chr(6) Then
   comunicating = False
   Exit Function
  End If

  'wait for response
  st = Timer
  Do
   DoEvents
  Loop While st + 3 > Timer And ab.Comm1.InBufferCount < 12 + (UBound(n%) * 2)

  'if timeout then exit
  If ab.Comm1.InBufferCount < 12 + (UBound(n%) * 2) Then
   comunicating = False
   Exit Function
  End If
  
  'send acknowledgment
  ab.Comm1.Output = Chr(16) + Chr(6)

  'get response
  ab.Comm1.InputLen = 0
  com$ = ab.Comm1.Input
  
  'remove surplus 'DLE's
  st = 3
  Do
   If Mid(com$, st, 1) = Chr(16) Then
    com$ = Left(com$, st) + Right(com$, Len(com$) - 1 - st)
   End If
  st = st + 1
  Loop While st < Len(com$) - 4

  'store results
  For st = 0 To UBound(n%) - 1
   n%(st) = 256 * Asc(Mid(com$, 2 * st + 10, 1)) + Asc(Mid(com$, 2 * st + 9, 1))
  Next st

  ReadTable = True

  comunicating = False

End Function

Private Sub rotate (res&)
Dim bitout%, shift%

  'Rotate result 8 times and combine with const.
  For shift% = 1 To 8
   bitout% = res& Mod 2 'test if bit will be shifted out
   res& = Int(res& / 2) 'shift right
   If bitout% Then
    res& = res& Xor &H1000A001 'xor with constant
    res& = res& - &H10000000 'clear top word
   End If
  Next shift%

End Sub

Function WriteTable (start, n%())
Dim st, com$

  'Write to PLC CIF data table, Micrologix=N7 SLC500=N9
  'the length of the block read is determined by the size
  'of the array passed.
  
  If comunicating Then Exit Function

  comunicating = True

  'clear buffer
  ab.Comm1.InputLen = 0
  com$ = ab.Comm1.Input
  
  'construct message
  com$ = Chr(16) + Chr(2) + Chr(0) + Chr(0)
  com$ = com$ + Chr(8) + Chr(0) + Chr(tns%) + Chr(0)
  com$ = com$ + Chr(start) + Chr(0)
  'add data
  For st = 0 To UBound(n%)
   com$ = com$ + Chr(n%(st) Mod 256) + Chr(Int(n%(st) / 256))
  Next st
  com$ = com$ + Chr(16) + Chr(3)
  
  'increment transaction number and check for rollover
  tns% = tns% + 1
  If tns% = 256 Then tns% = 0

  'calc crc checksum and add to command
  CalcCRC com$
  
  'send command
  ab.Comm1.Output = com$

  'wait for acknowledgment
  st = Timer
  Do
   DoEvents
  Loop While st + 3 > Timer And ab.Comm1.InBufferCount < 2

 'remove acknowledgment from buffer
  ab.Comm1.InputLen = 2
  com$ = ab.Comm1.Input
  
  'check for good acknowledgement
  If com$ <> Chr(16) + Chr(6) Then
   comunicating = False
   Exit Function
  End If

  'wait for response
  st = Timer
  Do
   DoEvents
  Loop While st + 3 > Timer And ab.Comm1.InBufferCount < 12

  'send acknowledgment
  ab.Comm1.Output = Chr(16) + Chr(6)
 
  'if timeout then exit
  If ab.Comm1.InBufferCount < 12 Then
   comunicating = False
   Exit Function
  End If
  
  'send acknowledgment
  ab.Comm1.Output = Chr(16) + Chr(6)

  WriteTable = True
  
  comunicating = False

End Function

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩精品一区二区天天拍小说| 亚洲一区二区三区国产| 国产偷国产偷精品高清尤物| 亚洲国产经典视频| 亚洲二区在线视频| 韩国成人福利片在线播放| 国产.欧美.日韩| 91电影在线观看| 精品国产91久久久久久久妲己 | 亚洲免费观看高清完整版在线观看 | 亚洲国产欧美在线| 国产专区欧美精品| 欧美性大战久久| 久久久久国产精品人| 亚洲一区二区三区四区的| 久久99久久精品| 99久久99久久免费精品蜜臀| 欧美久久免费观看| 国产午夜亚洲精品羞羞网站| 亚洲妇熟xx妇色黄| 成人免费av网站| 91精品在线一区二区| 中文字幕一区二区三区色视频| 亚洲成人7777| 成人理论电影网| 欧美一级欧美一级在线播放| 成人免费一区二区三区视频| 久久av资源站| 欧美亚洲免费在线一区| 国产欧美日韩中文久久| 天堂成人国产精品一区| 波多野结衣中文字幕一区| 日韩午夜中文字幕| 亚洲综合视频在线| 成人免费高清在线观看| 欧美成人艳星乳罩| 亚洲国产精品视频| 99麻豆久久久国产精品免费| 欧美成人a在线| 亚洲成人精品一区| 91免费版在线看| 欧美激情一区二区在线| 久久99热国产| 5566中文字幕一区二区电影| 亚洲乱码国产乱码精品精的特点 | 国产精品久久三| 久久国产精品99久久人人澡| 欧美日韩精品欧美日韩精品一 | 成人a级免费电影| 欧美白人最猛性xxxxx69交| 午夜亚洲国产au精品一区二区| 99久久精品免费| 亚洲国产精品成人综合色在线婷婷 | 在线亚洲人成电影网站色www| 国产亚洲欧美在线| 韩国三级在线一区| 欧美一区二区三区成人| 午夜av一区二区| 精品视频在线视频| 亚洲影视资源网| 色综合一个色综合亚洲| 中文字幕一区在线| 成人免费黄色在线| 国产精品国产三级国产aⅴ入口| 国产乱色国产精品免费视频| 日韩欧美国产一区二区三区| 日韩精彩视频在线观看| 欧美精选在线播放| 日日摸夜夜添夜夜添国产精品| 欧美色电影在线| 亚洲电影你懂得| 欧美日韩高清一区二区三区| 亚洲国产日韩a在线播放性色| 欧美性猛交xxxx乱大交退制版 | 91精品婷婷国产综合久久| 亚洲成人免费在线| 欧美丰满一区二区免费视频| 午夜在线电影亚洲一区| 欧美精三区欧美精三区| 久久国产成人午夜av影院| 欧美xingq一区二区| 国产精品白丝av| 国产精品午夜春色av| 成人黄色片在线观看| 亚洲色图一区二区| 在线国产电影不卡| 天天色综合成人网| 日韩欧美成人一区二区| 国产福利一区二区三区视频在线 | 91免费版在线| 亚洲一区二区精品3399| 91麻豆精品国产91久久久| 裸体在线国模精品偷拍| 国产日韩欧美精品综合| jlzzjlzz亚洲日本少妇| 亚洲福利视频导航| 欧美videos大乳护士334| 成人性生交大片免费看在线播放| 国产精品久久久久久一区二区三区| 99精品欧美一区二区三区小说| 一区二区三区精品久久久| 欧美精品在欧美一区二区少妇| 久久精品国产99久久6| 国产亚洲成av人在线观看导航| 成人动漫一区二区| 亚洲午夜国产一区99re久久| 日韩无一区二区| 国产91精品一区二区麻豆亚洲| 亚洲色图欧美在线| 正在播放一区二区| 国产精品中文字幕日韩精品| 亚洲人精品一区| 91精品黄色片免费大全| 国产99久久久精品| 亚洲一二三四区不卡| 欧美精品一区视频| 一本色道久久综合亚洲91| 日韩av网站在线观看| 国产欧美一区二区在线| 欧美色手机在线观看| 国产高清精品网站| 亚洲小说欧美激情另类| 久久人人爽爽爽人久久久| 色综合久久66| 精品一区二区三区在线观看| 亚洲欧美电影一区二区| 欧美电影免费提供在线观看| 99久久99久久精品免费看蜜桃| 奇米影视在线99精品| 国产精品国产三级国产aⅴ入口| 日韩一区二区三区电影| 91女人视频在线观看| 精品一区二区三区在线观看| 亚洲一区在线视频观看| 久久精品亚洲一区二区三区浴池 | 日韩国产欧美三级| 国产精品久久久久久妇女6080| 在线91免费看| av一区二区久久| 国产精品一区久久久久| 日韩高清一级片| 日韩理论电影院| 久久久久久久久久久黄色| 欧美日韩国产高清一区二区| 成人动漫精品一区二区| 国产一区二区三区综合| 天天操天天色综合| 中文字幕欧美一| 久久久综合视频| 欧美xxxxx裸体时装秀| 欧美精品色综合| 日本福利一区二区| 成人动漫一区二区| 国产成人av影院| 国产自产高清不卡| 麻豆精品视频在线观看免费| 偷窥少妇高潮呻吟av久久免费| 1024成人网色www| 国产亚洲一二三区| 久久综合狠狠综合| 日韩欧美不卡在线观看视频| 欧美日韩成人综合在线一区二区 | 日韩精品电影一区亚洲| 亚洲影院免费观看| 一区二区三区在线免费播放| 中文字幕一区二| 国产精品久久久久一区| 国产精品女主播av| 国产日本欧洲亚洲| 久久夜色精品国产欧美乱极品| 日韩一区二区三区视频在线观看| 日本丰满少妇一区二区三区| 色综合网色综合| 97久久超碰国产精品| 99久久久国产精品免费蜜臀| www.成人在线| 99久久国产综合精品色伊| 97精品国产露脸对白| www.日本不卡| 菠萝蜜视频在线观看一区| 99精品视频免费在线观看| 99视频在线精品| 91麻豆国产自产在线观看| 色综合久久中文综合久久97| 91丨porny丨蝌蚪视频| 91视频免费看| 日本国产一区二区| 欧美亚洲免费在线一区| 欧美精品1区2区| 日韩亚洲欧美一区| 精品国产乱码久久久久久久久 | 成人福利视频在线| voyeur盗摄精品| 欧美亚洲禁片免费| 欧美美女视频在线观看| 日韩一区二区精品| 久久午夜国产精品| 国产精品午夜电影| 一区二区三区色| 日韩电影免费一区|