From f534d41c36d5895322bf691784a10435b64609fe Mon Sep 17 00:00:00 2001
From: wei <kaede@kaededeMacBook-Air.local>
Date: 星期五, 25 十二月 2020 13:52:00 +0800
Subject: [PATCH] 修复添加、删除楼层时候,界面刷新异常问题

---
 HDL_ON/UI/MainPage.cs |  154 ++++++++++++++++++++++++++-------------------------
 1 files changed, 79 insertions(+), 75 deletions(-)

diff --git a/HDL_ON/UI/MainPage.cs b/HDL_ON/UI/MainPage.cs
index 51f1f50..ff4f6b3 100644
--- a/HDL_ON/UI/MainPage.cs
+++ b/HDL_ON/UI/MainPage.cs
@@ -26,7 +26,7 @@
         /// <summary>
         /// 鐗堟湰鍙�
         /// </summary>
-        public static string VersionString = "1.0.0924";
+        public static string VersionString = "1.0.1225";
         ///// <summary>
         ///// 瀹㈡埛绔被鍨�
         ///// </summary>
@@ -44,15 +44,19 @@
         /// 鏃犵櫥褰曟ā寮�
         /// </summary>
         public static bool NoLoginMode = false;
-        /// <summary>
-        /// 杩滅▼妯″紡
-        /// </summary>
-        public static bool IsRemote = false;
+        ///// <summary>
+        ///// 杩滅▼妯″紡
+        ///// </summary>
+        //public static bool IsRemote = false;
         /// <summary>
         /// 缃戠粶杩炴帴鐘舵��
         /// 0:鏃犵綉缁�
         /// </summary>
         public static int InternetStatus = 2;
+        /// <summary>
+        /// 鏄惁杩涘叆鍚庡彴
+        /// </summary>
+        public static bool IsEnterBackground = false;
 
         ///// <summary>
         ///// 鍏徃浠g爜
@@ -105,16 +109,17 @@
                     }
                     else
                     {
-                        new System.Threading.Thread(() =>
-                        {
-                            var pm = new DAL.Server.HttpServerRequest();
-                            pm.RefreshToken();//鍒锋柊Token
-                            pm.GetHomePager();//鍒锋柊浣忓畢淇℃伅
-                            pm.GetUserInfo();//鍒锋柊涓汉淇℃伅
-                        })
-                        { IsBackground = true }.Start();
+                        //new System.Threading.Thread(() =>
+                        //{
+                        //    var pm = new DAL.Server.HttpServerRequest();
+                        //    pm.RefreshToken();//鍒锋柊Token
+                        //    pm.GetHomePager();//鍒锋柊浣忓畢淇℃伅
+                        //    pm.GetUserInfo();//鍒锋柊涓汉淇℃伅
+                        //})
+                        //{ IsBackground = true }.Start();
+                        Common.ApiUtlis.Ins.DownloadData();
 
-                        GoUserPage(true);
+                        GoUserPage(false,true);
                     }
                 }
             }
@@ -147,42 +152,30 @@
         /// 杩涘叆涓婚〉
         /// </summary>
         /// <param name="isFirstOpen">濡傛灉鏄涓�娆″惎鍔� 妫�娴嬫牎楠屽瘑鐮�</param>
-        public static void GoUserPage(bool isFirstOpen = false)
+        /// <param name="pageShowEvent">涓婚〉鏄剧ず涔嬪悗瑙﹀彂鐨勪簨浠�(娌℃湁浣忓畢鐨勮瘽,鍒欎笉浼氳Е鍙�)</param>
+        public static void GoUserPage(bool downloadData , bool isFirstOpen = false, Action pageShowEvent = null)
         {
             //鍔犺浇Loading鏁堟灉
             var waitPage = new Loading();
             BaseView.AddChidren(waitPage);
             waitPage.Start(Language.StringByID(StringId.PleaseWait));
+
+            //褰撴病鏈変綇瀹呮椂,涓嶈兘璁╁畠寰�涓嬭蛋
+            if (UserInfo.Current.regionList.Count == 0)
+            {
+                waitPage.Hide();
+                var addResidencePage = new BindingResidencePage();
+                BaseView.AddChidren(addResidencePage);
+                addResidencePage.LoadView();
+                return;
+            }
+
             new System.Threading.Thread(() =>
             {
                 try
                 {
-                    if (UserInfo.Current.regionList.Count == 0)
-                    {
-                        bool loadPage = true;
-                        var pm = new DAL.Server.HttpServerRequest();
-                        while (UserInfo.Current.regionList.Count == 0)
-                        {
-                            pm.GetHomePager();//鍒锋柊浣忓畢淇℃伅
-                            System.Threading.Thread.Sleep(2000);
-                            if (loadPage)
-                            {
-                                loadPage = false;
-                                Application.RunOnMainThread(() =>
-                                {
-                                    waitPage.Hide();
-                                    var addResidencePage = new BindingResidencePage();
-                                    BaseView.AddChidren(addResidencePage);
-                                    addResidencePage.LoadView();
-                                });
-                            }
-                        }
-                    }
-                    else
-                    {
-                        Entity.FunctionList.List.Clear();
-                        Entity.SpatialInfo.CurrentSpatial.Clear();
-                    }
+                    Entity.FunctionList.List.Clear();
+                    Entity.SpatialInfo.CurrentSpatial.Clear();
                     ///绛夊緟鑾峰彇浣忓畢淇℃伅
                     Application.RunOnMainThread(() =>
                     {
@@ -224,6 +217,9 @@
                             //鍚姩瀵嗙爜楠岃瘉
                             new AppUnlockPage().LoadPage(isFirstOpen);
                         }
+                        //涓婚〉鍔犺浇瀹屾垚,鍥炶皟浜嬩欢
+                        pageShowEvent?.Invoke();
+                        pageShowEvent = null;
                     });
                 }
                 catch (Exception ex)
@@ -231,8 +227,14 @@
                     MainPage.Log($"GoUserPage : {ex.Message}");
                 }finally
                 {
-                    ///鍒濆鍖朼pp鏁版嵁
-                    InitializationData();
+                    Application.RunOnMainThread(() =>
+                    {
+                        if (downloadData)
+                        {
+                            ///鍒濆鍖朼pp鏁版嵁
+                            Common.ApiUtlis.Ins.DownloadData();
+                        };
+                    });
                 }
             }).Start();
         }
