利用VB實現(xiàn)上位機與DX中波發(fā)射機通訊_第1頁
利用VB實現(xiàn)上位機與DX中波發(fā)射機通訊_第2頁
利用VB實現(xiàn)上位機與DX中波發(fā)射機通訊_第3頁
利用VB實現(xiàn)上位機與DX中波發(fā)射機通訊_第4頁
利用VB實現(xiàn)上位機與DX中波發(fā)射機通訊_第5頁
已閱讀5頁,還剩8頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

前言dx系列中波發(fā)射機是由美國harris公司制造的全固態(tài)數(shù)字調(diào)幅發(fā)射機,由于其運行穩(wěn)定、各項指標好、整機效率高等優(yōu)點,在全國各臺站得以廣泛應(yīng)用。我臺自1999年起開始使用dx—400發(fā)射機,在10年左右的使用與維護工作中我們曾對dx-400發(fā)射機進行了兩次自動化改造。第一次改造是用omronc200hplc加外圍電路來實現(xiàn)對發(fā)射機和附屬設(shè)備進行采樣和控制的,但在實際的使用過程中我們發(fā)現(xiàn)這樣的控制系統(tǒng)有其致命的局限性。因為系統(tǒng)是plc加外圍電路實現(xiàn)的控制系統(tǒng)就決定了系統(tǒng)無法顯示機器內(nèi)部數(shù)據(jù)的實時狀態(tài),無法與發(fā)射機內(nèi)部實現(xiàn)直接通信。因此只有實現(xiàn)了工控機與發(fā)射機的控制核心—-plc(可編程控制器)直接通信才能克服這一局限性,真正實現(xiàn)實時掌握機器內(nèi)部數(shù)據(jù)狀態(tài)和對發(fā)射機的直接控制。dx—400發(fā)射機控制單元使用的是a-bplc,這種plc是rockwellautomation的專利產(chǎn)品,使得第三方的軟件不能很好地與a-bplc進行連接。在實際改造工作中我們找到了一種采用dde(動態(tài)數(shù)據(jù)交換技術(shù))技術(shù)與a-bplc進行數(shù)據(jù)交換的方法,能夠更好的解決這一瓶頸問題。dde技術(shù)的工作機制dde是動態(tài)數(shù)據(jù)交換技術(shù)的縮寫,是為在同一臺計算機或不同計算機上運行的程序提供動態(tài)數(shù)據(jù)交換的一種新技術(shù),最早由microsoft公司提出的。動態(tài)數(shù)據(jù)交換(dde)技術(shù)由于其具有實時性好、網(wǎng)絡(luò)通信連接實現(xiàn)方便等特點,在控制軟件與信息網(wǎng)絡(luò)集成中得到了廣泛應(yīng)用。動態(tài)數(shù)據(jù)交換基于widnows消息機制,各應(yīng)用程序間通過傳遞消息進行對話交換信息。windowsdde消息傳遞采用client/server模式,客戶(client)是數(shù)據(jù)的請求和接受者,而服務(wù)器(server)是數(shù)據(jù)的提供者,兩者之間通過請求、應(yīng)答、傳輸三個步驟來完成數(shù)據(jù)的傳送。dde協(xié)議使用服務(wù)(service)、主題(topic)和數(shù)據(jù)項(item)三級命名來標識dde所傳遞的數(shù)據(jù)單元。一般情況下,服務(wù)(service)就是應(yīng)用程序的文件名,主題是對服務(wù)器有意義的信息單元。每次dde客戶與服務(wù)程序之間的對話都是先由客戶啟動的,所以在每次客戶啟動之前,dde服務(wù)器應(yīng)當首先投入運行。當客戶程序需要向服務(wù)器程序請求數(shù)據(jù)時,客戶程序發(fā)送一條wm—dde—initeate消息給當前運行的所有widnows應(yīng)用程序,這條消息不但包含了它所需要的服務(wù)器名(service)和主題名(topic),而且指明了它所希望的數(shù)據(jù)類型,收到wm—dde-initeate消息的應(yīng)用程序通過判別服務(wù)器名和會話主題決定是否應(yīng)答,一旦dde服務(wù)器響應(yīng)了這條被傳播的消息,dde會話就開始了。dde的工作方式有冷連接(coollink)、溫連接(warmlink)和熱連接(hotlink)等3種。在冷連接方式下,當server中的數(shù)據(jù)發(fā)生變化后不主動通知client,但client可以隨時從server讀寫數(shù)據(jù);在溫連接方式下,當server中的數(shù)據(jù)發(fā)生變化后馬上通知client,client得到通知后將數(shù)據(jù)取回;在熱連接方式下,當server中的數(shù)據(jù)發(fā)生變化后馬上通知上位機(工client,同時將變化的數(shù)據(jù)直接送給client。硬件連接與系統(tǒng)配置控機)與a-bplc的連接方式有兩種:一種是利用廠家提供的dh+485數(shù)據(jù)線將上位機通訊卡與a—bplccpu模塊的dh+接口直接連接;一種是通過自制的r232數(shù)據(jù)線將上位機com口與a—bplccpu模塊的rs232接口直接連接。通訊卡連接方式將allenbradley公司出品的1784—pktx通訊卡安裝到上位機上.安裝方法如下:請確認已將其中一塊通訊卡上的地址跳線帽(jp3)拔掉。參見圖1。(1)打開工控機機箱,將1784—pktx通訊卡插入pci插槽內(nèi),固定螺絲,蓋好蓋板;(2)啟動工控機,系統(tǒng)檢測到硬件。如果用戶已經(jīng)安裝rslogix500軟件,則系統(tǒng)將自動檢測到驅(qū)動。如果用戶尚未安裝rslogix500軟件,可先安裝該軟件,軟件安裝完畢后,系統(tǒng)將自動為通訊卡安裝驅(qū)動程序;(3)用dh+485數(shù)據(jù)線將上位機(工控機)與plc連接;(4)使用rslinx連接a—bplc的通訊網(wǎng)絡(luò),運行rslinxclassic軟件。點擊菜單中“通信”選項,在下拉列表中選擇“配置驅(qū)動程序”:(參見圖2)。點擊該選項后,彈出如圖3所示頁面,在下拉列表中選擇1784-kt/ktx(d)/pktx(d)/pcmkfordh+/dh485devices后,單擊【新增…】按鈕:此時彈出確認框,如圖4所示。點擊“確定”后,彈出如下頁面,如圖5所示,在“值”下拉列表中選擇pktx(d)選項:點擊“確定”后,rslinx配置完成.r232連接方式(1)按照標準電纜1747cp3的內(nèi)部接線圖(如圖6)自制com口通信電纜也是能夠?qū)崿F(xiàn)上位機與plc的通信的,此種電纜的優(yōu)點:造價低廉、使用方便;缺點:不能通過這種數(shù)據(jù)線組成plc網(wǎng)絡(luò),實現(xiàn)多plc資源共享.(2)使用rslinx連接a-bplc的通訊網(wǎng)絡(luò)配置方式與前相同只是在進入configdirvier菜單后彈出如圖7所示頁面。在下拉列表中選擇rs-232df1devices選項,然后點擊“新增”按鈕會出現(xiàn)如下對話框,如圖8所示。點擊“確定”,出現(xiàn)如下對話框,如圖9所示.點擊“自動配置"按鈕,系統(tǒng)開始對plc進行自動配置.以上配置完成后點擊“確定"按鈕并關(guān)閉對話框(此時程序回最小化并沒有關(guān)閉)。進行dde服務(wù)的配置在菜單欄中打開“dde/opc”菜單并選擇“主題組態(tài)”對話框,如圖10所示。從圖左側(cè)我們發(fā)現(xiàn)了要找的plc并在右側(cè)顯示了“主題列表”中看到程序名。點開“數(shù)據(jù)采集"欄在“處理器類型”下拉菜單中選擇“slc-503+”項,這一步很重要只有通過它才能正確的加載驅(qū)動程序,為通信打下基礎(chǔ),如圖11所示。點開“高級通信”欄在“通信驅(qū)動程序”中選擇“abdf1-1dh485工作站”項,如圖12所示。這樣在rslinx軟件中對a-bplc的通信配置就完成了,建立與plc數(shù)據(jù)聯(lián)結(jié)既可以完成與plc的數(shù)據(jù)交換。利用vb開發(fā)dde客戶端vb作為microsoft公司軟件產(chǎn)品的重要一員,理所當然的對windows操作系統(tǒng)下的dde技術(shù)給予支持。vb為一些控件提供了用于dde動態(tài)數(shù)據(jù)交換的linktopic、linkitem、linktimeout、linkmode等屬性,以及l(fā)inkrequest、linkpoke、linkexecute、linksend等方法.其中,linktopic、linkitem兩項屬性分別對應(yīng)于dde通訊架構(gòu)中的主題名和數(shù)據(jù)項名,linktimeout、linkmode分別表示dde客戶端與dde服務(wù)器的嘗試連接時間和連接模式(數(shù)據(jù)交換方式),linkmode有manual、notify、automatic三種方式,而automatic方式最為常用,它主要用于和ddeserver建立“熱連接(hotlink)”,即在dde服務(wù)器數(shù)據(jù)發(fā)生變化時主動發(fā)送數(shù)據(jù)給客戶端.linkrequest、linkpoke分別用于dde客戶端對dde服務(wù)器數(shù)據(jù)的讀寫操作。在vb中實現(xiàn)與a-bplc的“熱連接”在visualbasi建立一個新工程,添加幾個label控件,并建立和rslinx的dde通訊連接,使其隨上一步所設(shè)置好的連接的a—bplc數(shù)據(jù)“b01主系統(tǒng)”數(shù)值的變化而變化。其代碼如下:privatesubform_load()label1.linktopic=“rslinx|”&“b01主系統(tǒng)"label1.linkitem=“s:42”label1。linkmode=1label1.linkrequestlabel3。linktopic=“rslinx|”&“b01主系統(tǒng)"label3.linkitem=“s:41”label3.linkmode=1label3.linkrequestlabel5.linktopic=“rslinx|”&“b01主系統(tǒng)"label5.linkitem=“s:40”label5.linkmode=1label5。linkrequestlabel10.linktopic=“rslinx|”&“b01主系統(tǒng)”label10.linkitem=“n60:11”label10.linkmode=1label10。linkrequestlabel12.linktopic=“rslinx|”&“b01主系統(tǒng)”label12。linkitem=“n60:130”label12。linkmode=1label12.linkrequestlabel14.linktopic=“rslinx|"&“b01主系統(tǒng)"label14。linkitem=“n60:131”label14.linkmode=1label14。linkrequestendsub其中,代碼中的“rslinx”和“b01主系統(tǒng)”分別表示應(yīng)用程序名和主題名,“l(fā)inkmode”值為1表示連接方式為automatic(即“熱連接”)方式。這樣當該應(yīng)用代碼被執(zhí)行時,label的值便隨a-bplc內(nèi)存值的變化而變化。具體執(zhí)行如圖13所示。在excel中實現(xiàn)通過dde方式訪問a-bplc首先必須先安裝rslinx創(chuàng)建ddetopic.比如我們定義一個topic名叫“b01主系統(tǒng)",打開excel,創(chuàng)建宏命令,編寫vba腳本如何讀取和寫入數(shù)據(jù),從而完成與plc的數(shù)據(jù)交換。substart()dimlngrowaslongdimvarcycleasvariantdimvarloggingasvariantdimvarresultsasvariantonerrorgotoerrorrsichan=ddeinitiate(“rslinx”,“b01主系統(tǒng)”)varlogging=dderequest(rsichan,“n60/163”)varcycle=dderequest(rsichan,“n60/161”)l/?ifvarcycle(1)=“1”andvarlogging(1)=“1”thenlngrow=3ifrange(“indata?。幔场?。value》3thenlngrow=range(“indata!a3").valueendifforlngrow=lngrowto65500ifcells(lngrow,1)=“"thenexitforrange(“indata!a3").value=lngrow+1nextrsichan=ddeinitiat(yī)e(“rslinx”,“n1”)f810dat(yī)a=dderequest(rsichan,“f8:10")f811data=dderequest(rsichan,“f8:11")f812data=dderequest(rsichan,“f8:12”)f816data=dderequest(rsichan,“f8:16")f818data=dderequest(rsichan,“f8:18”)f817data=dderequest(rsichan,“f8:17”)f820data=dderequest(rsichan,“f8:20”)f821data=dderequest(rsichan,“f8:21")f822data=dderequest(rsichan,“f8:22")f823data=dderequest(rsichan,“f8:23”)f824data=dderequest(rsichan,“f8:24”)varresults=dderequest(rsichan,“f8:25”)ddeterminate(rsichan)cells(lngrow,1).value=f810datacells(lngrow,2).value=f811datacells(lngrow,3).value=f812dat(yī)acells(lngrow,4).value=f816datacells(lngrow,5).value=f818datacells(lngrow,6).value=f817datacells(lngrow,7)。value=f820datacells(lngrow,8).value=f821datacells(lngrow,9).value=f822datacells(lngrow,10)。value=f823datacells(lngrow,11)。value=f824datacells(lngrow,13).value=now()endifendsub在vb中實現(xiàn)調(diào)用excel后臺數(shù)據(jù)庫因為前期已經(jīng)實現(xiàn)了vb與plc的通訊可以實時看到數(shù)據(jù)的狀態(tài)了,隨后又實現(xiàn)了excel與plc的通訊也可以實時看到數(shù)據(jù)的狀態(tài),但這兩種方法都有其局限性:前者可看、可控但因無數(shù)據(jù)庫無法實現(xiàn)數(shù)據(jù)的存儲,后者可看、可查但因無可執(zhí)行程序無法實現(xiàn)可控.只有二者結(jié)合在一起才能揚長避短充分發(fā)揮功效。于是在vb中實現(xiàn)調(diào)用excel后臺數(shù)據(jù)庫這種方式就應(yīng)運而生了,這種方式即充分發(fā)揮了vb可控的一面又實現(xiàn)了excel對數(shù)據(jù)的強大處理能力可以說上位機真正實現(xiàn)了對plc可看、可查、可控的功能。vb與excel的連接方法如下:(1)在工程中引用microsoftexcel類型庫:從“工程”菜單中選擇“引用”欄;選擇microsoftexcel9.0objectlibrary(excel2000),然后選擇“確定”。表示在工程中要引用excel類型庫.(2)在通用對象的聲明過程中定義excel對象:dimxlappasexcel.applicat(yī)iondimxlbookasexcel。workbookdimxlsheetasexcel.worksheet(3)在程序中操

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論