From 66a9965c44ecc32a6696abca876ab9d1cd091584 Mon Sep 17 00:00:00 2001
From: gxc <guoxuecheng@guoxuechengdeMacBook-Pro.local>
Date: 星期五, 28 二月 2020 15:25:13 +0800
Subject: [PATCH] 2020.2.28

---
 ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlGatewayReceiveLogic.cs |  477 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 465 insertions(+), 12 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlGatewayReceiveLogic.cs b/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlGatewayReceiveLogic.cs
index 5565855..303e827 100755
--- a/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlGatewayReceiveLogic.cs
+++ b/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlGatewayReceiveLogic.cs
@@ -2,6 +2,7 @@
 using System.Collections.Generic;
 using System.Text;
 using Newtonsoft.Json.Linq;
+using ZigBee.Device;
 
 namespace Shared.Phone.UserCenter
 {
@@ -10,15 +11,48 @@
     /// </summary>
     public class HdlGatewayReceiveLogic
     {
+        #region 鈻� 鍙橀噺澹版槑___________________________
+
+        /// <summary>
+        /// 鍏ㄥ眬鎺ユ敹缃戝叧鎺ㄩ�佺殑鐨勯�昏緫
+        /// </summary>
+        private static HdlGatewayReceiveLogic m_Current = null;
+        /// <summary>
+        /// 鍏ㄥ眬鎺ユ敹缃戝叧鎺ㄩ�佺殑鐨勯�昏緫
+        /// </summary>
+        public static HdlGatewayReceiveLogic Current
+        {
+            get
+            {
+                if (m_Current == null)
+                {
+                    m_Current = new HdlGatewayReceiveLogic();
+                }
+                return m_Current;
+            }
+        }
+
+        /// <summary>
+        /// 璁惧鎺ㄩ�佷簨浠堕泦鍚�
+        /// </summary>
+        private Dictionary<string, Action<CommonDevice>> dicDeviceEvent = new Dictionary<string, Action<CommonDevice>>();
+        /// <summary>
+        /// 鍛戒护鍖哄垎
+        /// </summary>
+        private Dictionary<string, ReceiveComandDiv> dicCommandDiv = new Dictionary<string, ReceiveComandDiv>();
+
+        #endregion
+
         #region 鈻� 鍏ㄥ眬鎺ユ敹___________________________
 
         /// <summary>
         /// 鍏ㄥ眬鎺ユ敹缃戝叧鎺ㄩ�佺殑鐨勯�昏緫(涓轰簡鎵ц閫熷害,灏藉彲鑳界殑鍒姞鑰楁椂鐨勬搷浣�)
         /// </summary>
         /// <param name="gatewayId">缃戝叧ID</param>
-        /// <param name="topic">涓婚</param>
-        /// <param name="receiveData">鎺ユ敹鐨勬暟鎹�</param>
-        public static void GatewayOverallMsgReceive(string gatewayId, string topic, JObject receiveData)
+        /// <param name="topic">鏁翠釜涓婚</param>
+        /// <param name="reportTopic">涓婃姤鏁版嵁鐨勪富棰�</param>
+        /// <param name="msgData">鎺ユ敹鐨勬暟鎹�</param>
+        public void GatewayOverallMsgReceive(string gatewayId, string topic, string reportTopic, string msgData)
         {
             if (topic == "AppNoLogin")
             {
@@ -31,8 +65,9 @@
 
                     UserCenterLogic.ReLoginAgain(UserCenterResourse.UserInfo.Account, false);
                 });
+                return;
             }
-            else if (topic == "BeingSqueezedOffline")
+            else if (topic == "ZigbeeGateWayToClient/" + Common.Config.Instance.ConnEmqClientId + "/Push/NotifySqueeze")
             {
                 HdlThreadLogic.Current.RunMain(() =>
                 {
@@ -43,8 +78,38 @@
 
                     UserCenterLogic.ReLoginAgain(UserCenterResourse.UserInfo.Account, false);
                 });
+                return;
             }
+            else if (topic == "YouIpAndPortNoRecord")
+            {
+                HdlThreadLogic.Current.RunMain(() =>
+                {
+                    //鎮ㄥ綋鍓嶇殑IP鍙婄鍙e湪浜戠涓嶅瓨鍦�,璇烽噸鏂扮櫥褰�!
+                    string msg = Language.StringByID(R.MyInternationalizationString.uYouIpAndPortNoRecord);
+                    var contr = new ShowMsgControl(ShowMsgType.Tip, msg);
+                    contr.Show();
 
+                    UserCenterLogic.ReLoginAgain(UserCenterResourse.UserInfo.Account, false);
+                });
+                return;
+            }
+            else if (topic == "ZigbeeGateWayToClient/" + Common.Config.Instance.Guid + "/Push/Deleted"
+                || topic == "ZigbeeGateWayToClient/" + Common.Config.Instance.Guid + "/Push/DeletedShareData")
+            {
+                if (UserCenterResourse.UserInfo.AuthorityNo == 3)
+                {
+                    HdlThreadLogic.Current.RunMain(() =>
+                    {
+                        //鍒嗕韩鏁版嵁宸茬粡鍙樻洿,璇烽噸鏂扮櫥闄�
+                        string msg = Language.StringByID(R.MyInternationalizationString.uShardDataIsChangedPleaseLoginAgain);
+                        var contr = new ShowMsgControl(ShowMsgType.Tip, msg);
+                        contr.Show();
+
+                        UserCenterLogic.ReLoginAgain(UserCenterResourse.UserInfo.Account, false);
+                    });
+                }
+                return;
+            }
             try
             {
                 if (HdlGatewayLogic.Current.IsGatewayExist(gatewayId) == false)
@@ -52,17 +117,51 @@
                     //涓嶆槸鑷繁缁戝畾鐨勭綉鍏筹紝鍒欎笉澶勭悊
                     return;
                 }
-                //闂ㄩ攣涓婃姤
-                if (topic == gatewayId + "/Alarms/SendAlarmInform")
+                //璁惧灞炴�т笂鎶�
+                if (reportTopic == "DeviceStatusReport")
                 {
-                    //淇濆瓨闂ㄩ攣鎶ヨ淇℃伅鍒版湰鍦�
-                    HdlAlarmsLogic.Current.SaveDoorLockAlarmInfo(receiveData);
-
+                    //璁惧灞炴�т笂鎶�
+                    this.DeviceAttributeReportPush(JObject.Parse(msgData));
+                }
+                //浼犳劅鍣ㄤ笂鎶�
+                else if (reportTopic == "IASInfoReport")
+                {
+                    this.SensorDeviceReportPush(JObject.Parse(msgData));
+                }
+                //闂ㄩ攣涓婃姤
+                else if (topic == gatewayId + "/Alarms/SendAlarmInform")
+                {
+                    this.DoorLockDeviceReportPush(null);
                 }
                 //閫氳繃澶栭儴鏂瑰紡甯冮槻鎾ら槻鎴愬姛鏃舵姤鍛�
                 else if (topic == gatewayId + "/Security/EnOrWithdrawSucceedReport")
                 {
-                    SecurityEnOrWithdrawSucceedReport(receiveData);
+                    this.SecurityEnOrWithdrawSucceedReport(JObject.Parse(msgData));
+                }
+                //璁惧鍦ㄧ嚎鐘舵�佹洿鏂板弽棣�
+                else if (reportTopic == "OnlineStatusChange_Respon")
+                {
+                    this.DeviceOnlineChangePush(JObject.Parse(msgData));
+                }
+                //鎾ら槻
+                else if (topic == gatewayId + "/Security/WithdrawMode_Respon")
+                {
+                    this.RemoveSafetyGarrisonPush(JObject.Parse(msgData));
+                }
+                //甯冮槻
+                else if (topic == gatewayId + "/Security/EnableMode_Respon")
+                {
+                    this.SetSafetyGarrisonPush(JObject.Parse(msgData));
+                }
+                //閫昏緫瑙﹀彂涓婃姤
+                else if (topic == gatewayId + "/Logic/Execute_Respon")
+                {
+                    this.LogicExecutePush(null);
+                }
+                //鍦烘櫙瑙﹀彂涓婃姤
+                else if (topic == gatewayId + "/Scene/Exec_Respon")
+                {
+                    this.SceneExecPush(null);
                 }
             }
             catch (Exception ex)
