客户端C#读取opc数据

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

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

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

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

如果win7下有问题,在C:\Windows\SysWOW64路径下,注册“OPCDAAuto.dll”

using OPCAutomation;

//OPC 变量

 

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


开始抓取数据​

/// 
        /// OPC服务器
        /// 开始抓取OPC数据
        /// 
        public void Start()
        {
             try
             {

              
                KepServer = new OPCServer();

KepServer.Connect("127.0.0.1","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);
         }

创建组

/// 
        /// 创建组
        /// 
        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);
            }
        }
设置采集属性
/// 
        /// 设置组属性
        /// 
        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); 
        }

点数据发送变化的事件

/// 
        /// 每当项数据有变化时执行的事件
        /// 
        /// 处理ID
        /// 项个数
        /// 项客户端句柄
        /// TAG值
        /// 品质
        /// 时间戳
        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,具体怎么配置,百度一下,本文主要是负责写代码

 

你可能感兴趣的:(技术)