From c8c33200e43f05136eca9fc8ff4942f8def31cc6 Mon Sep 17 00:00:00 2001
From: JLChen <551775569@qq.com>
Date: 星期三, 18 八月 2021 10:45:40 +0800
Subject: [PATCH] 2021-08-18 1.完善Android对接LinphoneSDK 2.完善SIP相关接口对接

---
 HDL_ON/UI/MainPage.cs |  231 ++++++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 171 insertions(+), 60 deletions(-)

diff --git a/HDL_ON/UI/MainPage.cs b/HDL_ON/UI/MainPage.cs
index b365695..223ecbc 100644
--- a/HDL_ON/UI/MainPage.cs
+++ b/HDL_ON/UI/MainPage.cs
@@ -1,6 +1,7 @@
 锘縰sing System;
 using System.Collections.Generic;
 using HDL_ON.DAL;
+using HDL_ON.Entity;
 using HDL_ON.UI;
 using HDL_ON.UI.CSS;
 using Shared;
@@ -18,15 +19,13 @@
         /// </summary>
         public static PageLayout BasePageView { get; set; }
         /// <summary>
-        /// DisplayCompleted
+        /// 鐢ㄦ埛鎺у埗鐖跺鍣�
         /// </summary>
-        public static bool DisplayCompleted = false;
-
-        //public static UserInfo LoginUser;
+        public static UserPage UserBasePage;
         /// <summary>
         /// 鐗堟湰鍙�
         /// </summary>
-        public static string VersionString = "1.1.0309";
+        public static string VersionString = "1.2.0721";
         ///// <summary>
         ///// 瀹㈡埛绔被鍨�
         ///// </summary>
@@ -40,6 +39,10 @@
         /// 澶╂皵鍒锋柊action
         /// </summary>
         public static Action RefreshAir;
+        /// <summary>
+        /// 鍥為��椤甸潰action 娌℃湁闇�瑕佸彲浠ヤ笉鐢�
+        /// </summary>
+        public static Action ReturnRefreshAction;
         /// <summary>
         /// 鏃犵櫥褰曟ā寮�
         /// </summary>
@@ -70,6 +73,14 @@
         //public static int Company = 0;
 
         /// <summary>
+        /// 鍙虫粦鍚庨��鎻愮ず鎸夐挳
+        /// </summary>
+        public static Button BtnBackIcon;
+        /// <summary>
+        /// 鍚庨��鍙虫粦浜嗗灏戣窛绂伙紝瓒呰繃涓�瀹氳窛绂绘墠瑙﹀彂鍚庨��浜嬩欢
+        /// </summary>
+        public static int StartX = 0;
+        /// <summary>
         /// 鏄惁鍏ㄩ潰灞忔墜鏈�
         /// </summary>
         public static bool Increase
@@ -87,6 +98,26 @@
 #endif
             }
         }
+
+        /// <summary>
+        /// 鍦烘櫙鏀寔鐨勫姛鑳藉垪琛�
+        /// </summary>
+        public static List<string> SceneSupportFunctionList = new List<string> {
+            SPK.LightCCT,SPK.LightDimming,SPK.LightSwitch,SPK.LightRGB,
+            SPK.CurtainRoller,SPK.CurtainSwitch,SPK.CurtainTrietex,
+            SPK.AcIr,SPK.AcStandard,
+            SPK.FloorHeatStandard,
+
+        };
+        /// <summary>
+        /// 鎴块棿鍔熻兘鍒楄〃涓嶅姞杞界殑鍔熻兘鍒楄〃
+        /// </summary>
+        public static List<string> RoomNotSupportFunctionList = new List<string>
+        {
+            SPK.EnergyStandard,
+            SPK.MusicStandard,
+        };
+
 
 
         public static void Show()
@@ -128,7 +159,7 @@
                         //})
                         //{ IsBackground = true }.Start();
                         Common.ApiUtlis.Ins.DownloadData();
-
+                        
                         GoUserPage(false,true);
                     }
                 }
@@ -164,7 +195,116 @@
         /// <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) =>
+            {
+                if (e < BasePageView.ChildrenCount - 1)
+                {
+                    BasePageView.GetChildren(BasePageView.ChildrenCount - 1).RemoveFromParent();
+                }
+                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);
+
+            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);
@@ -179,51 +319,23 @@
                 addResidencePage.LoadView();
                 return;
             }
-            new System.Threading.Thread(() =>
+            new System.Threading.Thread(async () =>
             {
                 try
                 {
                     Entity.FunctionList.List.Clear();
                     Entity.SpatialInfo.CurrentSpatial.Clear();
                     ///绛夊緟鑾峰彇浣忓畢淇℃伅
-                    Application.RunOnMainThread(() =>
+                    Application.RunOnMainThread( () =>
                     {
                         waitPage.Hide();
                         waitPage.RemoveFromParent();
-                        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 UserBasePage = new UserPage();
+                        UserBasePage = new UserPage();
                         BasePageView.AddChidren(UserBasePage);
                         UserBasePage.LoadPage();
                         BasePageView.PageIndex = 0;
-
-                   
 
                         if (isFirstOpen)
                         {
@@ -242,16 +354,12 @@
                 {
                     Application.RunOnMainThread(() =>
                     {
-                      
-
                         if (downloadData)
                         {
+                            DB_ResidenceData.Instance.EixtAccount();
                             ///鍒濆鍖朼pp鏁版嵁
                             Common.ApiUtlis.Ins.DownloadData();
                         };
-
-                       
-
                     });
                 }
             }).Start();
@@ -268,12 +376,17 @@
             int result = 0;
             Application.RunOnMainThread(() =>
             {
-                if (BaseView.ChildrenCount>1)
+                if (BasePageView == null || BasePageView.ChildrenCount<=1 )
                 {
-                    var view = BaseView.GetChildren(BaseView.ChildrenCount - 1);
-                    if(view.GetType() == typeof(Loading))
+                    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;
+                        var loading = view as Loading;
                         if (loading.CurStatus == false)//鏈変竴浜涚瓑寰呯晫闈㈤殣钘忎簡锛屼絾鏄病鏈夌Щ闄ゅ埌锛岄渶瑕佸厛绉婚櫎
                         {
                             loading.RemoveFromParent();
@@ -284,22 +397,20 @@
                             result = 1;//姝e湪绛夊緟鏌愪簺鎿嶄綔
                         }
                     }
+                    else
+                    {
+                        if (view != null)
+                        {
+                            if(view.Tag.ToString() != "unlockpage")
+                            {
+                                view.RemoveFromParent();
+                            }
+                        }
+                    }
                 }
                 else
                 {
-                    if (BasePageView.ChildrenCount > 1)
-                    {
-                        int index = BasePageView.ChildrenCount - 1;
-                        var view = BasePageView.GetChildren(index);
-                        if (view != null)
-                        {
-                            view.RemoveFromParent();
-                        }
-                    }
-                    else
-                    {
-                        result = 2;//鏃犳硶鍐嶅悗閫�锛屽彲浠ユ墽琛岄��鍒版闈�
-                    }
+                    result = 2;//鏃犳硶鍐嶅悗閫�锛屽彲浠ユ墽琛岄��鍒版闈�
                 }
             });
             return result;

--
Gitblit v1.8.0