客户端C#读取opc数据

来源:互联网 发布:spyder tensorflow 编辑:程序博客网 时间:2024/05/29 12:20

关于OPC这个东西,网上文章很多。作为一个需要取数的程序员来说,需要知道的就是客户端的一些设置,至于服务器端,想知道的自己去百度撸吧。

客户端读取数据,网上很多,但是在刚开始的时候总会遇到各种问题,在这里写点,权且自己当个记录吧。

首先是引用一个dll, 名称 OPCDAAuto.dll 这个哪里下载,百度一下,很多的

OPCDAAuto.dll 需要注册 regsvr32 /s OPCDAAuto.dll

using OPCAutomation;

//OPC 变量

 #region 私有变量        OPCServer KepServer;        OPCGroups KepGroups;        OPCGroup KepGroup;        OPCItems KepItems;        #endregion

开始抓取数据

/// <summary>        /// OPC服务器        /// 开始抓取OPC数据        /// </summary>        public void Start()        {             try             {                KepServer.Connect("10.3.4.109","Matrikon.OPC.Simulation.1");                //判断连接状态                if (KepServer.ServerState == (int)OPCServerState.OPCRunning)                {                    SendMsg("已连接到-" + KepServer.ServerName);                }                else                {                    SendMsg("状态:" + KepServer.ServerState.ToString());                    return;                }                KepGroups = KepServer.OPCGroups;                                Task.Factory.StartNew(CreateGroup);                //this.GatherData = true;             }             catch(Exception e)             {               throw e;             }        }

公共函数

private void SendMsg(string m)         {                         //LogHelper.WriteLog(m);         }


创建组

/// <summary>        /// 创建组        /// </summary>        private void CreateGroup()        {            try            {                KepGroups = KepServer.OPCGroups;                KepGroup = KepGroups.Add("OpcGroup");                SetGroupProperty();                KepGroup.DataChange += new DIOPCGroupEvent_DataChangeEventHandler(KepGroup_DataChange);                //KepGroup.AsyncWriteComplete += new DIOPCGroupEvent_AsyncWriteCompleteEventHandler(KepGroup_AsyncWriteComplete);                KepItems = KepGroup.OPCItems;                AddOpcItem();            }            catch (Exception err)            {                SendMsg("枚举本地OPC创建组出现错误:" + err.Message);            }        }
设置采集属性

/// <summary>        /// 设置组属性        /// </summary>        private void SetGroupProperty()        {            KepServer.OPCGroups.DefaultGroupIsActive = true;            KepServer.OPCGroups.DefaultGroupDeadband = 0;            KepGroup.UpdateRate = 3000;            KepGroup.IsActive = true;            KepGroup.IsSubscribed = true;        }


把需要采集数据的点加进去

 

 private void AddOpcItem()        {                  KepItems.AddItem("a1.22.1", 1);   KepItems.AddItem("a2.22.2", 2);   KepItems.AddItem("a3.22.3", 3);         }

点数据发送变化的事件

/// <summary>        /// 每当项数据有变化时执行的事件        /// </summary>        /// <param name="TransactionID">处理ID</param>        /// <param name="NumItems">项个数</param>        /// <param name="ClientHandles">项客户端句柄</param>        /// <param name="ItemValues">TAG值</param>        /// <param name="Qualities">品质</param>        /// <param name="TimeStamps">时间戳</param>        private void KepGroup_DataChange(int TransactionID, int NumItems, ref Array ClientHandles, ref Array ItemValues, ref Array Qualities, ref Array TimeStamps)        {            try            {                    for (int i = 1; i <= NumItems; i++)                    { string temp = string.Concat(ClientHandles.GetValue(i),"-",ItemValues.GetValue(i), "-",Qualities.GetValue(i), "-",TimeStamps.GetValue(i));                        SendMsg(temp);                    }                            }            catch (Exception e) {               SendMsg("KepGroup_DataChange" + e.Message);            }        }


基本上就这样了,整理一下,理解一下,入门没问题,OPC数据的读取还是比较简单的,利用上面的代码,写个简单的程序,把数据读出来没有问题的。


其实如果不喜欢或者不会写程序,也可以用 KEPServerEx软件,配置一下就能搞定。这个玩意是外国人写,运行稳定,并且支持sql,oracle等多种数据库。虽然是要钱的,但是这个难不倒我们中国人,有破解版。


这个代码运行有个前提,那就是客户端是服务器端必须是通的。这个通是用标准的OPC客户端能连上,不是网络上能ping通。

什么是标准的OPC客户端客户端。OPC Client.exe 网上也有下载。


如果标准OPC客户端也连接不上,那就数说明需要客户端需要配置dcom,具体怎么配置,百度一下,本文主要是负责写代码





原创粉丝点击