From 43b0d5870d528f23ecd6aeceb6cfd4325188b46f Mon Sep 17 00:00:00 2001
From: wxr <464027401@qq.com>
Date: 星期四, 01 七月 2021 15:50:43 +0800
Subject: [PATCH] Revert "1"

---
 HDL_ON/UI/MainPage.cs |  355 +++++++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 299 insertions(+), 56 deletions(-)

diff --git a/HDL_ON/UI/MainPage.cs b/HDL_ON/UI/MainPage.cs
index 8c87491..cc24670 100644
--- a/HDL_ON/UI/MainPage.cs
+++ b/HDL_ON/UI/MainPage.cs
@@ -9,32 +9,76 @@
 {
     public static class MainPage
     {
+        /// <summary>
+        /// BaseView
+        /// </summary>
         public static FrameLayout BaseView { get; internal set; }
+        /// <summary>
+        /// BasePageView
+        /// </summary>
         public static PageLayout BasePageView { get; set; }
+        /// <summary>
+        /// 鐢ㄦ埛鎺у埗鐖跺鍣�
+        /// </summary>
+        public static UserPage UserBasePage;
+        /// <summary>
+        /// 鐗堟湰鍙�
+        /// </summary>
+        public static string VersionString = "1.2.0629";
+        ///// <summary>
+        ///// 瀹㈡埛绔被鍨�
+        ///// </summary>
+        //public static string ClientType = APIClientType.HDL_ON_PRO.ToString();
 
-        public static bool DisplayCompleted = false;
-
-        public static UserInfo LoginUser;
-
-        public static string VersionString = "1.0103";
-
+        /// <summary>
+        /// 
+        /// </summary>
         public static Entity.CityInfo cityInfo = new Entity.CityInfo();
         /// <summary>
         /// 澶╂皵鍒锋柊action
         /// </summary>
         public static Action RefreshAir;
         /// <summary>
-        /// 鏈湴妯″紡
+        /// 鍥為��椤甸潰action 娌℃湁闇�瑕佸彲浠ヤ笉鐢�
         /// </summary>
-        public static bool LocalMode = false;
+        public static Action ReturnRefreshAction;
+        /// <summary>
+        /// 鏃犵櫥褰曟ā寮�
+        /// </summary>
+        public static bool NoLoginMode = false;
+        /// <summary>
+        /// 缃戠粶杩炴帴鐘舵��
+        /// 0:鏃犵綉缁�
+        /// </summary>
+        public static int InternetStatus = 2;
+        /// <summary>
+        /// 鏄惁杩涘叆鍚庡彴
+        /// </summary>
+        public static bool IsEnterBackground = false;
+        /// <summary>
+        /// 褰撳墠鍒嗛〉绱㈠紩
+        /// 0:鏀惰棌
+        /// 1:鍒嗙被
+        /// 2:鏅鸿兘
+        /// 3:涓汉
+        /// </summary>
+        public static int CurPageIndex = 9999;
+
+        ///// <summary>
+        ///// 鍏徃浠g爜
+        ///// 棰勭暀绗笁鏂瑰畾鍒舵爣璁�
+        ///// 0:HDL
+        ///// </summary>
+        //public static int Company = 0;
 
         /// <summary>
-        /// 鍏徃浠g爜
-        /// 棰勭暀绗笁鏂瑰畾鍒舵爣璁�
-        /// 0:HDL
+        /// 鍙虫粦鍚庨��鎻愮ず鎸夐挳
         /// </summary>
-        public static int Company = 0;
-
+        public static Button BtnBackIcon;
+        /// <summary>
+        /// 鍚庨��鍙虫粦浜嗗灏戣窛绂伙紝瓒呰繃涓�瀹氳窛绂绘墠瑙﹀彂鍚庨��浜嬩欢
+        /// </summary>
+        public static int StartX = 0;
         /// <summary>
         /// 鏄惁鍏ㄩ潰灞忔墜鏈�
         /// </summary>
@@ -62,40 +106,41 @@
                 Application.DesignWidth = 375;
                 Application.DesignHeight = 667;
 
-                BusSocket.Start(6000);
-                CommonPage.InitReceiveEvent();
-
                 BaseView = Application.MainPage;
                 Application.MainPage.BackgroundColor = CSS_Color.MainBackgroundColor;
 
-                LoginUser = Newtonsoft.Json.JsonConvert.DeserializeObject<UserInfo>(System.Text.Encoding.UTF8.GetString(FileUtils.ReadFile("Register_File")));
-                //鍒ゆ柇闇�涓嶉渶瑕佺櫥褰曪紝鏈夋病鏈夌櫥褰曪紝鎴栬�呯櫥褰曟槸鍚﹁繃鏈燂紝
-                if (LoginUser == null || !LoginUser.IsLogin)
+
+                //#region 娴嬭瘯
+                //var ddd = new UI.test.TestDialog();
+                //ddd.InitView();
+                //return;
+                //#endregion
+
+                if (string.IsNullOrEmpty(OnAppConfig.Instance.LastLoginUserId))
                 {
-                    GoLoginPage(LoginUser);
+                    GoLoginPage();
                 }
                 else
                 {
-                    new System.Threading.Thread(() =>
+                    //鍒ゆ柇闇�涓嶉渶瑕佺櫥褰曪紝鏈夋病鏈夌櫥褰曪紝鎴栬�呯櫥褰曟槸鍚﹁繃鏈燂紝
+                    if (UserInfo.Current == null || !UserInfo.Current.IsLogin)
                     {
-                        var pm =new DAL.Server.HttpServerRequest();
-                        pm.GetUserInfo();//鍒锋柊涓汉淇℃伅
-                    })
-                    { IsBackground = true }.Start();
-                    new System.Threading.Thread(() =>
+                        GoLoginPage(UserInfo.Current);
+                    }
+                    else
                     {
-                        var pm = new DAL.Server.HttpServerRequest();
-                        pm.GetHomePager();//鍒锋柊浣忓畢淇℃伅
-                    })
-                    { IsBackground = true }.Start();
-                    GoUserPage();
-                    //鍚姩瀵嗙爜楠岃瘉
-                    new AppUnlockPage().LoadPage();
-                    //璇诲彇闊充箰淇℃伅
-                    UI.Music.A31MusicModel.ReadMusicStates();
+                        //new System.Threading.Thread(() =>
+                        //{
+                        //    var pm = new DAL.Server.HttpServerRequest();
+                        //    pm.RefreshToken();//鍒锋柊Token
+                        //    pm.GetHomePager();//鍒锋柊浣忓畢淇℃伅
+                        //    pm.GetUserInfo();//鍒锋柊涓汉淇℃伅
+                        //})
+                        //{ IsBackground = true }.Start();
+                        Common.ApiUtlis.Ins.DownloadData();
 
-                    new HDL_ON.DAL.Net.TcpListener().OpenServer(8586);
-                    
+                        GoUserPage(false,true);
+                    }
                 }
             }
             catch (Exception ex)
