无码精品人妻一区二区三区入口-无码精品人妻一区二区三区夜夜嗨-无码精品人妻一区二区三区颖A片-无码精品日本一区二区桃花岛-无码精品网站-无码精品一

趙云龍
級別: 正式會員
精華主題: 0
發帖數量: 6 個
工控威望: 53 點
下載積分: 256 分
在線時間: 8(小時)
注冊時間: 2023-11-23
最后登錄: 2024-12-03
查看趙云龍的 主題 / 回貼
樓主  發表于: 2024-09-17 16:49
Option Explicit

Private Sub Form_Load()

  '設置本地任意可用端口,這樣系統會自動分配一個未被占用的端口

  Winsock1.LocalPort = 0

  Winsock2.LocalPort = 0

  '設置通信協議為 TCP 協議

  Winsock1.Protocol = sckTCPProtocol

  Winsock2.Protocol = sckTCPProtocol

  '開始監聽,等待客戶端連接

  Winsock1.Listen

  Winsock2.Listen

  '初始化PLC地址,IP,端口數據

  Open App.Path & "\data\add.ini" For Binary As #1

  Add = StrConv(InputB$(LOF(1), 1), vbUnicode)

  Close #1

  Open App.Path & "\data\ip.ini" For Binary As #1

  ip = StrConv(InputB$(LOF(1), 1), vbUnicode)

  Close #1

  Open App.Path & "\data\port.ini" For Binary As #1

  port = StrConv(InputB$(LOF(1), 1), vbUnicode)

  Close #1

  reg.Text = "0"

  high.Text = "0"

  low.Text = "0"

End Sub



Private Sub SendData_Click()

  '如果 Winsock 處于已連接狀態

  If Winsock1.State = sckConnected Then

    '構造 Modbus TCP 請求數據

    Dim PLC_Add As Long

    Dim dataToSend As Integer

    Dim dataToSend1 As Integer

    Dim dataToSend2 As Integer

    'Add PLC起始地址,reg:寄存器地址,high/low高低字節位(數據)。

    PLC_Add = Val(Add.Text)

    To_reg = Val(reg.Text)

    To_high = Val(high.Text)

    To_low = Val(low.Text)

    'MODBUSTCP報文

     Dim request As String

    request = Chr(&H0) & Chr(&H1) & Chr(&H0) & Chr(&H0) & Chr(&H0) & Chr(&H6) & Chr(&H1) & Chr(&H6) & Chr(PLC_Add - 40001) & Chr(To_reg) & Chr(To_high) & Chr(To_low)

      '發送構造好的請求數據給 PLC

      Winsock1.SendData request

    Exit Sub

  

  Else

    '如果未連接到 PLC,彈出消息提示

    MsgBox "Not connected to PLC."

  End If

  

End Sub


Private Sub Timer1_Timer()

  '定時器事件,用于周期性檢查連接狀態并更新界面

  If Winsock1.State = sckConnected Then

    '如果連接成功,將標簽的背景色設置為綠色(十六進制顏色值 &HC000&)

    connection.BackColor = &HC000&

  Else

    '如果未連接,將標簽的背景色設置為紅色(十六進制顏色值 &HFF&)

    connection.BackColor = &HFF&

  End If

    

End Sub



Private Sub Timer2_Timer()

  '定時器事件,用于周期性檢查連接狀態并重新連接

  If connection.BackColor = &HFF& Then

  '檢查 Winsock 的狀態,如果不是已關閉狀態

  If Winsock1.State <> sckClosed Then

    '關閉當前連接,以便重新連接到 PLC

    Winsock1.Close

    '確認連接IP地址及端口

    Timer3.Interval = 1

  End If

  If Winsock2.State <> sckClosed Then

    '關閉當前連接,以便重新連接到 PLC

    Winsock2.Close

    '確認連接IP地址及端口

    Timer3.Interval = 1

  End If

  

    '變量

    Dim plc_ip As String

    Dim plc_port As Integer

    '讀取IP及端口參數

    plc_ip = ip.Text

    plc_port = port.Text

    '連接到指定的 PLC IP 地址和端口號,這里需替換為實際的 PLC IP 和端口

    Winsock1.Connect plc_ip, plc_port

    Winsock2.Connect plc_ip, plc_port

    '停止IP地址及端口確認

    Timer3.Interval = 0

  End If

End Sub



Private Sub Command1_Click()

    '打開通訊設置窗口

    Form2.Show

End Sub



Private Sub ConnectToPLC_Click()

  '判斷通訊是否啟動連接

  If Timer2.Interval = 0 Then

     '開始連接

    Timer2.Interval = 1

  ElseIf Timer2.Interval = 1 Then

    '判斷通訊是否啟動連接

    If Winsock1.State <> sckClosed Then

    '停止連接

    Timer2.Interval = 0

    '斷開連接

    Winsock1.Close

    Winsock2.Close

    

    End If

    

  End If



End Sub



Private Sub Timer3_Timer()

    '讀取起始地址

    Open App.Path & "\data\add.ini" For Binary As #1

    '更新起始地址

    Add = StrConv(InputB$(LOF(1), 1), vbUnicode)

    Close #1

    '讀取IP地址

    Open App.Path & "\data\ip.ini" For Binary As #1

    '更新IP地址

    ip = StrConv(InputB$(LOF(1), 1), vbUnicode)

    Close #1

    '讀取端口

    Open App.Path & "\data\port.ini" For Binary As #1

    '更新端口

    port = StrConv(InputB$(LOF(1), 1), vbUnicode)

    Close #1

    '停止更新

    Timer3.Interval = 0

