论文网首页|会计论文|管理论文|计算机论文|医药学|经济学论文|法学论文|社会学论文|文学论文|教育论文|理学论文|工学论文|艺术论文|哲学论文|文化论文|外语论文|论文格式
中国论文网

用户注册

设为首页

您现在的位置: 中国论文网 >> 计算机论文 >> 计算机应用论文 >> 正文 会员中心
 计算机应用论文   计算机理论论文   计算机网络论文   电子商务论文   软件工程论文   操作系统论文   通信技术论文
VC环境下的OPC客户端程序开发
 摘  要  本文通过分析opc 数据访问规范,介绍了有关opc技术的基本概念、数据访问方式以及编写opc客户端接口程序的一般方法。同时给出了一个具体实例,用visual c++编写了一个opc客户端接口程序,并利用opc服务器kepserver对其进行测试,实现了opc客户端与opc服务器之间的数据交换。     关键词  opc服务器;opc客户端;com技术  

1  引言

    随着通信技术、计算机技术和自动化技术的快速发展,大范围信息共享的需求在自动化系统中显得越来越来越重要,现代工业控制系统已逐渐发展成为以现场设备层、过程控制层和中央管理层三个层次组成的系统,因而对其开放性也提出了更高的要求。在传统的控制系统中,现场设备之间以及现场设备与控制软件之间的信息共享主要是通过驱动程序来实现的,不同厂家的设备使用不同的驱动程序,使得软件开发商不得不开发大量驱动程序来连接这些设备,即使设备厂家在硬件上做小小的改动,应用程序就可能重写,这也势必造成工业控制软硬件的升级与维护不便,给用户和软件开发商带来巨大的工作负担。同时,由于不同设备的驱动程序也有所不同,使得不同的应用程序也不能同时访问同一设备的数据,因此,需要制定一种统一开放的接口标准,使应用程序能够方便的存取一台或多台现场设备的数据,为不同厂商的软硬件提供一种系统集成和数据交换的途径。wWW.11665.coM正是在自动化系统开放性要求的驱使下,促使了opc技术的产生。

2  opc技术简介

    opc(ole for process control)是基于微软公司的dna(distributed internet application)构架和com (component object model)/dcom(distributed com)技术,根据易扩展性而设计的,opc规范定义了一个工业标准接口,这个标准使得com技术适用于过程控制和制造自动化等应用领域。ole最初意思为对象链接与嵌入,是微软的复合文档技术。随着后续版本ole2中导入了com技术之后,现在的ole在原版的基础上增加了更多新的功能,包括结构化存储、统一数据传输和自动化等,它已经成为独立于计算机语言、操作系统甚至硬件平台的一种规范,进一步推广了面向对象程序设计的概念。opc正是建立在ole2规范之上,为工业控制领域提供了一种标准的数据访问机制。

2.1  opc数据访问规范

    opc规范是由世界主要的自动化设备制造商、opc基金会和微软公司共同协商制定而成的,为不同厂商的设备和应用程序之间实现了接口标准化。它把硬件供应商和软件开发商分离开来,在设备、数据库等数据源和客户之间架起了一座桥梁,为解决统一接口标准问题提供了解决方案。这其中包括opc数据访问规范(opc da)、opc报警和事件规范(opc ae)和opc历史数据访问规范(opc hda)等,而opc数据访问规范是最常用的规范之一。     通过对opc数据访问规范的分析可知,在opc数据访问规范中主要包括3类对象,分别是opc server、opc group和opc item。opc服务器对象维护有关服务器的信息并作为opc组对象的包容器,能够动态地创建和释放组对象;opc组对象除了维护有关自身的信息之外,还提供了包容opc项的机制,从逻辑上管理opc项。它提供了客户组织数据的一种方法,客户可以对其进行读写,还可以设置客户端的数据更新速率。当服务器缓冲区内的数据发生改变时,opc将向客户发出通知,客户得到通知后再进行必要处理,而无需浪费大量的时间进行查询;opc项则表示了与opc服务器的连接,它并不提供对外接口,客户端不能直接对其进行操作,而是通过组对象对其进行操作的。图1表示了这3类对象的相互关系以及它们与opc客户端程序之间的关系。 图1  opc da服务器对象与opc da客户端的对应关系

2.2  opc数据访问方式

    opc客户端在对opc服务器进行数据访问时,可以选择两种不同的访问方式,即同步访问方式和异步访问方式。其中同步访问方式的实现相对简单,opc服务器将opc应用程序所要求得到的数据访问结果作为方法引数返回给opc应用程序,此时opc应用程序一直处于等待状态,直到结果被返回为止。当客户数目较少并且与服务器交互的数据量也较少的时候可以采用同步访问方式。与此相对,异步访问方式的实现较为复杂,opc服务器接到opc应用程序的要求后,立即将方法引数返回,opc应用程序随后可以进行其它处理。当opc服务器完成数据访问时,触发opc应用程序的异步访问完成事件,将数据访问结果传送给opc应用程序,opc应用程序在vc的事件处理程序中接收从opc服务器传来的数据。当有大量客户和大量数据交互时,异步访问方式的效率更高,能够避免客户数据请求的阻塞,从而最大限度的节省cpu和网络资源。图2和图3分别表示了两种数据访问方式的处理过程。 图2  同步数据访问处理 图3  异步数据访问处理

