From 320d7cc8feb394d0ce3db2ec1d01593b554d990f Mon Sep 17 00:00:00 2001
From: JLChen <551775569@qq.com>
Date: 星期三, 23 十二月 2020 10:57:13 +0800
Subject: [PATCH] 2020-12-23 1.更新

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

diff --git a/HDL_ON/UI/MainPage.cs b/HDL_ON/UI/MainPage.cs
index ea844b8..b834063 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.1220";
         ///// <summary>
         ///// 瀹㈡埛绔被鍨�
         ///// </summary>
@@ -44,10 +44,19 @@
         /// 鏃犵櫥褰曟ā寮�
         /// </summary>
         public static bool NoLoginMode = false;
+        ///// <summary>
+        ///// 杩滅▼妯″紡
+        ///// </summary>
+        //public static bool IsRemote = false;
         /// <summary>
-        /// 杩滅▼妯″紡
+        /// 缃戠粶杩炴帴鐘舵��
+        /// 0:鏃犵綉缁�
         /// </summary>
-        public static bool IsRemote = false;
+        public static int InternetStatus = 2;
+        /// <summary>
+        /// 鏄惁杩涘叆鍚庡彴
+        /// </summary>
+        public static bool IsEnterBackground = false;
 
         ///// <summary>
         ///// 鍏徃浠g爜
@@ -86,32 +95,32 @@
                 BaseView = Application.MainPage;
                 Application.MainPage.BackgroundColor = CSS_Color.MainBackgroundColor;
 
-                //LoginUser = Newtonsoft.Json.JsonConvert.DeserializeObject<UserInfo>(System.Text.Encoding.UTF8.GetString(FileUtils.ReadFile("UserInfo_File")));
-                //鍒ゆ柇闇�涓嶉渶瑕佺櫥褰曪紝鏈夋病鏈夌櫥褰曪紝鎴栬�呯櫥褰曟槸鍚﹁繃鏈燂紝
-                if (UserInfo.Current == null || !UserInfo.Current.IsLogin)
+
+                if (string.IsNullOrEmpty(OnAppConfig.Instance.LastLoginUserId))
                 {
-                    GoLoginPage(UserInfo.Current);
+                    GoLoginPage();
                 }
                 else
                 {
-                    new System.Threading.Thread(() =>
+                    //鍒ゆ柇闇�涓嶉渶瑕佺櫥褰曪紝鏈夋病鏈夌櫥褰曪紝鎴栬�呯櫥褰曟槸鍚﹁繃鏈燂紝
+                    if (UserInfo.Current == null || !UserInfo.Current.IsLogin)
                     {
-                        var pm = new DAL.Server.HttpServerRequest();
-                        pm.RefreshToken();//鍒锋柊Token
-                        pm.GetHomePager();//鍒锋柊浣忓畢淇℃伅
-                        pm.GetUserInfo();//鍒锋柊涓汉淇℃伅
-                    })
-                    { IsBackground = true }.Start();
-                    
-                    GoUserPage();
-                    //鍚姩瀵嗙爜楠岃瘉
-                    new AppUnlockPage().LoadPage();
+                        GoLoginPage(UserInfo.Current);
+                    }
+                    else
+                    {
+                        new System.Threading.Thread(() =>
+                        {
+                            var pm = new DAL.Server.HttpServerRequest();
+                            pm.RefreshToken();//鍒锋柊Token
+                            pm.GetHomePager();//鍒锋柊浣忓畢淇℃伅
+                            pm.GetUserInfo();//鍒锋柊涓汉淇℃伅
+                        })
+                        { IsBackground = true }.Start();
 
-                    ///鍒濆鍖朼pp鏁版嵁
-                    InitializationData();
+                        GoUserPage(true);
+                    }
                 }