End Sub





Private Sub TCP0_Click(Index As Integer)

  '對齊寄存器地址

  If reg.Text <> 0 Then

    reg.Text = 0

  End If

  '開關量轉換

  If reg.Text = 0 Then

    If low.Text = 0 Then

      low.Text = 1

      SendData_Click

    ElseIf low.Text = 1 Then

      low.Text = 0

      SendData_Click

    End If

  End If



End Sub



Private Sub TCP1_Click(Index As Integer)

  '對齊寄存器地址

  If reg.Text <> 1 Then

    reg.Text = 1

  End If

  '開關量轉換

  If reg.Text = 1 Then

    If low.Text = 0 Then

      low.Text = 1

      SendData_Click

    ElseIf low.Text = 1 Then

      low.Text = 0

      SendData_Click

    End If

  End If



End Sub



Private Sub TCP2_Click(Index As Integer)

  '對齊寄存器地址

  If reg.Text <> 2 Then

    reg.Text = 2

  End If

  '開關量轉換

  If reg.Text = 2 Then

    If low.Text = 0 Then

      low.Text = 1

      SendData_Click

    ElseIf low.Text = 1 Then

      low.Text = 0

      SendData_Click

    End If

  End If



End Sub



Private Sub TCP3_Click(Index As Integer)

  '對齊寄存器地址

  If reg.Text <> 3 Then

    reg.Text = 3

  End If

  '開關量轉換

  If reg.Text = 3 Then

    If low.Text = 0 Then

      low.Text = 1

      SendData_Click

    ElseIf low.Text = 1 Then

      low.Text = 0

      SendData_Click

    End If

  End If



End Sub



Private Sub TCP4_Click(Index As Integer)

  '對齊寄存器地址

  If reg.Text <> 4 Then

    reg.Text = 4

  End If

  '開關量轉換

  If reg.Text = 4 Then

    If low.Text = 0 Then

      low.Text = 1

      SendData_Click

    ElseIf low.Text = 1 Then

      low.Text = 0

      SendData_Click

    End If

  End If



End Sub



Private Sub TCP5_Click(Index As Integer)

  '對齊寄存器地址

  If reg.Text <> 5 Then

    reg.Text = 5

  End If

  '開關量轉換

  If reg.Text = 5 Then

    If low.Text = 0 Then

      low.Text = 1

      SendData_Click

    ElseIf low.Text = 1 Then

      low.Text = 0

      SendData_Click

    End If

  End If


End Sub



Private Sub end_Click()

End

End Sub


powtiger
狂人日妓
級別: 略有小成
精華主題: 0
發帖數量: 314 個
工控威望: 450 點
下載積分: 3358 分
在線時間: 124(小時)
注冊時間: 2014-03-04
最后登錄: 2025-03-12
查看powtiger的 主題 / 回貼
1樓  發表于: 2024-09-18 08:28
VB工程發一個上來學習啊
科技創造未來,人才決定明天!
tandekun
級別: 探索解密
精華主題: 0
發帖數量: 126 個
工控威望: 149 點
下載積分: 6421 分
在線時間: 39(小時)
注冊時間: 2021-12-17
最后登錄: 2025-03-14
查看tandekun的 主題 / 回貼
2樓  發表于: 2024-09-18 13:03
背景圖有點影響觀感
mhbxfys
趁年輕,走遍中國!
級別: 網絡英雄
精華主題: 0
發帖數量: 672 個
工控威望: 7028 點
下載積分: 7339 分
在線時間: 232(小時)
注冊時間: 2012-01-04
最后登錄: 2025-02-19
查看mhbxfys的 主題 / 回貼
3樓  發表于: 2024-09-19 11:16
大神啊
感謝每位朋友! 承接plc柜、電氣柜設計、定制。觸摸屏組態、調試。 藍海華騰變頻器代理,變頻器維修!!!   QQ:545636511

主站蜘蛛池模板: 日韩高清影片免费播放 | 国产一区二区三区免费大片天美 | 国产成人老熟女久久久久 | 亚洲国产欧美精品区一区二区三区 | a级片免费在线播放 | 一本大道久久a久久精品综合 | 91久久国产香蕉熟女线看 | 狠狠色丁香久久婷婷综合_中 | videos日本熟妇人妻多毛 | 国产精品无码免费专区午夜党 | 99国产精品久久人妻 | 丁香五月天激情婷婷五月天 | 蜜臀AV国产精品久久久久 | 97色伦色在线综合视频 | 无码人妻一区二区三区蜜桃手机版 | 国产va无码高清 | 狠狠色噜噜狠狠狠狠2021天天 | 2024国产欧洲精品网站 | 亚洲欧美日韩精品久久 | 欧美在线三级艳情网站 | CHINESE性内射高清国产 | 天堂网在线最新版在线 | 亚洲欧美中文日韩二区一区 | 久久综合一 | 青青久在线视频免费观看手机 | 国产国产成人久久精品性色 | 99精品无人 | 亚洲AV无码一区二区高潮 | 国产日韩麻豆电影一区二区 | 国产人妻久久精品二区三区老狼 | 日本国产一卡二卡三新区 | 青草青华人在线观看视频 | 一本色道久久88亚洲精品综合 | 熟女倶楽部1011熟女倶楽部 | 久久久青青久久国产精品 | 国产精品三级在线观看无码 | 国偷自产一区二区免费视频 | 久久麻豆精亚洲av品国产 | 欧美洲精品亚洲精品中文字 | 色情五月亚洲中文字幕 | 欧美综合久久 |