@@ -104,13 +149,16 @@
             }
             finally
             {
+                //Application.RunOnMainThread(() => {
+                //    Application.HideSoftInput();
+                //});
             }
         }
 
         /// <summary>
         /// 杩涘叆鐧诲綍鐣岄潰
         /// </summary>
-        public static void GoLoginPage(UserInfo userInfo =null)
+        public static void GoLoginPage(UserInfo userInfo = null)
         {
             BaseView.RemoveAll();
             BaseView.BackgroundColor = CSS_Color.BackgroundColor;
@@ -123,37 +171,229 @@
         /// <summary>
         /// 杩涘叆涓婚〉
         /// </summary>
-        public static void GoUserPage()
+        /// <param name="isFirstOpen">濡傛灉鏄涓�娆″惎鍔� 妫�娴嬫牎楠屽瘑鐮�</param>
+        /// <param name="pageShowEvent">涓婚〉鏄剧ず涔嬪悗瑙﹀彂鐨勪簨浠�(娌℃湁浣忓畢鐨勮瘽,鍒欎笉浼氳Е鍙�)</param>
+        public static void GoUserPage(bool downloadData , bool isFirstOpen = false, Action pageShowEvent = null)
         {
             BaseView.RemoveAll();
+            #region 鍚庨��浜嬩欢
             BasePageView = new PageLayout();
             BasePageView.ScrollEnabled = false;
             BasePageView.IsShowPoint = false;
-            BasePageView.PageChange = (sender, e) => {
+            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;
+                try
+                {
+                    ReturnRefreshAction?.Invoke();
+                    ReturnRefreshAction = null;
+                }
+                catch (Exception ex)
+                {
+                    Log($"鍚庨��浜嬩欢寮傚父:{ex.Message}");
+                }
             };
             BaseView.AddChidren(BasePageView);
+            var backView = new FrameLayout()
+            {
+                Y = Application.GetRealHeight(100),
+                Width = Application.GetRealWidth(10),
+                Height = Application.GetRealHeight(440),
+            };
+            BaseView.AddChidren(backView);
 
-            //璺宠浆椤甸潰----
-            var userPage = new UserPage();
-            BasePageView.AddChidren(userPage);
-            userPage.LoadPage();
-            BasePageView.PageIndex = 0;
+            BtnBackIcon = new Button()
+            {
+                X = -Application.GetRealWidth(100),
+                Gravity = Gravity.CenterVertical,
+                Width = Application.GetRealWidth(88 / 2),
+                Height = Application.GetRealHeight(56 / 2),
+                UnSelectedImagePath = "Public/RightSlideBackIcon.png"
+            };
+            BaseView.AddChidren(BtnBackIcon);
+            backView.MouseMoveEventHandler = (sender, e) =>
+            {
+                if (BasePageView.ChildrenCount <= 1)
+                {
+                    return;
+                }
+                MainPage.Log($"move:{e.X}");
+                if (StartX == 0 && e.X < 30)
+                {
+                    StartX = (int)e.X;
+                }
+                if (StartX < 30)
+                {
+                    if (e.X < Application.GetRealWidth(100))
+                    {
+                        BtnBackIcon.X = (int)e.X - Application.GetRealWidth(100);
+                    }
+                }
+            };
+            backView.MouseDownEventHandler = (sender, e) =>
+            {
+                if (BasePageView.ChildrenCount <= 1)
+                {
+                    return;
+                }
+                MainPage.Log($"down:{e.X}");
+                StartX = (int)e.X;
+                BtnBackIcon.Y = (int)e.Y + Application.GetRealHeight(50);
+            };
+            backView.MouseUpEventHandler = (sender, e) => {
+                MainPage.Log($"up{e.X}");
+                StartX = 0;
+                BtnBackIcon.X = -Application.GetRealWidth(100);
+
+                if (e.X > 70)
+                {
+                    if (BasePageView.ChildrenCount > 1)
+                    {
+                        BasePageView.PageIndex = BasePageView.ChildrenCount - 2;
+                    }
+                }
+            };
+            backView.MouseUpOutsideEventHandler = (sender, e) => {
+                MainPage.Log($"up{e.X}");
+                StartX = 0;
+                BtnBackIcon.X = -Application.GetRealWidth(100);
+
+                if (e.X > 70)
+                {
+                    if (BasePageView.ChildrenCount > 1)
+                    {
+                        BasePageView.PageIndex = BasePageView.ChildrenCount - 2;
+                    }
+                }
+            };
+            #endregion
+
+
+            //浣撻獙妯″紡
+            if (NoLoginMode)
+            {
+                //璺宠浆椤甸潰----
+                UserBasePage = new UserPage();
+                BasePageView.AddChidren(UserBasePage);
+                UserBasePage.LoadPage();
+                BasePageView.PageIndex = 0;
+
+                return;
+            }
+
+            //鍔犺浇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(async () =>
+            {
+                try
+                {
+                    Entity.FunctionList.List.Clear();
+                    Entity.SpatialInfo.CurrentSpatial.Clear();
+                    ///绛夊緟鑾峰彇浣忓畢淇℃伅
+                    Application.RunOnMainThread( () =>
+                    {
+                        waitPage.Hide();
+                        waitPage.RemoveFromParent();
+
+                        //璺宠浆椤甸潰----
+                        UserBasePage = new UserPage();
+                        BasePageView.AddChidren(UserBasePage);
+                        UserBasePage.LoadPage();
+                        BasePageView.PageIndex = 0;
+
+                        if (isFirstOpen)
+                        {
+                            //鍚姩瀵嗙爜楠岃瘉
+                            new AppUnlockPage().LoadPage(isFirstOpen);
+                        }
+                        //涓婚〉鍔犺浇瀹屾垚,鍥炶皟浜嬩欢
+                        pageShowEvent?.Invoke();
+                        pageShowEvent = null;
+                    });
+                }
+                catch (Exception ex)
+                {
+                    MainPage.Log($"GoUserPage : {ex.Message}");
+                }finally
+                {
+                    Application.RunOnMainThread(() =>
+                    {
+                        if (downloadData)
+                        {
+                            ///鍒濆鍖朼pp鏁版嵁
+                            Common.ApiUtlis.Ins.DownloadData();
+                        };
+                    });
+                }
+            }).Start();
         }