@@ -74,13 +173,160 @@
 
         #endregion
 
+        #region 鈻� 璁惧灞炴�т笂鎶______________________
+
+        /// <summary>
+        /// 璁惧灞炴�т笂鎶�
+        /// </summary>
+        /// <param name="receiveData"></param>
+        private void DeviceAttributeReportPush(JObject receiveData)
+        {
+            if (this.dicDeviceEvent.Count == 0)
+            {
+                //娌℃湁娣诲姞鐩戝惉
+                return;
+            }
+            var deviceAddr = receiveData.Value<string>("DeviceAddr");
+            var deviceEpoint = receiveData.Value<int>("Epoint");
+
+            var tempDevice = new CommonDevice { DeviceAddr = deviceAddr, DeviceEpoint = deviceEpoint };
+            tempDevice.DeviceStatusReport = Newtonsoft.Json.JsonConvert.DeserializeObject<CommonDevice.DeviceStatusReportData>(receiveData["Data"].ToString());
+
+            this.DeviceReportPush(tempDevice, ReceiveComandDiv.A璁惧灞炴�т笂鎶�);
+        }
+
+        #endregion
+
+        #region 鈻� 浼犳劅鍣ㄤ笂鎶________________________
+
+        /// <summary>
+        /// 浼犳劅鍣ㄨ澶囦笂鎶�
+        /// </summary>
+        /// <param name="receiveData"></param>
+        private void SensorDeviceReportPush(JObject receiveData)
+        {
+            var ias = new IASZone() { DeviceAddr = receiveData.Value<string>("DeviceAddr"), DeviceEpoint = receiveData.Value<int>("Epoint") };
+            ias.iASInfo = Newtonsoft.Json.JsonConvert.DeserializeObject<IASZone.IASInfoData>(receiveData["Data"].ToString());
+
+            //濡傛灉娌℃湁娣诲姞鍏ュ畨闃�
+            if (HdlSafeguardLogic.Current.GetZoneIdByIASZone(ias) != -1)
+            {
+                //淇濆瓨瀹夐槻鎶ヨ淇℃伅鍒版湰鍦�
+                HdlAlarmsLogic.Current.SaveSafeguardAlarmInfo(ias);
+            }
+
+            this.DeviceReportPush(ias, ReceiveComandDiv.A浼犳劅鍣ㄤ笂鎶�);
+
+            //鏄剧ず鏈夋柊娑堟伅鐨勭壒鏁�
+            this.ShowHadNewMessageAppeal();
+        }
+
+        #endregion
+
+        #region 鈻� 闂ㄩ攣涓婃姤___________________________
+
+        /// <summary>
+        /// 闂ㄩ攣涓婃姤
+        /// </summary>
+        /// <param name="receiveData"></param>
+        private void DoorLockDeviceReportPush(JObject receiveData)
+        {
+            //淇濆瓨闂ㄩ攣淇℃伅鍒版湰鍦�
+            //HdlAlarmsLogic.Current.SaveDoorLockAlarmInfo(receiveData);
+
+            //鏄剧ず鏈夋柊娑堟伅鐨勭壒鏁�
+            this.ShowHadNewMessageAppeal();
+        }
+
+        #endregion
+
+        #region 鈻� 璁惧鍦ㄧ嚎鐘舵�佹洿鏂板弽棣坃______________
+
+        /// <summary>
+        /// 璁惧鍦ㄧ嚎鐘舵�佹洿鏂板弽棣�
+        /// </summary>
+        /// <param name="receiveData"></param>
+        private void DeviceOnlineChangePush (JObject receiveData)
+        {
+            if (this.dicDeviceEvent.Count == 0)
+            {
+                //娌℃湁娣诲姞鐩戝惉
+                return;
+            }
+            var tempDevice = new CommonDevice() { DeviceAddr = receiveData.Value<string>("DeviceAddr"), DeviceEpoint = receiveData.Value<int>("Epoint") };
+            tempDevice.IsOnline = Convert.ToInt32(receiveData["Data"]["IsOnline"].ToString());
+            
+            this.DeviceReportPush(tempDevice, ReceiveComandDiv.A璁惧鍦ㄧ嚎涓婃姤);
+        }
+
+        #endregion
+
+        #region 鈻� 甯冮槻_______________________________
+
+        /// <summary>
+        /// 甯冮槻鎺ㄩ��
+        /// </summary>
+        /// <param name="receiveData"></param>
+        private void SetSafetyGarrisonPush(JObject receiveData)
+        {
+            var data = Newtonsoft.Json.JsonConvert.DeserializeObject<Safeguard.EnableModeResponseData>(receiveData["Data"].ToString());
+            if (data.Result == 0)
+            {
+                var garrison = GarrisonMode.None;
+                //鍦ㄥ甯冮槻
+                if (data.ModeId == 1) { garrison = GarrisonMode.AtHome; }
+                //绂诲甯冮槻
+                else if (data.ModeId == 2) { garrison = GarrisonMode.RemoveHome; }
+                else { return; }
+
+                //淇濆瓨鎶ヨ淇℃伅鐒跺悗鎺ㄩ�佸埌鐣岄潰涓�
+                HdlAlarmsLogic.Current.SaveSafeguardAlarmInfo(garrison);
+                if (UserCenterResourse.DicActionForm.ContainsKey("SafetyManagementMainForm") == true)
+                {
+                    //鎺ㄩ��
+                    var form = (Safety.SafetyManagementMainForm)UserCenterResourse.DicActionForm["SafetyManagementMainForm"];
+                    form?.GarrisonModePush(garrison);
+                }
+                //鏄剧ず鏈夋柊娑堟伅鐨勭壒鏁�
+                this.ShowHadNewMessageAppeal();
+            }
+        }
+
+        #endregion
+
+        #region 鈻� 鎾ら槻_______________________________
+
+        /// <summary>
+        /// 鎾ら槻鎺ㄩ��
+        /// </summary>
+        /// <param name="receiveData"></param>
+        private void RemoveSafetyGarrisonPush(JObject receiveData)
+        {
+            var data = Newtonsoft.Json.JsonConvert.DeserializeObject<Safeguard.WithdrawModeResponseData>(receiveData["Data"].ToString());
+            if (data.Result == 0)
+            {
+                //淇濆瓨鎶ヨ淇℃伅鐒跺悗鎺ㄩ�佸埌鐣岄潰涓�
+                HdlAlarmsLogic.Current.SaveSafeguardAlarmInfo(GarrisonMode.RemoveGarrison);
+                if (UserCenterResourse.DicActionForm.ContainsKey("SafetyManagementMainForm") == true)
+                {
+                    //鎺ㄩ��
+                    var form = (Safety.SafetyManagementMainForm)UserCenterResourse.DicActionForm["SafetyManagementMainForm"];
+                    form?.GarrisonModePush(GarrisonMode.RemoveGarrison);
+                }
+                //鏄剧ず鏈夋柊娑堟伅鐨勭壒鏁�
+                this.ShowHadNewMessageAppeal();
+            }
+        }
+
+        #endregion
+
         #region 鈻� 閫氳繃澶栭儴鏂瑰紡甯冮槻鎾ら槻_______________
 
         /// <summary>
         /// 閫氳繃澶栭儴鏂瑰紡甯冮槻鎾ら槻
         /// </summary>
         /// <param name="receiveData">鎺ユ敹鐨勬暟鎹�</param>
