1 前言
目前國內(nèi)閘門監(jiān)控系統(tǒng)設(shè)計(jì)的方案基本上是PLC+上位機(jī)模式,而上位監(jiān)控軟件大多是購買現(xiàn)成的集成系統(tǒng)和商業(yè)組態(tài)軟件來實(shí)現(xiàn)的。但在缺少資金的情況下要進(jìn)行小型項(xiàng)目自動(dòng)化建設(shè)或改造,就不得不考慮成本問題,因?yàn)榻M態(tài)軟件是按點(diǎn)數(shù)賣錢的,定義一個(gè)變量就算一個(gè)點(diǎn),價(jià)格昂貴。而采用高級(jí)語言結(jié)合OPC技術(shù)開發(fā)監(jiān)控軟件不僅可以節(jié)省大量的成本而且可以擺脫對(duì)設(shè)備驅(qū)動(dòng)程序的依賴,尤其是在對(duì)老項(xiàng)目進(jìn)行自動(dòng)化改造時(shí),這種優(yōu)勢(shì)更加明顯。
機(jī)遇以上考慮,筆者在參與安徽淮河流域某小型閘門自動(dòng)化改造工程時(shí),采用了Visual Basic 6.0開發(fā)環(huán)境,應(yīng)用OPC自動(dòng)化接口技術(shù)開發(fā)了OPC客戶端程序(閘門監(jiān)控系統(tǒng)的監(jiān)控軟件)。服務(wù)器采用凱譜華的 KEPServerEx.V4。她嵌入了工業(yè)市場(chǎng)上廣泛范圍(超過80多種支持100種以上設(shè)備型號(hào)的可下載驅(qū)動(dòng)程序)的驅(qū)動(dòng)程序和組件 ,更重要的是,這個(gè)服務(wù)器是完全免費(fèi)的。
2 OPC知識(shí)簡(jiǎn)介
2.1 OPC基本概念
OPC是OLE for Process Control的縮寫,即把OLE應(yīng)用于工業(yè)控制領(lǐng)域。OPC建立在OLE規(guī)范之上,它為工業(yè)控制領(lǐng)域提供了一種標(biāo)準(zhǔn)的數(shù)據(jù)訪問機(jī)制。
OPC技術(shù)采用COM/DCOM技術(shù)的客戶/服務(wù)器(Client/Server)模型,使OPC的通用性得到擴(kuò)展。相應(yīng)的OPC應(yīng)用程序的開發(fā)就有了OPC客戶端程序部分和OPC服務(wù)器程序部分的開發(fā)。一般來說,OPC服務(wù)器程序由硬件的生產(chǎn)廠商開發(fā);而OPC客戶端程序由用戶開發(fā)。
2.2 OPC結(jié)構(gòu)原理
2.2.1 OPC基本體系結(jié)構(gòu)
OPC規(guī)范提供了兩套接口方案,即COM接口和自動(dòng)化。COM接口效率高,通過該接口,客戶能夠發(fā)揮OPC服務(wù)器的最佳性能,采用C++語言的客戶一般用COM接口方案;自動(dòng)化接口使用解釋性和宏語言訪問OPC服務(wù)器,采用Visaul Basic語言的客戶一般采用自動(dòng)化接口。典型的OPC體系如下圖所視:
圖1 典型OPC體系機(jī)構(gòu)圖
Figure1 OPC architecture
2.2.2 OPC自動(dòng)化服務(wù)器對(duì)象模型
OPC自動(dòng)化服務(wù)器對(duì)象的組織是層次結(jié)構(gòu),其對(duì)象模型如圖5-1所示:
圖2 OPC 自動(dòng)化服務(wù)器對(duì)象模型
Figure2 Automation Object Hierarchy
服務(wù)器對(duì)象(Server)擁有服務(wù)器的所有信息,同時(shí)也是組對(duì)象(Group)的容器。OPC組對(duì)象(Group)提供了OPC客戶程序用來組織數(shù)據(jù)的一種方法。在每個(gè)組對(duì)象中,客戶可以加入多個(gè)OPC數(shù)據(jù)項(xiàng)(Item)。OPC數(shù)據(jù)項(xiàng)(Item)是服務(wù)器端定義的對(duì)象,通常指向設(shè)備的一個(gè)寄存器單元。OPC客戶對(duì)設(shè)備寄存器的操作都是通過其數(shù)據(jù)項(xiàng)來完成的,通過OPC數(shù)據(jù)項(xiàng)(Item),OPC規(guī)范盡可能地隱藏了設(shè)備的特殊信息,也使OPC服務(wù)器的通用性大大增強(qiáng)。OPC數(shù)據(jù)項(xiàng)(Item)并不提供對(duì)外接口,客戶不能直接對(duì)之進(jìn)行操作,所有的操作都是通過組對(duì)象進(jìn)行的。每個(gè)OPC數(shù)據(jù)項(xiàng)(Item)的數(shù)據(jù)結(jié)構(gòu)包括三個(gè)成員變量:即數(shù)據(jù)值、數(shù)據(jù)質(zhì)量和時(shí)間戳。數(shù)據(jù)值是以Variant形式表示的。一個(gè)OPC服務(wù)器中只能有一個(gè)OPC瀏覽器對(duì)象,而且它是可選的。OPC瀏覽器對(duì)象是為了讓客戶程序可以瀏覽到OPC服務(wù)器的配置而設(shè)計(jì)的,它把OPC服務(wù)器上可用的東西顯示給用戶。
2.2.3 OPC技術(shù)優(yōu)勢(shì)
一個(gè)完整的基于OPC技術(shù)的監(jiān)控系統(tǒng)由OPC客戶端程序和OPC服務(wù)器程序組成,實(shí)際上實(shí)現(xiàn)了用戶和設(shè)備供應(yīng)商開發(fā)監(jiān)控系統(tǒng)的分工。利用OPC技術(shù)實(shí)際上就等于客戶端程序不用直接從硬件上讀取數(shù)據(jù),而是直接從OPC服務(wù)器上讀取數(shù)據(jù),設(shè)計(jì)OPC服務(wù)器程序的廠商已經(jīng)完成了OPC服務(wù)器程序與硬件設(shè)備的數(shù)據(jù)存取。而且任意的OPC服務(wù)器的接口是標(biāo)準(zhǔn)統(tǒng)一的,這使得客戶程序能用一種標(biāo)準(zhǔn)的方法去訪問任意廠商的OPC服務(wù)器程序。每個(gè)用戶就不必各自開發(fā)和硬件的通信程序,就可以直接讀取OPC服務(wù)器的數(shù)據(jù),提高了代碼的重用性。也就是說OPC客戶端程序一旦開發(fā)成功了,就可以應(yīng)用到任意一個(gè)帶有OPC服務(wù)器的監(jiān)控系統(tǒng)中。OPC技術(shù)將監(jiān)控系統(tǒng)的復(fù)雜性大大地簡(jiǎn)化后,軟件開發(fā)的周期也大大縮短了,用戶就可以不需要購買比較昂貴的商業(yè)組態(tài)軟件而獨(dú)立開發(fā)OPC客戶端程序。
3 客戶端監(jiān)控程序開發(fā)
3.1引用OPC自動(dòng)化接口
建立新工程或項(xiàng)目,在“工程”菜單下選擇“引用”,如圖5-3所示。只有引用OPCDAAuoto.DLL后,在程序中才能創(chuàng)建服務(wù)器對(duì)象,然后進(jìn)行一系列的操作。
圖3 打開引用對(duì)話框
Figure3 Open Reference Dialog
(2)在彈出的引用窗口里單擊“瀏覽(B)…”按鈕,彈出添加引用窗口,選擇OPCDAAuoto.DLL文件。
(3)在引用窗口里的OPC Automation 2.0前面打鉤,按“確定”按鈕。如圖5-4所示:
圖4 選擇引用項(xiàng)目
Figure4 Select Reference Item
3.2程序開發(fā)
3.2.1定義全局變量
變量類型應(yīng)該指定為對(duì)象型。這些對(duì)象最好在窗體的通用部分聲明加上“Option Explicit”語句,表示模塊里的所有變量都需要顯式聲明。由于OPC自動(dòng)化接口的數(shù)組的索引要求必須從1開始,而系統(tǒng)默認(rèn)是從0開始,為了避免錯(cuò)誤最好在代碼的最初加上“Option Base 1”語句。為了使對(duì)象可以處理事件,必須將myTestGrp和myServer的聲明中加上“WithEvents”語句,表示聲明的對(duì)象可以響應(yīng)事件。
Option Explicit
Option Base 1
Dim WithEvents myServer As OPCServer
Dim myGroups As OPCGroups
Dim WithEvents myTestGrp As OPCGroup
Dim myItems As OPCItems
3.2.2連接OPC服務(wù)器和建立OPC組主要程序
連接子程序:
Sub Connect(strProgID As String, Optional strNode As String)
If myServer Is Nothing Then
' 建立一個(gè)OPC服務(wù)器對(duì)象
Set myServer = New OPCServer
End If
If myServer.ServerState = OPCDisconnected Then
' 連接OPC服務(wù)器
myServer.Connect strProgID, strNode
End If
在Visual Basic中,通過執(zhí)行一個(gè)Set操作實(shí)現(xiàn)調(diào)用其它接口的方法。
If myGroups Is Nothing Then
' 建立一個(gè)OPC組集合
Set myGroups = myServer.OPCGroups
End If
If myTestGrp Is Nothing Then
' 添加一個(gè)OPC組
Set myTestGrp = myGroups.Add("Group")
End If
End Sub
ServerState屬性一共有OPCRunning、OPCFailed、OPCNoconfig、OPCSuspended、OPCTest和OPCDisconnected六個(gè),分別表示正在運(yùn)行、失敗、沒有配置、暫停、測(cè)試和沒有連接六種OPC服務(wù)器當(dāng)前的狀態(tài)。如果OPC服務(wù)器沒有連接,我們才執(zhí)行myServer.Connect strProgID, strNode語句。strProgID就是ProgID,strNode就是用于遠(yuǎn)程通信的IP地址。
在窗口登陸時(shí)調(diào)用連接子程序,便可以連接到你需要的服務(wù)器。
Call Connect("KEPware.KEPServerEx.V4")
3.2.3添加OPC標(biāo)簽
對(duì)服務(wù)器進(jìn)行訪問前,必須先在OPC組里添加要訪問的OPC標(biāo)簽。為了編程方便,在服務(wù)器端,將每個(gè)閘門的升、降、停止、開度、水位、流量 等監(jiān)控量組態(tài)為TAGI(I=1,2…15)
Sub AddItem()
Dim strItemIDs(15) As String
Dim lClientHandles(15) As Long
Dim lErrors() As Long
Dim I As Integer
myTestGrp.IsSubscribed = True ' 啟動(dòng)組異步通知。
Set myItems = myTestGrp.OPCItems ' 建立OPC項(xiàng)集合
For I = 1 To 15 ' 生成從TAG1到TAG15的項(xiàng)標(biāo)識(shí)符
strItemIDs(I) = "Server.Group.TAG" & I
lClientHandles(I) = I
Next
Call myItems.AddItems(15, strItemIDs, lClientHandles, lServerHandles, lErrors)
End Sub ' 添加OPC項(xiàng)
3.2.4異步讀取代碼的實(shí)現(xiàn)
在定時(shí)器事件內(nèi)進(jìn)行執(zhí)行AsyncRead子程序的讀取代碼
Sub AsyncRead()
Dim lErrors() As Long
If myTestGrp Is Nothing Then
Exit Sub
End If
If myTestGrp.OPCItems.Count > 0 Then
' 異步讀取
lTransID_Rd = lTransID_Rd + 1
myTestGrp.AsyncRead 15, lServerHandles, lErrors, lTransID_Rd, lCancelID_Rd
End If
End Sub
AsyncWrite子程序,完成異步寫的操作。
Sub AsyncWrite(nIndex As Integer, ByRef vtItemValues() As Variant, _
ByRef lErrors() As Long)
Dim lHandle(1) As Long
If myTestGrp Is Nothing Then
Exit Sub
End If
If myTestGrp.OPCItems.Count > 0 Then
lHandle(1) = lServerHandles(nIndex)
' 異步寫入
lTransID_Wt = lTransID_Wt + 1
myTestGrp.AsyncWrite 1, lHandle(), vtItemValues, _
lErrors, lTransID_Wt, lCancelID_Wt
End If
End Sub
3.2.5斷開OPC服務(wù)器
連接著OPC服務(wù)器的OPC客戶應(yīng)用程序,在退出前必須斷開和OPC服務(wù)器的連接。斷開連接前要清除 項(xiàng)和組.
Sub Disconnect()
Dim lErrors() As Long
If Not myItems Is Nothing Then
If myItems.Count > 0 Then
myItems.Remove 15, lServerHandles, lErrors ' 清除OPC項(xiàng)
End If
Set myItems = Nothing
End If
If Not myTestGrp Is Nothing Then
myGroups.Remove "Group"' 清除OPC組
Set myTestGrp = Nothing
End If
If Not myGroups Is Nothing Then
Set myGroups = Nothing
End If
If Not myServer Is Nothing Then
If myServer.ServerState <> OPCDisconnected Then
myServer.Disconnect' 斷開OPC服務(wù)器.
End If
Set myServer = Nothing
End If
End Sub
4 結(jié)論
OPC技術(shù)應(yīng)用于工業(yè)控制領(lǐng)域,大大的突破了傳統(tǒng)設(shè)備的概念,通過一個(gè)接口標(biāo)準(zhǔn)(規(guī)范)方便的將現(xiàn)場(chǎng)任何一個(gè)符合OPC規(guī)范的設(shè)備數(shù)據(jù)收集與處理,從而擺脫了傳統(tǒng)上的編寫驅(qū)動(dòng)程序的重復(fù)勞動(dòng),使工程人員在設(shè)備選擇上有了更大的自主性。
隨著組態(tài)軟件的發(fā)展,監(jiān)控系統(tǒng)開發(fā)越來越“傻瓜化”,只需要簡(jiǎn)單的連接就可以完成一個(gè)工程的基本組態(tài),然而,一旦面臨對(duì)組態(tài)軟件中沒有的設(shè)備時(shí),就無能為力了。在項(xiàng)目改造過程中,這種情況尤為明顯。
在面臨大量諸如小型水利閘門監(jiān)控系統(tǒng)一樣的各種小型工業(yè)監(jiān)控系統(tǒng)改造的情況下,應(yīng)用OPC不僅可以大大的節(jié)約系統(tǒng)開發(fā)的時(shí)間,而且也能充分利用現(xiàn)有設(shè)備,節(jié)省開支。可以說,在小型工控系統(tǒng)改造中,OPC技術(shù)結(jié)合高級(jí)語言開發(fā)監(jiān)控軟件將具有很大的優(yōu)勢(shì)。
【參考文獻(xiàn)】
【1】 OPC Foundation. Data Access Custom Interface Standard Specification 2.0[S],1998.10.14.
【2】 詹根基,郭厚焜.基于OPC的客戶端監(jiān)控程序的開發(fā).自動(dòng)化博覽,2005,Vol.22增刊 (9):105-1
【3】 范逸之.Visual Basic 與分布監(jiān)控系統(tǒng)——RS232/485串行通信,清華大學(xué)出版社,2002
【4】 馬國華.監(jiān)控組態(tài)軟件及其應(yīng)用,清華大學(xué)出版社,2002
【5】 潘愛民.COM原理與應(yīng)用,清華大學(xué)出版社,2000