From d76b0e40e5bb127fd33aa1f7842447a1df0628d5 Mon Sep 17 00:00:00 2001
From: wxr <464027401@qq.com>
Date: 星期日, 30 七月 2023 22:16:34 +0800
Subject: [PATCH] Update PublicAssmeblyBLL.cs

---
 HDL_ON/UI/UI2/FuntionControlView/Light/RGBPageBLL.cs |   93 ++++++++++++++++++++++++----------------------
 1 files changed, 49 insertions(+), 44 deletions(-)

diff --git a/HDL_ON/UI/UI2/FuntionControlView/Light/RGBPageBLL.cs b/HDL_ON/UI/UI2/FuntionControlView/Light/RGBPageBLL.cs
index 023c828..2654e0b 100644
--- a/HDL_ON/UI/UI2/FuntionControlView/Light/RGBPageBLL.cs
+++ b/HDL_ON/UI/UI2/FuntionControlView/Light/RGBPageBLL.cs
@@ -58,6 +58,20 @@
                         {
                             bodyView.btnCurColor.BorderColor = 0x00000000;
                         }
+                        try
+                        {
+                            var colorfulState = updateTemp.GetAttribute(FunctionAttributeKey.Colorful);
+                            if (colorfulState != null)
+                            {
+                                if(bodyView.btnColorfulSwitch!= null)
+                                {
+                                    bodyView.btnColorfulSwitch.IsSelected = colorfulState.curValue.ToString() == "on";
+                                }
+                            }
+                        }catch(Exception ex)
+                        {
+                            MainPage.Log($"鏇存柊RGB 鐐僵寮�鍏崇姸鎬佸紓甯�:{ex.Message}");
+                        }
                     }
                 }
                 catch (Exception ex)
@@ -88,23 +102,23 @@
         /// </summary>
         void LoadColorChangeEvent()
         {
-            //if (!function.online)
-            //{
-            //    new Tip()
-            //    {
-            //        CloseTime = 1,
-            //        Text = Language.StringByID(StringId.DeviceOfflineCannotOption),
-            //        Direction = AMPopTipDirection.None,
-            //    }.Show(MainPage.BaseView);
-            //    return;
-            //}
+            if (!function.online)
+            {
+                new Tip()
+                {
+                    CloseTime = 1,
+                    Text = Language.StringByID(StringId.DeviceOfflineCannotOption),
+                    Direction = AMPopTipDirection.None,
+                }.Show(MainPage.BaseView);
+                return;
+            }
             DateTime colorChangeTime = DateTime.MinValue;
             //bool send = false;
 
             //褰撳墠鐐瑰嚮鐨勩�愮偣銆戞槸鍚︽纭�
             bool pointIsRight = false;
             //鍦嗙殑鍗婂緞(鑰冭檻杈圭晫,闇�瑕佽缃畠鐨勫崐寰勬瘮杈冨皬涓�鐐�)
-            int circleR = colorPicker.Width / 2 - Application.GetRealWidth(12);
+            int circleR = colorPicker.Width / 2 - Application.GetRealWidth(2);
 
             colorPicker.ColorChaged += (sender2, e2) => {
                 if (function.trait_on_off.curValue.ToString() == "off" || pointIsRight == false)
@@ -148,24 +162,7 @@
             {
                 //褰撻紶鏍囩偣涓嬩簨浠跺鐞�
                 colorPicker.MouseDownEventHandler(sender, e);
-                //if (function.trait_on_off.curValue.ToString() == "off")
-                //{
-                //    return;
-                //}
-                //pointIsRight = this.CheckPoint(circleR, colorPicker.Width / 2, colorPicker.Height / 2, (int)e.X, (int)e.Y);
-                //if (pointIsRight == false)
-                //{
-                //    //鐐圭殑鍖哄煙涓嶆槸鍦嗙洏鍐�
-                //    return;
-                //}
-                ////鏄剧ず鐧界偣
-                //btnWhiteRound.X = (int)e.X - btnWhiteRound.Width / 2;
-                //btnWhiteRound.Y = (int)e.Y - btnWhiteRound.Height / 2;
-                //if (btnWhiteRound.Visible == false)
-                //{
-                //    btnWhiteRound.Visible = true;
-                //}
-                //btnCurColor.BackgroundColor = (uint)(0xFF000000 + lightTemp.GetRGBcolor(function));
+                
             };
 
             var colorChangeEvent = new System.Threading.Thread(() => {
@@ -185,6 +182,7 @@
                             lightTemp.SetRGBcolor(lastColor, function);
                             System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
                             d.Add(FunctionAttributeKey.RGB, lightTemp.GetRGBcolorString(function));
+                            d.Add(FunctionAttributeKey.Brightness, dimmerBar.Progress.ToString());
                             Control.Ins.SendWriteCommand(function, d,false,0);
                             break;
                         }
@@ -216,16 +214,16 @@
 
             dimmerBar.OnStopTrackingTouchEvent = (sender, e) =>
             {
-                //if (!function.online)
-                //{
-                //    new Tip()
-                //    {
-                //        CloseTime = 1,
-                //        Text = Language.StringByID(StringId.DeviceOfflineCannotOption),
-                //        Direction = AMPopTipDirection.None,
-                //    }.Show(MainPage.BaseView);
-                //    return;
-                //}
+                if (!function.online)
+                {
+                    new Tip()
+                    {
+                        CloseTime = 1,
+                        Text = Language.StringByID(StringId.DeviceOfflineCannotOption),
+                        Direction = AMPopTipDirection.None,
+                    }.Show(MainPage.BaseView);
+                    return;
+                }
                 curDimmerStatus = false;
                 function.SetAttrState(FunctionAttributeKey.Brightness, dimmerBar.Progress);
                 System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
@@ -233,7 +231,7 @@
 
                 Control.Ins.SendWriteCommand(function, d);
             };
-            //if (function.online)
+            if (function.online)
             {
                 dimmerBar.OnStartTrackingTouchEvent = (sender, e) =>
                 {
@@ -286,6 +284,9 @@
                 barFadeTime.OnStopTrackingTouchEvent = (sender, e) =>
                 {
                     function.SetAttrState(FunctionAttributeKey.FadeTime, e.ToString());
+                    var d = new System.Collections.Generic.Dictionary<string, string>();
+                    d.Add(FunctionAttributeKey.FadeTime, e.ToString());
+                    Control.Ins.SendWriteCommand(function, d);
                     function.SaveFunctionFile();
                 };
             }
@@ -305,6 +306,10 @@
                     function.trait_on_off.curValue = btnSwitch.IsSelected ? "on" : "off";
                     System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
                     d.Add(FunctionAttributeKey.OnOff, function.trait_on_off.curValue.ToString());
+                    if (function.GetAttribute(FunctionAttributeKey.FadeTime) != null)
+                    {
+                        d.Add(FunctionAttributeKey.FadeTime, barFadeTime.Progress.ToString());
+                    }
                     if (btnSwitch.IsSelected)
                     {
                         if(function.lastBrightness == 0)
@@ -330,10 +335,10 @@
         {
             btnRestoredPoint.MouseUpEventHandler = (sender, e) =>
             {
-                //if (!function.online)
-                //{
-                //    return;
-                //}
+                if (!function.online)
+                {
+                    return;
+                }
                 if(function.trait_on_off.curValue.ToString() == "off")
                 {
                     return;

--
Gitblit v1.8.0