@@ -240,41 +242,43 @@
         /// <summary>
         /// 鍒濆鍖朼pp鎵�闇�瑕佺殑鏁版嵁
         /// </summary>
-        public static void InitializationData()
+        public static void InitializationData1()
         {
-            new System.Threading.Thread(() =>
-            {
-                while (true)
-                {
-                    if (Entity.DB_ResidenceData.Instance == null )//|| Entity.DB_ResidenceData.residenceData.HomeGateway == null)
-                    {
-                        System.Threading.Thread.Sleep(100);
-                    }
-                    else
-                    {
-                        break;
-                    }
-                }
-                //System.Threading.Thread.Sleep(2000);
-                #region 璇诲彇浜戠鏁版嵁--
-                //todo鏁版嵁瑕嗙洊澶勭悊
-                //璇诲彇浜戠鎴块棿銆佹ゼ灞傛暟鎹�
-                Entity.SpatialInfo.CurrentSpatial.DownloadRoomList();
-                //璇诲彇浜戠璁惧鏁版嵁
-                Entity.FunctionList.List.DownloadFunctionList();
-                //璇诲彇浜戠鍦烘櫙鏁版嵁
-                Entity.FunctionList.List.DownloadSceneList();
-                #endregion
+            //new System.Threading.Thread(() =>
+            //{
+            //    int count = 0;
+            //    while (count< 10)
+            //    {
+            //        if (Entity.DB_ResidenceData.Instance.CheckWhetherGatewayIdIsNull() )//|| Entity.DB_ResidenceData.residenceData.HomeGateway == null)
+            //        {
+            //            System.Threading.Thread.Sleep(200);
+            //        }
+            //        else
+            //        {
+            //            break;
+            //        }
+            //        count++;
+            //    }
+            //    if(Entity.DB_ResidenceData.Instance.CheckWhetherGatewayIdIsNull())
+            //    {
+            //        return;
+            //    }
+            //    //System.Threading.Thread.Sleep(2000);
+            //    #region 璇诲彇浜戠鏁版嵁--
+            //    //todo鏁版嵁瑕嗙洊澶勭悊
+            //    //璇诲彇浜戠鎴块棿銆佹ゼ灞傛暟鎹�
+            //    Entity.SpatialInfo.CurrentSpatial.DownloadRoomList();
+            //    //璇诲彇浜戠璁惧鏁版嵁
+            //    Entity.FunctionList.List.DownloadFunctionList();
+            //    //璇诲彇浜戠鍦烘櫙鏁版嵁
+            //    Entity.FunctionList.List.DownloadSceneList();
+            //    //璇诲彇閫昏緫鍒楄〃
+            //    UI.UI2.Intelligence.Automation.MainView.GetLogicList();
+            //    #endregion
 
-            })
-            { IsBackground = true }.Start();
+            //})
+            //{ IsBackground = true }.Start();
 
-            #region 璇诲彇鏈湴鏁版嵁
-            //璇诲彇闊充箰淇℃伅
-            UI.Music.A31MusicModel.ReadMusicStates();
-            //鎼滅储缃戝叧
-            DriverLayer.Control.Ins.SearchLoaclGateway();
-            #endregion
         }
 
         /// <summary>

--
Gitblit v1.8.0