-
-
             }
             catch (Exception ex)
             {
@@ -141,71 +150,85 @@
         /// <summary>
         /// 杩涘叆涓婚〉
         /// </summary>
-        public static void GoUserPage()
+        /// <param name="isFirstOpen">濡傛灉鏄涓�娆″惎鍔� 妫�娴嬫牎楠屽瘑鐮�</param>
+        /// <param name="pageShowEvent">涓婚〉鏄剧ず涔嬪悗瑙﹀彂鐨勪簨浠�(娌℃湁浣忓畢鐨勮瘽,鍒欎笉浼氳Е鍙�)</param>
+        public static void GoUserPage(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(() =>
             {
-                if (UserInfo.Current.regionList.Count == 0)
+                try
                 {
-                    bool loadPage = true;
-                    var pm = new DAL.Server.HttpServerRequest();
-                    while (UserInfo.Current.regionList.Count == 0)
+                    Entity.FunctionList.List.Clear();
+                    Entity.SpatialInfo.CurrentSpatial.Clear();
+                    ///绛夊緟鑾峰彇浣忓畢淇℃伅
+                    Application.RunOnMainThread(() =>
                     {
-                        pm.GetHomePager();//鍒锋柊浣忓畢淇℃伅
-                        System.Threading.Thread.Sleep(1000);
-                        if (loadPage)
-                        {
-                            loadPage = false;
-                            Application.RunOnMainThread(() =>
-                            {
-                                waitPage.Hide();
-                                var addResidencePage = new BindingResidencePage();
-                                BaseView.AddChidren(addResidencePage);
-                                addResidencePage.LoadDialog();
-                            });
-                        }
-                    }
-                }
-                ///绛夊緟鑾峰彇浣忓畢淇℃伅
-                Application.RunOnMainThread(() =>
-                {
-                    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) =>
-                    {
+                        waitPage.Hide();
+                        BaseView.RemoveAll();
+                        BasePageView = new PageLayout();
                         BasePageView.ScrollEnabled = false;
-                    };
-                    BaseView.AddChidren(BasePageView);
+                        BasePageView.IsShowPoint = false;
+                        BasePageView.PageChange = (sender, e) =>
+                        {
+                            if (e < BasePageView.ChildrenCount - 1)
+                            {
+                                MainPage.BasePageView.GetChildren(MainPage.BasePageView.ChildrenCount - 1).RemoveFromParent();
+                            }
 
-                    //璺宠浆椤甸潰----
-                    var userPage = new UserPage();
-                    BasePageView.AddChidren(userPage);
-                    userPage.LoadPage();
-                    BasePageView.PageIndex = 0;
-                });
+                            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;
+
+                        if (isFirstOpen)
+                        {
+                            //鍚姩瀵嗙爜楠岃瘉
+                            new AppUnlockPage().LoadPage(isFirstOpen);
+                        }
+                        //涓婚〉鍔犺浇瀹屾垚,鍥炶皟浜嬩欢
+                        pageShowEvent?.Invoke();
+                        pageShowEvent = null;
+                    });
+                }
+                catch (Exception ex)
+                {
+                    MainPage.Log($"GoUserPage : {ex.Message}");
+                }finally
+                {
+                    ///鍒濆鍖朼pp鏁版嵁
+                    InitializationData();
+                }
             }).Start();
         }
 
@@ -218,8 +241,7 @@
             {
                 while (true)
                 {
-                    if (Entity.DB_ResidenceData.residenceData == null ||
-                    Entity.DB_ResidenceData.residenceData.HomeGateway == null)
+                    if (Entity.DB_ResidenceData.Instance == null )//|| Entity.DB_ResidenceData.residenceData.HomeGateway == null)
                     {
                         System.Threading.Thread.Sleep(100);
                     }
@@ -228,6 +250,7 @@
                         break;
                     }
                 }
+                //System.Threading.Thread.Sleep(2000);
                 #region 璇诲彇浜戠鏁版嵁--
                 //todo鏁版嵁瑕嗙洊澶勭悊
                 //璇诲彇浜戠鎴块棿銆佹ゼ灞傛暟鎹�
@@ -236,6 +259,8 @@
                 Entity.FunctionList.List.DownloadFunctionList();
                 //璇诲彇浜戠鍦烘櫙鏁版嵁
                 Entity.FunctionList.List.DownloadSceneList();
+                //璇诲彇閫昏緫鍒楄〃
+                UI.UI2.Intelligence.Automation.MainView.GetLogicList();
                 #endregion
 
             })

--
Gitblit v1.8.0