| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 | using Aitex.Core.RT.Log;using Aitex.Core.RT.SCCore;using Aitex.Core.Util;using MECF.Framework.Common.Beckhoff.ModuleIO;using MECF.Framework.Common.Device.Festo;using MECF.Framework.Common.TwinCat;using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;namespace MECF.Framework.Common.Device.Galil{    public class GalilAxisManager : Singleton<GalilAxisManager>     {        #region 内部变量        /// <summary>        /// 模块变量更新委托字典(key-模块.变量,value-变量委托事件        /// </summary>        private Dictionary<string, BeckhoffDelegate.OnUpdateModuleVariableValue> _moduleVariableActionDic = new Dictionary<string, BeckhoffDelegate.OnUpdateModuleVariableValue>();        /// <summary>        /// 变量数值字典(key-io变量名称,value-数值)        /// </summary>        private Dictionary<string, object> _nameVariableValueDic = new Dictionary<string, object>();        #endregion        /// <summary>        /// 注册变量数值发生变化回调        /// </summary>        /// <param name="moduleName"></param>        /// <param name="variable"></param>        /// <param name="onUpdateModuleVariableValue"></param>        public void SubscribeModuleVariable(string moduleName, string variable, BeckhoffDelegate.OnUpdateModuleVariableValue onUpdateModuleVariableValue)        {            string name = $"{moduleName}.{variable}";            _moduleVariableActionDic[name] = onUpdateModuleVariableValue;            if (_nameVariableValueDic.ContainsKey(name))            {                _moduleVariableActionDic[name].Invoke(variable, _nameVariableValueDic[name]);                            }        }        /// <summary>        /// 更新IO数值        /// </summary>        /// <param name="name"></param>        /// <param name="value"></param>        public void UpdateIoValue(string name, object value)        {            bool _enableRead = SC.GetValue<bool>("Twincat.EnableReadLog");            if (_enableRead)            {                LOG.WriteBackgroundLog(eEvent.INFO_GALIL, "System", $"read {name} value {value}");            }            _nameVariableValueDic[name] = value;            if (_moduleVariableActionDic.ContainsKey(name))            {                string[] strAry = name.Split('.');                if (strAry.Length != 0)                {                    _moduleVariableActionDic[name].Invoke(strAry[strAry.Length - 1], value);                }            }        }    }}
 |