From 25429f085093d89d543a0b90e30d0d62d1b7dac9 Mon Sep 17 00:00:00 2001
From: hxb <hxb@hdlchina.com.cn>
Date: 星期二, 30 八月 2022 09:37:38 +0800
Subject: [PATCH] 合并了IOS的代码

---
 ZigbeeApp/Shared/Phone/MainPage/Controls/SceneCardControl.cs |   71 ++++++++++++++++++++++-------------
 1 files changed, 44 insertions(+), 27 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/MainPage/Controls/SceneCardControl.cs b/ZigbeeApp/Shared/Phone/MainPage/Controls/SceneCardControl.cs
index 7290a4b..c674940 100755
--- a/ZigbeeApp/Shared/Phone/MainPage/Controls/SceneCardControl.cs
+++ b/ZigbeeApp/Shared/Phone/MainPage/Controls/SceneCardControl.cs
@@ -8,7 +8,7 @@
     /// <summary>
     /// 鍦烘櫙鍗$墖鎺т欢
     /// </summary>
-    public class SceneCardControl : FrameLayoutControl
+    public class SceneCardControl : FrameLayoutStatuControl
     {
         #region 鈻� 鍙橀噺澹版槑___________________________
 
@@ -51,15 +51,16 @@
         public SceneCardControl()
         {
             //鍥剧墖鐪熷疄瀹藉害+鍥剧墖鑷韩宸﹀彸绌虹櫧
-            this.Width = Application.GetMinRealAverage(458 + 14 * 2);
+            this.Width = HdlControlLogic.Current.GetPictrueRealSize(458 + 14 * 2);
             //鍥剧墖楂樺害+闃村奖
-            this.Height = Application.GetMinRealAverage(305 + 43);
+            this.Height = HdlControlLogic.Current.GetPictrueRealSize(305 + 43);
             //鍙栨秷鐐瑰嚮鐗规晥
             this.UseClickStatu = false;
 
             this.ButtonClickEvent += (sender, e) =>
             {
                 //璋冪敤鍦烘櫙
+                this.CanClick = false;
                 this.SetSceneAction();
             };
         }
@@ -77,33 +78,33 @@
 
             //鍦烘櫙鍥剧墖鎺т欢
             this.btnScenePic = new ImageView();
-            btnScenePic.X = Application.GetMinRealAverage(14);
-            btnScenePic.Width = Application.GetMinRealAverage(458);
-            btnScenePic.Height = Application.GetMinRealAverage(305);
-            btnScenePic.Radius = (uint)Application.GetMinRealAverage(17);
+            btnScenePic.X = HdlControlLogic.Current.GetPictrueRealSize(14);
+            btnScenePic.Width = HdlControlLogic.Current.GetPictrueRealSize(458);
+            btnScenePic.Height = HdlControlLogic.Current.GetPictrueRealSize(305);
+            btnScenePic.Radius = (uint)Application.GetRealHeight(17);
             this.AddChidren(btnScenePic, ChidrenBindMode.NotBind);
 
             //鍦烘櫙鑳屾櫙鍥炬帶浠�
             this.btnSceneBackGroud = new PicViewControl(this.Width, this.Height, false);
             btnSceneBackGroud.UnSelectedImagePath = "Scene/Background.png";
-            this.AddChidren(btnSceneBackGroud, ChidrenBindMode.BindEventOnly);
+            this.AddChidren(btnSceneBackGroud, ChidrenBindMode.BindEvent);
 
             //寤舵椂鏃堕棿鏄剧ず鎺т欢
-            this.btnTimeView = new NormalViewControl(Application.GetMinRealAverage(280), Application.GetMinRealAverage(63), false);
-            btnTimeView.X = Application.GetMinRealAverage(37);
-            btnTimeView.Y = Application.GetMinRealAverage(10);
+            this.btnTimeView = new NormalViewControl(HdlControlLogic.Current.GetPictrueRealSize(280), HdlControlLogic.Current.GetPictrueRealSize(63), false);
+            btnTimeView.X = HdlControlLogic.Current.GetPictrueRealSize(37);
+            btnTimeView.Y = HdlControlLogic.Current.GetPictrueRealSize(10);
             btnTimeView.TextColor = 0xffffb400;
             btnTimeView.IsBold = true;
             if (i_scene.SceneDelayTime > 0)
             {
                 btnTimeView.Text= this.GetTimeString(i_scene.SceneDelayTime, hourText, minuText, secondText);
             }
-            this.AddChidren(btnTimeView, ChidrenBindMode.BindEventOnly);
+            this.AddChidren(btnTimeView, ChidrenBindMode.BindEvent);
 
             //鏃堕棿鍥炬爣鎺т欢
             this.btnTimeIcon = new IconViewControl(63);
-            btnTimeIcon.X = Application.GetMinRealAverage(37);
-            btnTimeIcon.Y = Application.GetMinRealAverage(20);
+            btnTimeIcon.X = HdlControlLogic.Current.GetPictrueRealSize(37);
+            btnTimeIcon.Y = HdlControlLogic.Current.GetPictrueRealSize(20);
             btnTimeIcon.UnSelectedImagePath = "Item/Time.png";
             this.AddChidren(btnTimeIcon, ChidrenBindMode.NotBind);
             if (i_scene.SceneDelayTime > 0)
@@ -125,19 +126,24 @@
                 timeSelect.Init();
                 timeSelect.TimeAction = (time) =>
                 {
+                    //閫夋嫨鐨勬槸涓嶅紑鍚�
+                    if (time == 0) { return; }
+
                     i_scene.SceneDelayTime = time;
 
                    //鏃堕棿鍥炬爣涓嶆樉绀�
                    this.btnTimeIcon.Visible = false;
                    //鏄剧ず鍓╀綑鐨勬椂闂�
                    this.btnTimeView.Text = this.GetTimeString(time, hourText, minuText, secondText);
+                    //閫夋嫨寤舵椂鏃�,闇�瑕佸埛鏂颁富椤�
+                    UserView.UserPage.Instance.RefreshAllForm = true;
                 };
             };
 
             //鏀惰棌鎺т欢
             var btnCollect = new IconViewControl(107);
