時間:2007-03-05 16:50:00來源:jiangf
在這里,作者使用的是臺灣泓格科技有限公司的232/485轉換模塊 I-7520。由主控計算機送出的命令是通過 RS-232 串行通信端口發送出去,此信號經過 232/485 轉換模塊(模塊編號I-7520)將信號標準電位及類型轉換后,在 485 網絡上傳播開來。多功能電力儀表收到屬于自身的命令后,會進行分析控制的操作,最后將結果送至485網絡,讓此信號再通過I-7520的轉換后,可由計算機的 RS-232串行通信端口接收進來。整個送收過程全是以串行處理。
三、軟件的設計和開發
注:從 CD194E 系列的多功能電力儀表傳過來的電功率數據就存放在 Byte1到 Byte4 內。
3.通信步驟:
⑴加入通信控件。也就是 MSComm控件
⑵設置通信端口號碼。即 CommPort屬性,在本文使用 Com1。
⑶設置通訊參數。即Settings 屬性。在本文設置為 9600,n,8,1。即通訊速度為 9600,數據格式為1 個起始位,8個數據位,1個停止位,無校驗位。注意必須與多功能電力儀表的設置一致,不然就會通信失敗。
⑷設置其它參數。必要時再加上其它的屬性設置。
⑸打開通信端口。即PortOpen 屬性設成 True。
⑹每隔500毫秒送出字符串或讀入字符串。即發送命令 4(讀N 個字節)來讀取電功率參數,使用Input 及 Output屬性。
⑺使用完 MSComm控件后,將通信端口關閉。
4.人機界面:
5.程序代碼:
’API 函數聲名
Private Declare Function GetTickCount Lib "kernel32" () As Long
’點擊結束程序按鈕
Private Sub CmdEnd_Click()
End
End Sub
’點擊讀取電功率按鈕
Private Sub CmdRead_Click()
Timer1.Enabled = Not Timer1.Enabled
If Timer1.Enabled Then
CmdRead.Caption = "停止讀數"
Else
CmdRead.Caption = "讀取電功率"
End If
End Sub
’程序初始化
Private Sub Form_Load()
MSComm1.InputMode = comInputModeBinary
MSComm1.PortOpen = True
Timer1.Enabled = False
End Sub
Private Sub Timer1_Timer()
Dim C4%, C5%, C6%, C7%
Dim Tick&
Dim Data As Double
Dim Buf() As Byte
Dim ByteOut(7) As Byte
MSComm1.InputLen = 0
Buf = MSComm1.Input
’重新定義數據輸入緩沖區, 發送命令 4
MSComm1.InputLen = 1
ByteOut(0) = &H1
ByteOut(1) = &H4
ByteOut(2) = &H0
ByteOut(3) = &H5C
ByteOut(4) = &H0
ByteOut(5) = &H4
ByteOut(6) = &H31
ByteOut(7) = &HDB
MSComm1.Output = ByteOut(0) & ByteOut(1) & ByteOut(2) & ByteOut(3) & ByteOut(4) & ByteOut(5) &
ByteOut(6) & ByteOut(7)
’等待多功能電力儀表響應的數據到達串口
Tick = GetTickCount()
Do
If (GetTickCount() - Tick) / 1000# > 10 Then
MsgBox "時間過久,請檢查多功能電力儀表及傳輸狀態!", vbCritical + vbOKOnly, "系統信息"
Exit Sub
End If
DoEvents
Loop Until MSComm1.InBufferCount >= 9
’從輸入緩沖區讀數據
Buf = MSComm1.Input
If Buf(0) <> 1 Then
MsgBox "地址錯誤!", vbCritical + vbOKOnly, "系統信息"
Exit Sub
End If
Buf = MSComm1.Input
If Buf(0) <> 4 Then
MsgBox "長度錯誤!", vbCritical + vbOKOnly, "系統信息"
Exit Sub
End If
Buf = MSComm1.Input
C4 = Buf(0)
Buf = MSComm1.Input
C5 = Buf(0)
Buf = MSComm1.Input
C6 = Buf(0)
Buf = MSComm1.Input
C7 = Buf(0)
Buf = MSComm1.Input
Buf = MSComm1.Input
Data = Power(C4, C5, C6, C7)
TxtPower.Text = CStr(Data)
End Sub
’自定義功率換算函數
Private Function Power(C4%, C5%, C6%, C7%)
Dim PowerExp As String, Mantissa As String
Dim ReadValue#
Dim ValueSign&
If ((C4 And &H80) / 2 ︿ 7) = True Then
ValueSign = -1
Else
ValueSign = 1
End If
PowerExp = CStr((C4 And &H7F) * 2 + (C5 And &H80) / 2 ︿ 7)
Mantissa = CStr((&H80 Or C5) * 2 ︿ 16 + C6 * 2 ︿ 8 + C7)
ReadValue = ValueSign * 2 ︿ (Val(PowerExp) - 126) * Val(Mantissa) / (256 * 65536)
Power = ReadValue
End Function
四、結論
本實例是作者在實驗室做過多次實驗,達到了預定的應用效果,目前在江西某廠取得了實際的應用。
該控制系統的最大優點是:
1,從硬件上看,僅僅使用一個轉換模塊就可以實現全廠電能遠程監控和集中管理的功能。大大提高了效率,且十分經濟實惠。
2,從軟件上看,直接使用串口的控制技術,而不必需要寫額外的驅動程序。采用VB開發應用軟件十分方便,編程工作量小。
【參考文獻】
1.李肇慶、韓濤。串行端口技術,國防工業出版社,2004
2.范逸之。Visual Basic 與 RS-232 串行通信控制,清華大學出版社,2002
3.范逸之。Visual Basic 與分布監控系統——RS232/485 串行通信,清華大學出版社,2002
4.江陰長江斯菲爾電力儀表有限公司使用手冊
5. 臺灣泓格科技有限公司的 232/485 轉換模塊說明書.標簽:
傳動網版權與免責聲明:凡本網注明[來源:傳動網]的所有文字、圖片、音視和視頻文件,版權均為傳動網(www.cdcst56.com)獨家所有。如需轉載請與0755-82949061聯系。任何媒體、網站或個人轉載使用時須注明來源“傳動網”,違反者本網將追究其法律責任。
本網轉載并注明其他來源的稿件,均來自互聯網或業內投稿人士,版權屬于原版權人。轉載請保留稿件來源及作者,禁止擅自篡改,違者自負版權法律責任。
產品新聞
更多>2025-09-08
華為昇騰Atlas800iA2 910B服務器Deepsee...
2025-09-04
2025-08-06
2025-07-08
2025-06-30
2025-06-16