From 1bb8683aef25143048e572b65734de4772bfc712 Mon Sep 17 00:00:00 2001
From: wxr <464027401@qq.com>
Date: 星期五, 11 十二月 2020 10:48:17 +0800
Subject: [PATCH] Merge branch 'CJL-NEW'

---
 HDL_ON/UI/MainPage.cs |  161 ++++++++++++++++++++++++++++++++++-------------------
 1 files changed, 103 insertions(+), 58 deletions(-)

diff --git a/HDL_ON/UI/MainPage.cs b/HDL_ON/UI/MainPage.cs
index 4d6eb1a..ea844b8 100644
--- a/HDL_ON/UI/MainPage.cs
+++ b/HDL_ON/UI/MainPage.cs
@@ -99,11 +99,6 @@
                         var pm = new DAL.Server.HttpServerRequest();
                         pm.RefreshToken();//鍒锋柊Token
                         pm.GetHomePager();//鍒锋柊浣忓畢淇℃伅
-                    })
-                    { IsBackground = true }.Start();
-                    new System.Threading.Thread(() =>
-                    {
-                        var pm =new DAL.Server.HttpServerRequest();
                         pm.GetUserInfo();//鍒锋柊涓汉淇℃伅
                     })
                     { IsBackground = true }.Start();
@@ -111,18 +106,12 @@
                     GoUserPage();
                     //鍚姩瀵嗙爜楠岃瘉
                     new AppUnlockPage().LoadPage();
-                    //璇诲彇闊充箰淇℃伅
-                    UI.Music.A31MusicModel.ReadMusicStates();
-                    //鎼滅储缃戝叧
 
-#if DEBUG
-                    //Entity.DB_ResidenceData.residenceData.residenceGatewayMAC = "4E47323347591243";
-                    //Entity.DB_ResidenceData.residenceData.GatewayType = 0;
-                    Entity.DB_ResidenceData.residenceData.residenceGatewayMAC = "123456789AAAAAAA";
-                    Entity.DB_ResidenceData.residenceData.GatewayType = 1;
-#endif
-                    DriverLayer.Control.Ins.SearchLoaclGateway();
+                    ///鍒濆鍖朼pp鏁版嵁
+                    InitializationData();
                 }