+
+        /// <summary>
+        /// 鍚庨��浜嬩欢
+        /// 0:鍚庨��
+        /// 1:鏈夌瓑寰呯晫闈�
+        /// 2:鏃犳硶鍐嶅悗閫�锛屽彲浠ユ墽琛岄��鍒版闈�
+        /// </summary>
+        public static int LoadEvent_BackAction()
+        {
+            int result = 0;
+            Application.RunOnMainThread(() =>
+            {
+                if (BasePageView == null || BasePageView.ChildrenCount<=1 )
+                {
+                    result = 2;//鏃犳硶鍐嶅悗閫�锛屽彲浠ユ墽琛岄��鍒版闈�
+                }
+                if (BasePageView.ChildrenCount > 1)
+                {
+                    int index = BasePageView.ChildrenCount - 1;
+                    var view = BasePageView.GetChildren(index);
+                    if (view.GetType() == typeof(Loading))
+                    {
+                        var loading = view as Loading;
+                        if (loading.CurStatus == false)//鏈変竴浜涚瓑寰呯晫闈㈤殣钘忎簡锛屼絾鏄病鏈夌Щ闄ゅ埌锛岄渶瑕佸厛绉婚櫎
+                        {
+                            loading.RemoveFromParent();
+                            result = LoadEvent_BackAction();
+                        }
+                        else
+                        {
+                            result = 1;//姝e湪绛夊緟鏌愪簺鎿嶄綔
+                        }
+                    }
+                    else
+                    {
+                        if (view != null)
+                        {
+                            if(view.Tag.ToString() != "unlockpage")
+                            {
+                                view.RemoveFromParent();
+                            }
+                        }
+                    }
+                }
+                else
+                {
+                    result = 2;//鏃犳硶鍐嶅悗閫�锛屽彲浠ユ墽琛岄��鍒版闈�
+                }
+            });
+            return result;
+        }
+
 
         /// <summary>
         /// 鑷畾涔夋棩蹇楄緭鍑�
@@ -164,5 +404,8 @@
             Console.WriteLine(msg);
 #endif
         }
+
+
     }
+
 }

--
Gitblit v1.8.0