-        private static void SecurityEnOrWithdrawSucceedReport(JObject receiveData)
+        private void SecurityEnOrWithdrawSucceedReport(JObject receiveData)
         {
             var data = Newtonsoft.Json.JsonConvert.DeserializeObject<SecurityEnOrWithdrawResult>(receiveData["Data"].ToString());
             if (data.EnOrWithdraw == -1 || data.ModeId == -1 || data.OperationWay == -1)
@@ -107,7 +353,15 @@
             else if (data.OperationWay == 1) { appendText = "(" + Language.StringByID(R.MyInternationalizationString.uPanelOperation) + ")"; }
 
             //淇濆瓨鎶ヨ淇℃伅鐒跺悗鎺ㄩ�佸埌鐣岄潰涓�
-            HdlAlarmsLogic.Current.SaveSafeguardAlarmInfo(garrison, appendText, true);
+            HdlAlarmsLogic.Current.SaveSafeguardAlarmInfo(garrison, appendText);
+            if (UserCenterResourse.DicActionForm.ContainsKey("SafetyManagementMainForm") == true)
+            {
+                //鎺ㄩ��
+                var form = (Safety.SafetyManagementMainForm)UserCenterResourse.DicActionForm["SafetyManagementMainForm"];
+                form?.GarrisonModePush(garrison);
+            }
+            //鏄剧ず鏈夋柊娑堟伅鐨勭壒鏁�
+            this.ShowHadNewMessageAppeal();
         }
 
         /// <summary>