-            btnCollect.X = Application.GetMinRealAverage(350);
-            btnCollect.Y = Application.GetMinRealAverage(12);
+            btnCollect.X = HdlControlLogic.Current.GetPictrueRealSize(350);
+            btnCollect.Y = HdlControlLogic.Current.GetPictrueRealSize(12);
             btnCollect.UnSelectedImagePath = "Item/Collection1.png";
             btnCollect.SelectedImagePath = "Item/CollectionSelected1.png";
             this.AddChidren(btnCollect, ChidrenBindMode.NotBind);
@@ -150,7 +156,7 @@
                 {
                     //鍙栨秷鏀惰棌
                     HdlSceneLogic.Current.DeleteLoveScene(i_scene);
-                    if (HdlRoomLogic.Current.CurrentRoom.IsLove == true)
+                    if (HdlRoomLogic.Current.NowMainPageRoom.IsLove == true)
                     {
                         //濡傛灉褰撳墠鎴块棿鏄垜鐨勫枩鐖辩殑璇�,鍥炶皟鍗$墖琚垹闄ょ殑浜嬩欢
                         this.CardNeedRemoveEvent?.Invoke();
@@ -164,12 +170,12 @@
             };
 
             //鍦烘櫙鍚嶇О鎺т欢
-            this.btnSceneName = new NormalViewControl(Application.GetMinRealAverage(280), Application.GetMinRealAverage(63), false);
-            btnSceneName.X = Application.GetMinRealAverage(37);
-            btnSceneName.Y = Application.GetMinRealAverage(236);
+            this.btnSceneName = new NormalViewControl(HdlControlLogic.Current.GetPictrueRealSize(280), HdlControlLogic.Current.GetPictrueRealSize(63), false);
+            btnSceneName.X = HdlControlLogic.Current.GetPictrueRealSize(37);
+            btnSceneName.Y = HdlControlLogic.Current.GetPictrueRealSize(236);
             btnSceneName.IsBold = true;
             btnSceneName.TextColor = UserCenterColor.Current.White;
-            this.AddChidren(btnSceneName, ChidrenBindMode.BindEventOnly);
+            this.AddChidren(btnSceneName, ChidrenBindMode.BindEvent);
 
             //鍒锋柊鎺т欢鐘舵��
             this.RefreshControlInfo(i_scene);
@@ -195,7 +201,13 @@
             var result = await HdlSceneLogic.Current.ControlScene(scene);
             if (result == false)
             {
+                this.CanClick = true;
                 return;
+            }
+            if (scene.SceneDelayTime > 0)
+            {
+                //璋冪敤鏈夊欢鏃剁殑鍦烘櫙,闇�瑕佸埛鏂颁富椤�
+                UserView.UserPage.Instance.RefreshAllForm = true;
             }
             //淇敼鏃堕棿
             scene.RemainTime = scene.SceneDelayTime;
@@ -219,9 +231,11 @@
             //鍒锋柊鍥剧墖
             if (i_scene.IconPathType == 0)
             {
-                if (this.btnScenePic.ImagePath != i_scene.IconPath)
+                //涓婚〉鐨勫満鏅崱鐗囩敤鐨勬槸鍙﹀鐨勫浘
+                string newPath = i_scene.IconPath.Replace("SceneIcon", "SceneCardIcon");
+                if (this.btnScenePic.ImagePath != newPath)
                 {
-                    this.btnScenePic.ImagePath = i_scene.IconPath;
+                    this.btnScenePic.ImagePath = newPath;
                 }
             }
             else
@@ -234,6 +248,7 @@
             }
 
             //寮�鍚欢鏃跺�掕鏃剁壒鏁�
+            this.CanClick = false;
             this.StartRemainTimeApreal(i_scene);
         }
 
@@ -249,6 +264,7 @@
         {
             if (i_scene.RemainTime <= 0)
             {
+                this.CanClick = true;
                 return;
             }
             int remainTine = i_scene.RemainTime;
@@ -269,20 +285,21 @@
                 while (remainTine > 0 && this.Parent != null)
                 {
                     System.Threading.Thread.Sleep(1000);
-                    Application.RunOnMainThread(() =>
+                    HdlThreadLogic.Current.RunMain(() =>
                     {
                         this.btnTimeView.Text = this.GetTimeString(remainTine, hourText, minuText, secondText);
-                    });
+                    }, ShowErrorMode.NO);
                     remainTine--;
                 }
-                Application.RunOnMainThread(() =>
+                HdlThreadLogic.Current.RunMain(() =>
                 {
                     //鍊掕鏃剁粨鏉熸椂锛屾椂闂村浘鏍囨樉绀�
                     this.btnTimeIcon.Visible = true;
                     this.btnTimeView.Text = string.Empty;
                     //鐩存帴寮�鍚疞oading鐗规晥
                     this.StartLoadingApreal();
-                });
+                    this.CanClick = true;
+                }, ShowErrorMode.NO);
             })
             { IsBackground = true }.Start();
         }

--
Gitblit v1.8.0