From 4fef29b9ab9f2632f15a0d45005f92d91de5d4e5 Mon Sep 17 00:00:00 2001
From: Davin <591807572@qq.com>
Date: 星期四, 27 七月 2023 14:26:59 +0800
Subject: [PATCH] feature 萤石sdk更新

---
 HDL_ON/UI/UI2/FuntionControlView/Light/RGBPageBLL.cs |  165 +++++++++++++++++++++++++++---------------------------
 1 files changed, 82 insertions(+), 83 deletions(-)

diff --git a/HDL_ON/UI/UI2/FuntionControlView/Light/RGBPageBLL.cs b/HDL_ON/UI/UI2/FuntionControlView/Light/RGBPageBLL.cs
index 4826777..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;
                         }
@@ -207,6 +205,7 @@
             };
         }
 
+        bool curDimmerStatus = false;
         /// <summary>
         /// 鐏厜璋冨厜浜嬩欢
         /// </summary>
@@ -215,70 +214,63 @@
 
             dimmerBar.OnStopTrackingTouchEvent = (sender, e) =>
             {
-                //if (!function.online)
-                //{
-                //    new Tip()
-                //    {
-                //        CloseTime = 1,
-                //        Text = Language.StringByID(StringId.DeviceOfflineCannotOption),
-                //        Direction = AMPopTipDirection.None,
-                //    }.Show(MainPage.BaseView);
-                //    return;
-                //}
-                new System.Threading.Thread(() =>
+                if (!function.online)
                 {
-                    System.Threading.Thread.Sleep(200);
-                    onDimmerBar = false;
-                })
-                { IsBackground = true }.Start();
+                    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>();
                 d.Add(FunctionAttributeKey.Brightness, dimmerBar.Progress.ToString());
 
                 Control.Ins.SendWriteCommand(function, d);
             };
-            //if (function.online)
+            if (function.online)
             {
                 dimmerBar.OnStartTrackingTouchEvent = (sender, e) =>
                 {
-                    onDimmerBar = true;
+                    curDimmerStatus = onDimmerBar = true;
                 };
                 dimmerBar.OnProgressChangedEvent = (sender, e) =>
                 {
-                    //function.fadeTime = 0;
-                    //if (!btnSwitch.IsSelected)
-                    //{
-                    //    dimmerBar.ProgressBarColor = CSS.CSS_Color.AuxiliaryColor1;
-                    //}
-                    //btnSwitch.IsSelected = e > 0 ? true : false;
-                    //function.brightness = e;
-                    //function.trait_on_off.curValue = e > 0 ? "on" : "off";
+                    if (!btnSwitch.IsSelected)
+                    {
+                        dimmerBar.ProgressBarColor = CSS.CSS_Color.AuxiliaryColor1;
+                    }
+                    btnSwitch.IsSelected = e > 0 ? true : false;
+                    function.trait_on_off.curValue = e > 0 ? "on" : "off";
 
-                    //if (e == 0 || e == 100)
-                    //{
-                    //    System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
-                    //    d.Add(FunctionAttributeKey.Brightness, function.brightness.ToString());
-                    //    Control.Ins.SendWriteCommand(function, d);
-                    //}
-                    //else
-                    //{
-                    //    if (200 < (DateTime.Now - function.refreshTime).TotalMilliseconds)
-                    //    {
-                    //        function.refreshTime = DateTime.Now;
-                    //        new System.Threading.Thread(() =>
-                    //        {
-                    //            //Control.Send(CommandType_A.write, function);
-                    //            System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
-                    //            d.Add(FunctionAttributeKey.Brightness, function.brightness.ToString());
-                    //            Control.Ins.SendWriteCommand(function, d);
-                    //        })
-                    //        { IsBackground = true }.Start();
-                    //    }
-                    //    else
-                    //    {
-                    //        MainPage.Log("skip dimmer control!!");
-                    //    }
-                    //}
+                    if (e == 0 || e == 100)
+                    {
+                        System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
+                        d.Add(FunctionAttributeKey.Brightness, e.ToString());
+                        Control.Ins.SendWriteCommand(function, d);
+                    }
+                    else
+                    {
+                        if (350 < (DateTime.Now - function.refreshTime).TotalMilliseconds)
+                        {
+                            function.refreshTime = DateTime.Now;
+                            new System.Threading.Thread(() =>
+                            {
+                                //Control.Send(CommandType_A.write, function);
+                                System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
+                                d.Add(FunctionAttributeKey.Brightness, e.ToString());
+                                Control.Ins.SendWriteCommand(function, d);
+                            })
+                            { IsBackground = true }.Start();
+                        }
+                        else
+                        {
+                            MainPage.Log("skip dimmer control!!");
+                        }
+                    }
                 };
             }
         }
@@ -292,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();
                 };
             }
@@ -311,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)
@@ -336,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