@@ -130,5 +384,204 @@
         }
 
         #endregion
+
+        #region 鈻� 閫昏緫瑙﹀彂涓婃姤_______________________
+
+        /// <summary>
+        /// 閫昏緫瑙﹀彂涓婃姤
+        /// </summary>
+        /// <param name="receiveData"></param>
+        private void LogicExecutePush(JObject receiveData)
+        {
+            //鐩墠涓嶅鐞嗛�昏緫涓婃姤鍐呭
+
+            //鏄剧ず鏈夋柊娑堟伅鐨勭壒鏁�
+            this.ShowHadNewMessageAppeal();
+        }
+
+        #endregion
+
+        #region 鈻� 鍦烘櫙瑙﹀彂涓婃姤_______________________
+
+        /// <summary>
+        /// 鍦烘櫙瑙﹀彂涓婃姤
+        /// </summary>
+        /// <param name="receiveData"></param>
+        private void SceneExecPush(JObject receiveData)
+        {
+            //鐩墠涓嶅鐞嗗満鏅笂鎶ュ唴瀹�
+
+            //鏄剧ず鏈夋柊娑堟伅鐨勭壒鏁�
+            this.ShowHadNewMessageAppeal();
+        }
+
+        #endregion
+
+
+
+        #region 鈻� 娣诲姞璁惧浜嬩欢_______________________
+
+        /// <summary>
+        /// 娣诲姞鑾峰彇璁惧灞炴�х殑浜嬩欢(鎺ㄩ�佸凡缁忓己鍒舵寚瀹氳繍琛屼簬涓荤嚎绋嬶紝灞炴�т笂鎶ョ殑瀵硅薄锛歞evice.DeviceStatusReport)
+        /// </summary>
+        /// <param name="mainKeys">鏍囪瘑浜嬩欢鐨勪富閿�(鍙互闅忎究濉�,涓昏鏄拡瀵瑰涓晫闈竴璧蜂娇鐢ㄧ殑鎯呭喌)</param>
+        /// <param name="comand">鍛戒护鍖哄垎</param>
+        /// <param name="action">
+        /// <para>褰撴帴鏀跺埌缃戝叧鍥炲涔嬪悗鐨勫洖璋冨嚱鏁�</para>
+        /// <para>璁惧灞炴�т笂鎶ョ殑瀵硅薄锛歞evice.DeviceStatusReport</para>
+        /// <para>浼犳劅鍣ㄤ笂鎶ョ殑瀵硅薄锛歩as.iASInfo</para>
+        /// <para>璁惧鍦ㄧ嚎涓婃姤鐨勫璞★細device.IsOnline</para></param>
+        public void AddAttributeEvent(string mainKeys, ReceiveComandDiv comand, Action<CommonDevice> action)
+        {
+            lock (this.dicDeviceEvent)
+            {
+                if (this.dicDeviceEvent.ContainsKey(mainKeys) == true)
+                {
+                    this.RemoveEvent(mainKeys);
+                }
+                this.dicDeviceEvent[mainKeys] = action;
+                this.dicCommandDiv[mainKeys] = comand;
+            }
+        }
+
+        #endregion
+
+        #region 鈻� 绉婚櫎璁惧鐩戝惉_______________________
+
+        /// <summary>
+        /// 绉婚櫎浜嬩欢
+        /// </summary>
+        /// <param name="mainKeys">鏍囪瘑浜嬩欢鐨勪富閿�(鍙互闅忎究濉�,涓昏鏄拡瀵瑰涓晫闈竴璧蜂娇鐢ㄧ殑鎯呭喌)</param>
+        public void RemoveEvent(string mainKeys)
+        {
+            lock (this.dicDeviceEvent)
+            {
+                if (this.dicDeviceEvent.ContainsKey(mainKeys) == true)
+                {
+                    var action = this.dicDeviceEvent[mainKeys];
+                    this.dicDeviceEvent.Remove(mainKeys);
+                    this.dicCommandDiv.Remove(mainKeys);
+
+                    action = null;
+                }
+            }
+        }
+
+        /// <summary>
+        /// 绉婚櫎鍏ㄩ儴鐨勪簨浠�
+        /// </summary>
+        public void RemoveAllEvent()
+        {
+            lock (this.dicDeviceEvent)
+            {
+                var list = new HashSet<string>();
+                foreach (var keys in this.dicDeviceEvent.Keys)
+                {
+                    list.Add(keys);
+                }
+                foreach (var keys in list)
+                {
+                    //闇�瑕佹參鎱竴涓竴涓殑閲婃斁Action,鍚
+                    this.RemoveEvent(keys);
+                }
+            }
+        }
+
+        #endregion
+
+        #region 鈻� 涓�鑸柟娉昣__________________________
+
+        /// <summary>
+        /// 璁惧涓婃姤鎺ㄩ��
+        /// </summary>
+        /// <param name="common"></param>
+        /// <param name="comand"></param>
+        private void DeviceReportPush(CommonDevice common, ReceiveComandDiv comand)
+        {
+            if (this.dicDeviceEvent.Count == 0)
+            {
+                //娌℃湁娣诲姞鐩戝惉
+                return;
+            }
+            lock (this.dicDeviceEvent)
+            {
+                var list = new List<Action<CommonDevice>>();
+                foreach (string keys in this.dicDeviceEvent.Keys)
+                {
+                    if (this.dicCommandDiv[keys] != comand)
+                    {
+                        //鍛戒护鍖哄垎涓嶄竴鑷达紝鍒欎笉璋冪敤鍥炶皟鍑芥暟
+                        continue;
+                    }
+                    //鍛戒护鍖哄垎涓�鑷存椂锛屽垯璋冪敤鍥炶皟鍑芥暟
+                    list.Add(this.dicDeviceEvent[keys]);
+                }
+                //鏈夊彲鑳藉湪鍥炶皟鍑芥暟涓Щ闄や簡浜嬩欢锛屽鑷存姤閿欙紝鎵�浠ュ厛鏀堕泦锛屽啀璋冪敤
+                foreach (var action in list)
+                {
+                    try
+                    {
+                        action?.Invoke(common);
+                    }
+                    catch (Exception ex)
+                    {
+                        //Log鍑哄姏
+                        string msg = "鎺ㄩ�侀敊璇�! 褰撳墠婵�娲荤殑鐣岄潰[" + UserCenterResourse.NowActionFormID + "]";
+                        HdlLogLogic.Current.WriteLog(ex, msg);
+                    }
+                }
+            }
+        }
+
+        /// <summary>
+        /// 鏄惁瀛樺湪鎸囧畾鐨勪簨浠�
+        /// </summary>
+        /// <param name="mainkeys"></param>
+        /// <returns></returns>
+        public bool IsEsixt(string mainkeys)
+        {
+            return this.dicCommandDiv.ContainsKey(mainkeys);
+        }
+
+        /// <summary>
+        /// 鏄剧ず鏈夋柊娑堟伅鐨勭壒鏁�
+        /// </summary>
+        private void ShowHadNewMessageAppeal()
+        {
+            //鏈夋柊娑堟伅(鐗规晥杩樺湪鏃�,涓嶉渶瑕佸啀澶勭悊)
+            if (ControlCommonResourse.HadNewMessage == false)
+            {
+                HdlThreadLogic.Current.RunMain(() =>
+                {
+                    for (int i = 0; i < ControlCommonResourse.listMessageManaContr.Count; i++)
+                    {
+                        //鏄剧ず瑙掓爣鐗规晥
+                        ControlCommonResourse.listMessageManaContr[i].IsSelected = true;
+                    }
+                    ControlCommonResourse.HadNewMessage = true;
+                });
+            }
+        }
+
+        #endregion
+    }
+
+    /// <summary>
+    /// 鎺ユ敹鍛戒护鍖哄垎
+    /// </summary>
+    public enum ReceiveComandDiv
+    {
+        /// <summary>
+        /// 璁惧灞炴�т笂鎶�
+        /// </summary>
+        A璁惧灞炴�т笂鎶� = 1,
+        /// <summary>
+        /// 浼犳劅鍣ㄤ笂鎶�
+        /// </summary>
+        A浼犳劅鍣ㄤ笂鎶� = 2,
+        /// <summary>
+        /// 璁惧鍦ㄧ嚎涓婃姤
+        /// </summary>
+        A璁惧鍦ㄧ嚎涓婃姤 = 3
     }
 }

--
Gitblit v1.8.0