3  vc环境下opc客户端程序设计

    opc客户端程序在设计时需要遵守opc数据访问规范,实现规范所规定的全部必需接口。同时,客户端模块需要有独立的设备连接界面和监控运行界面,并能够支持多服务器的连接。下面详细介绍vc环境下的opc客户端程序开发步骤,并给出关键源代码:     (1)包含opc头文件。首先创建新的工程,编辑stdafx.h文件,加载opcda.h、opccomn.h、opcerrors.h、opcprops.h、opcquality.h以及opcda_i.c、opccomn_i.c文件。     (2)初始化com库。由于opc是基于com技术制定的,所以在使用接口类之前必须首先使用coinitialize(null)函数对com库进行初始化,如果成功,函数返回值等于s_ ok。     hresult h1;     h1=coinitialize(null);     if(h1!=s_ok)     return(fause);     (3)通过opc服务器的progid查询注册表中相关clsid。每个com服务器都有一个字符串型的progid,通过progid可以得到全球惟一的clsid,使用clsidfromprogid( )函数实现progid到clsid的转换。     h1=clsidfromprogid(progid,&clsid);     (4)连接opc服务器,查询对象的iid_iopcserver接口。在连接opc服务器前,opc客户端需要事先指定计算机名和opc数据访问服务器名,建立连接后,创建opc组并添加opc数据项。     h1=cocreateinstance(clsid,null,clsctx_ local_ server,iid_iopcserver,(void**)&m_opcserver);     (5)创建opc组,查询iopcitemmgt接口。iopcserver接口的addgroup()方法可以创建一个有指定名称和属性的opc组。     h1=m_iopcserver->addgroup(l,” ”,true,800,111,&timebias,&percentdeadband,local_id,& m_ grpsrvhandle,&revisedupdaterate,iid_iopcitemmgt,(lpunknown*)m_iopcitemmgt);     (6)添加opc数据项。使用iopcitemmgt接口的additem()方法可以添加具有特殊属性的指定数量的数据项。     popcitemmgt->additems(itemnumber,itemarray,(opcitemresult**)&pitemresult,(hresult **) & perrors);     (7)opc的数据项读写。对opc数据项的读写可以有同步与异步之分,对于大量的数据传输,异步是更佳的选择,但对少量的数据传输,同步表现得更好。本程序采用异步访问方式,需要指向iopcasyncio2指针。 h1=m_iopcitemmgt->queryinterface(iid_iopcasyncio2,(void**)&m_iopcasyncio2); void casynopcdlg::onread ( ) 实现异步读数据。 h1=m_iopcasyncio2->read(1,phserver,1,&dwcancelid,&perrors);     delete[] phserver;     void casynopcdlg::onwrite( ) 实现异步写数据。 h1=m_iopcasyncio2->write(1,phserver,values,2,&dwcancelid,&perrors);     delete[] phserver;    (8)opc连接断开,释放接口指针。当程序退出或停止服务器时,依次删除item(removeitems)、group(removegroups),释放资源。 void casynopcdlg::onstop( ) 停止服务器。 h1=m_iopcitemmgt->removeitems(1,phserver,&perrors);删除items。 h1=m_iopcserver->removegroup(m_grpsrvhandle,true);删除group。 m_iopcserver->release( );释放服务器。 m_iopcserver=null; couninitialize( );关闭com库。 图4  opc客户端程序     使用opc技术之后,我们就可以通过opc客户端直接访问由硬件供应商提供的opc服务器,从而达到直接获取现场设备数据的目的。图4显示的即是基于vc开发的opc客户端程序对opc服务器kepserver的访问界面,实现了opc客户端与opc服务器进行数据交互的功能,为开发其它功能更加完善的opc客户端软件提供了基础。

4  结束语

    自动化系统的发展趋势是控制与管理一体化,应用于自动化领域的opc技术统一了数据访问的接口,使控制系统进一步走向开放,实现了信息的集成与共享,其优越性是显而易见的。opc技术的出现改变了原有的控制系统模式,获得了自动化设备厂商的广泛认可。目前绝大多数的工控设备厂家都为其硬件提供了opc服务器,这使得开发opc客户端软件也具有更广阔的应用前景。

参考文献

[1] 邹云涛,吴重光. opc技术初探及国内应用现状,2003,6,3-5 [2] 何海江. opc客户端关键技术的实现.微计算机信息,2003,19(7),76-78 [3] david j. kruglinski,scot wingo,george shepherd,programming visual c++ 6.0 技术内幕第五版,.北京:北京希望电子出版社,2002. 3,550-615 [4] opc foundation,opc da 3.0 specification,mar . 4,2003,87-98
  • 上一个计算机论文:
  • 下一个计算机论文:
  •  作者:赵健 师奕兵 [标签: 客户 程序 ]
    姓 名: *
    E-mail:
    评 分: 1分 2分 3分 4分 5分
    评论内容:
    发表评论请遵守中国各项有关法律法规,评论内容只代表网友个人观点,与本网站立场无关。
    XBRL环境下财务报告鉴证框架的建构
    环境规制促进产业结构优化升级的绩效分析
    洞庭湖生态旅游危机的环境伦理学分析
    浅谈城市规划中的环境保护规划
    基于角色的计算机软件协作环境研究与实现
    电子商务环境下的消费者权益保护
    氟康唑治疗复杂型外阴阴道假丝酵母菌病(VV
    甘草酸对酸性环境中变异链球菌生长影响的体
    ASP环境下建设中小企业信息系统
    浅谈基于网络环境下中职计算机教学评价系统
    电子商务环境下逆向物流发展策略分析
    网络环境下学生信息素养的培养初探
    | 设为首页 | 加入收藏 | 联系我们 | 网站地图 | 手机版 | 论文发表

    Copyright 2006-2013 © 毕业论文网 All rights reserved 

     [中国免费论文网]  版权所有