From dee21bf452a8979d0515d13e534fbb69ed9715dd Mon Sep 17 00:00:00 2001
From: 黄学彪 <hxb@hdlchina.com.cn>
Date: 星期二, 01 九月 2020 15:33:13 +0800
Subject: [PATCH] 上传一个版本

---
 ZigbeeApp/Shared/Phone/Device/Logic/Send.cs |   76 ++++++++++++++++++++++++--------------
 1 files changed, 48 insertions(+), 28 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/Device/Logic/Send.cs b/ZigbeeApp/Shared/Phone/Device/Logic/Send.cs
index 04d882d..1f50bbe 100755
--- a/ZigbeeApp/Shared/Phone/Device/Logic/Send.cs
+++ b/ZigbeeApp/Shared/Phone/Device/Logic/Send.cs
@@ -12,6 +12,7 @@
 {
     public class Send
     {
+       
         #region  ----Logic鎵�鏈夊彂閫佸懡浠�
         /// <summary>
         /// 鑾峰彇LogicId鐨勬柟娉�
@@ -22,7 +23,9 @@
             return await System.Threading.Tasks.Task.Run(async () =>
             {
                 List<int> logicIdList = new List<int>();
-                
+
+                bool if_theme = false;
+                int if_number = -1;
                 Action<string, string> action = (topic, data) =>
                 {
                     var gatewayID = topic.Split('/')[0];
@@ -34,19 +37,19 @@
                     
                     if (topic == $"{gatewayID}/Logic/GetLogicList_Respon")
                     {
-
-                        var list = jObjectdata["Data"]["LogicList"];
-                        if (list == null)
+                        if_theme = true;
+                        var list = Newtonsoft.Json.JsonConvert.DeserializeObject<List<Dictionary<string, string>>>(jObjectdata["Data"]["LogicList"].ToString());
+                        if_number = list.Count;
+                        if (list.Count == 0)
                         {
                             return;
                         }
                         foreach (var listIfon in list)
                         {
-                            var logicId = int.Parse(listIfon["LogicId"].ToString());
+                            var logicId = int.Parse(listIfon["LogicId"]);
                             logicIdList.Add(logicId);
                            
                         }
-
                     }
                 };
                 var mainGateWay = ZbGateway.MainGateWay;
@@ -72,9 +75,13 @@
                 while ((DateTime.Now - dateTime).TotalMilliseconds < 3 * 1000)
                 {
                     await System.Threading.Tasks.Task.Delay(100);
-                    if (logicIdList.Count != 0)
+                    if (if_theme)
                     {
-                        break;
+                        if (if_number == 0 || if_number == logicIdList.Count)
+                        {
+                            break;//鍥炲娌℃湁鏁版嵁绔嬪埢杩斿洖
+                        }
+
                     }
                 }
                 ZbGateway.MainGateWay.GwResDataAction -= action;
@@ -103,7 +110,6 @@
 
                     if (topic == $"{gatewayID}/Logic/GetLogicInfo_Respon")
                     {
-
                         logic = new Common.Logic();
                         var Logicifon = jObjectdata["Data"];
                         logic.LogicId = int.Parse(Logicifon["LogicId"]?.ToString());
@@ -248,7 +254,6 @@
                     {
                         try
                         {
-                            Logicifon = new Common.Logic();
                             Logicifon = Newtonsoft.Json.JsonConvert.DeserializeObject<Common.Logic>(jObjectdata["Data"].ToString());
                         }
                         catch (Exception ex)
@@ -652,7 +657,6 @@
             {
 
                 var listLogic = new List<Common.Logic>();
-                // bool @bool = false;
                 Action<string, string> action = (topic, data) =>
                 {
                     var gatewayID = topic.Split('/')[0];
@@ -664,7 +668,6 @@
 
                     if (topic == $"{gatewayID}/Logic/GetAllLogicListInfo_Respon")
                     {
-
                         var logic = new Common.Logic();
                         var Logicifon = jObjectdata["Data"];
                         logic.LogicId = int.Parse(Logicifon["LogicId"].ToString());
@@ -723,10 +726,7 @@
                         }
 
                     }
-                    //if (topic == $"{gatewayID}/Logic/AllLogicNum_Respon")
-                    //{
-                    //    @bool = true;
-                    //}
+                  
                 };
                 var mainGateWay = ZbGateway.MainGateWay;
                 if (mainGateWay == null)
@@ -751,10 +751,6 @@
                     {
                         break;
                     }
-                    //if (@bool)
-                    //{
-                    //    break;
-                    //}
                 }
                 ZbGateway.MainGateWay.GwResDataAction -= action;
                 return listLogic;
@@ -804,7 +800,7 @@
                 while ((DateTime.Now - dateTime).TotalMilliseconds < 3 * 1000)
                 {
                     await System.Threading.Tasks.Task.Delay(100);
-                    if (sceneui != null)
+                    if (sceneui != null && sceneui.Id > 0)
                     {
                         break;
                     }
@@ -1324,6 +1320,23 @@
 
         #region  瀛樺彇鏈湴鏂囦欢鐨勬柟娉� ---鏆傛椂涓嶇敤鍚堝苟璇ユ柟娉�---
         /// <summary>
+        /// 鍒ゆ柇鏄惁寮�鍚疓PS鏈嶅姟
+        /// </summary>
+        public static string If_Exist
+        {
+            get
+            {
+                string value = ReadLocalFile(Config.Instance.HomeId+"_GPS_File");
+                //璇诲彇鏈湴GPS鏈嶅姟鐘舵��
+                if (value == "0"||string.IsNullOrEmpty(value))
+                {
+                    return "0";
+                }
+                return "1";
+            }
+
+        }
+        /// <summary>
         /// 鏂囦欢淇濆瓨
         /// </summary>
         /// <param name="FileName">鏂囦欢璺緞</param>
@@ -1337,7 +1350,19 @@
             //鍐欏叆鏁版嵁锛�
             Shared.IO.FileUtils.WriteFileByBytes(FileName, byteData);
         }
-
+        /// <summary>
+        /// 鏂囦欢淇濆瓨
+        /// </summary>
+        /// <param name="FileName">鏂囦欢璺緞</param>
+        /// <param name="data">瀛楃涓�</param>
+        public static void SaveLocalFile(string FileName, string data)
+        {
+            //鍏堝簭鍒楀寲鏁版嵁锛�
+            //鏁版嵁杞崲涓哄瓧鑺傛祦锛�
+            var byteData = System.Text.Encoding.UTF8.GetBytes(data);
+            //鍐欏叆鏁版嵁锛�
+            Shared.IO.FileUtils.WriteFileByBytes(FileName, byteData);
+        }
         /// <summary>
         /// 鏂囦欢璇诲彇
         /// </summary>
@@ -1345,11 +1370,6 @@
         /// <returns></returns>
         public static string ReadLocalFile(string FileName)
         {
-            if (System.IO.File.Exists(FileName) == false)
-            {
-                ///鍒ゆ柇鏄惁鏈夋枃浠�;
-                return null;
-            }
             //璇诲嚭淇濆瓨璇ヨ矾寰勭殑鏂囦欢锛�
             var varByte = Shared.IO.FileUtils.ReadFile(FileName);
             //瀛楄妭娴佽浆鎹负瀛楃涓诧紱
@@ -1372,6 +1392,6 @@
             deviceConditionsInfo.Add(Key, Value);
         }
 
-      
+       
     }
 }

--
Gitblit v1.8.0