+
+
             }
             catch (Exception ex)
             {
@@ -154,55 +143,111 @@
         /// </summary>
         public static void GoUserPage()
         {
-            BaseView.RemoveAll();
-            BasePageView = new PageLayout();
-            BasePageView.ScrollEnabled = false;
-            BasePageView.IsShowPoint = false;
-            BasePageView.PageChange = (sender, e) => {
-                if (e < BasePageView.ChildrenCount - 1)
+            //鍔犺浇Loading鏁堟灉
+            var waitPage = new Loading();
+            BaseView.AddChidren(waitPage);
+            waitPage.Start(Language.StringByID(StringId.PleaseWait));
+            new System.Threading.Thread(() =>
+            {
+                if (UserInfo.Current.regionList.Count == 0)
                 {
-                    MainPage.BasePageView.GetChildren(MainPage.BasePageView.ChildrenCount - 1).RemoveFromParent();
+                    bool loadPage = true;
+                    var pm = new DAL.Server.HttpServerRequest();
+                    while (UserInfo.Current.regionList.Count == 0)
+                    {
+                        pm.GetHomePager();//鍒锋柊浣忓畢淇℃伅
+                        System.Threading.Thread.Sleep(1000);
+                        if (loadPage)
+                        {
+                            loadPage = false;
+                            Application.RunOnMainThread(() =>
+                            {
+                                waitPage.Hide();
+                                var addResidencePage = new BindingResidencePage();
+                                BaseView.AddChidren(addResidencePage);
+                                addResidencePage.LoadDialog();
+                            });
+                        }
+                    }
                 }
-
-                while (e < BasePageView.ChildrenCount - 1)
+                ///绛夊緟鑾峰彇浣忓畢淇℃伅
+                Application.RunOnMainThread(() =>
                 {
-                    BasePageView.GetChildren(BasePageView.ChildrenCount - 1).RemoveFromParent();
+                    waitPage.Hide();
+                    BaseView.RemoveAll();
+                    BasePageView = new PageLayout();
+                    BasePageView.ScrollEnabled = false;
+                    BasePageView.IsShowPoint = false;
+                    BasePageView.PageChange = (sender, e) =>
+                    {
+                        if (e < BasePageView.ChildrenCount - 1)
+                        {
+                            MainPage.BasePageView.GetChildren(MainPage.BasePageView.ChildrenCount - 1).RemoveFromParent();
+                        }
+
+                        while (e < BasePageView.ChildrenCount - 1)
+                        {
+                            BasePageView.GetChildren(BasePageView.ChildrenCount - 1).RemoveFromParent();
+                        }
+                    };
+                    BasePageView.MouseDownEventHandler += (sender, e) =>
+                    {
+                        BasePageView.ScrollEnabled = true;
+                    };
+                    BasePageView.MouseUpEventHandler += (sender, e) =>
+                    {
+                        BasePageView.ScrollEnabled = false;
+                    };
+                    BaseView.AddChidren(BasePageView);
+
+                    //璺宠浆椤甸潰----
+                    var userPage = new UserPage();
+                    BasePageView.AddChidren(userPage);
+                    userPage.LoadPage();
+                    BasePageView.PageIndex = 0;
+                });
+            }).Start();
+        }
+
+        /// <summary>
+        /// 鍒濆鍖朼pp鎵�闇�瑕佺殑鏁版嵁
+        /// </summary>
+        public static void InitializationData()
+        {
+            new System.Threading.Thread(() =>
+            {
+                while (true)
+                {
+                    if (Entity.DB_ResidenceData.residenceData == null ||
+                    Entity.DB_ResidenceData.residenceData.HomeGateway == null)
+                    {
+                        System.Threading.Thread.Sleep(100);
+                    }
+                    else
+                    {
+                        break;
+                    }
                 }
-            };
-            BasePageView.MouseDownEventHandler += (sender, e) => {
-                BasePageView.ScrollEnabled = true;
-            };
-            BasePageView.MouseUpEventHandler += (sender, e) => {
-                BasePageView.ScrollEnabled = false;
-            };
-            BaseView.AddChidren(BasePageView);
+                #region 璇诲彇浜戠鏁版嵁--
+                //todo鏁版嵁瑕嗙洊澶勭悊
+                //璇诲彇浜戠鎴块棿銆佹ゼ灞傛暟鎹�
+                Entity.SpatialInfo.CurrentSpatial.DownloadRoomList();
+                //璇诲彇浜戠璁惧鏁版嵁
+                Entity.FunctionList.List.DownloadFunctionList();
+                //璇诲彇浜戠鍦烘櫙鏁版嵁
+                Entity.FunctionList.List.DownloadSceneList();
+                #endregion
 
-            //璺宠浆椤甸潰----
-            var userPage = new UserPage();
-            BasePageView.AddChidren(userPage);
-            userPage.LoadPage();
-            BasePageView.PageIndex = 0;
+            })
+            { IsBackground = true }.Start();
+
+            #region 璇诲彇鏈湴鏁版嵁
+            //璇诲彇闊充箰淇℃伅
+            UI.Music.A31MusicModel.ReadMusicStates();
+            //鎼滅储缃戝叧
+            DriverLayer.Control.Ins.SearchLoaclGateway();
+            #endregion
         }
-
-        public static void GetRoomList()
-        {
-            var pm = new DAL.Server.HttpServerRequest();
-            var packNew = pm.GetRoomList();//鍒锋柊鎴块棿鍒楄〃
-            var floorPack = pm.GetRoomList("FLOOR");
-            var rooms = Newtonsoft.Json.JsonConvert.DeserializeObject<Entity.RoomApiPack>(packNew.Data.ToString());
-            var floors = Newtonsoft.Json.JsonConvert.DeserializeObject<Entity.RoomApiPack>(packNew.Data.ToString());
-            MainPage.Log(packNew.Data.ToString());
-            MainPage.Log(floorPack.Data.ToString());
-        }
-
-        public static void GetDeviceList()
-        {
-            var pm = new DAL.Server.HttpServerRequest();
-            var packNew = pm.GetDeviceList();
-            var functions = Newtonsoft.Json.JsonConvert.DeserializeObject<Entity.DevcieApiPack>(packNew.Data.ToString());
-            MainPage.Log(packNew.Data.ToString());
-        }
-
 
         /// <summary>
         /// 鑷畾涔夋棩蹇楄緭鍑�

--
Gitblit v1.8.0