From 3f6685c77beeb12baf840733fb890860f4c26e7c Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期四, 25 七月 2024 17:25:59 +0800
Subject: [PATCH] 2024年07月25日17:24:45

---
 HDL_ON/UI/UI2/FuntionControlView/Light/DimmerPageBLL.cs |  166 +++++++++++++++++++++++++++++++------------------------
 1 files changed, 94 insertions(+), 72 deletions(-)

diff --git a/HDL_ON/UI/UI2/FuntionControlView/Light/DimmerPageBLL.cs b/HDL_ON/UI/UI2/FuntionControlView/Light/DimmerPageBLL.cs
index a8d34a9..11c2daa 100644
--- a/HDL_ON/UI/UI2/FuntionControlView/Light/DimmerPageBLL.cs
+++ b/HDL_ON/UI/UI2/FuntionControlView/Light/DimmerPageBLL.cs
@@ -7,41 +7,50 @@
 {
     public partial class DimmerPage
     {
+        
         /// <summary>
         /// 鏇存柊鍔熻兘鐘舵��
         /// </summary>
         public static void UpdataStates(Function updataTemp)
         {
-            Application.RunOnMainThread((() =>
+            if (bodyView == null)
             {
-                try
-                {
-                    if (bodyView == null)
-                        return;
-                    if (updataTemp.spk == bodyView.function.spk && updataTemp.sid == bodyView.function.sid)
-                    {
-                        bodyView.btnBrightnessText.Text = updataTemp.GetAttrState(FunctionAttributeKey.Brightness) + "%";
-                        bodyView.btnBrightnessText.Y = ((100 - Convert.ToInt32( updataTemp.GetAttrState(FunctionAttributeKey.Brightness))) * Application.GetRealHeight(288 - 16 - 16) / 100) + Application.GetRealWidth(40);
-                        if (updataTemp.trait_on_off.curValue.ToString() == "on")
-                        {
-                            bodyView.dimmerBar.SetProgressBarColors(CSS_Color.AuxiliaryColor1, CSS_Color.AuxiliaryColor1);
-                            if (!bodyView.onDimmerBar)
+                return;
+            }
+
+                        Application.RunOnMainThread(() =>{
+                            try
                             {
-                                bodyView.dimmerBar.Progress = Convert.ToInt32(updataTemp.GetAttrState(FunctionAttributeKey.Brightness));
+                                if (bodyView == null)
+                                    return;
+                                if (updataTemp.spk == bodyView.function.spk && updataTemp.sid == bodyView.function.sid)
+                                {
+                                    bodyView.btnBrightnessText.Text = updataTemp.GetAttrState(FunctionAttributeKey.Brightness) + "%";
+                                    if (updataTemp.trait_on_off.curValue.ToString() == "on")
+                                    {
+                                        bodyView.dimmerBar.SetProgressBarColors(CSS_Color.AuxiliaryColor1, CSS_Color.AuxiliaryColor1);
+                                        if (!bodyView.onDimmerBar)
+                                        {
+                                            bodyView.dimmerBar.Progress = Convert.ToInt32(updataTemp.GetAttrState(FunctionAttributeKey.Brightness));
+                                            bodyView.btnBrightnessText.Y = ((100 - Convert.ToInt32(updataTemp.GetAttrState(FunctionAttributeKey.Brightness))) * Application.GetRealHeight(288 - 16 - 16) / 100) + Application.GetRealWidth(40);
+                                        }
+                                    }
+                                    else
+                                    {
+                                        bodyView.dimmerBar.SetProgressBarColors(CSS_Color.DividingLineColor, CSS_Color.DividingLineColor);
+                                    }
+                                    bodyView.btnSwitch.IsSelected = updataTemp.trait_on_off.curValue.ToString() == "on";
+                                }
                             }
-                        }
-                        else
-                        {
-                            bodyView.dimmerBar.SetProgressBarColors(CSS_Color.DividingLineColor, CSS_Color.DividingLineColor);
-                        }
-                        bodyView.btnSwitch.IsSelected = updataTemp.trait_on_off.curValue.ToString() == "on";
-                    }
-                }
-                catch (Exception ex)
-                {
-                    MainPage.Log($"{bodyView.GetType().Name } UpdataStates error : {ex.Message}");
-                }
-            }));
+                            catch (Exception ex)
+                            {
+                                MainPage.Log($"{bodyView.GetType().Name} UpdataStates error : {ex.Message}");
+                            }
+                            finally
+                            {
+                            }
+                        });
+
         }
 
         void LoadEventList()
@@ -67,6 +76,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();
                 };
             }
@@ -83,60 +95,66 @@
             };
         }
 
+        bool curDimmerStatus = false;
+
         /// <summary>
         /// 鐏厜璋冨厜浜嬩欢
         /// </summary>
         void LoadEvent_DimmerBar()
         {
-            if (function.online)
+            if (function.isOnline())
             {
                 dimmerBar.OnStartTrackingTouchEvent = (sender, e) =>
                 {
-                    onDimmerBar = true;
+                    curDimmerStatus = onDimmerBar = true;
+                    dimmerBar.SetProgressBarColors(CSS_Color.AuxiliaryColor1, CSS_Color.AuxiliaryColor1);
                 };
                 dimmerBar.OnStopTrackingTouchEvent = (sender, e) =>
                 {
-                    onDimmerBar = false;
+
+                    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());
+                    //if(dimmerBar.Progress > 0)
+                    //{
+                    //    d.Add(FunctionAttributeKey.OnOff, "on");
+                    //}
                     Control.Ins.SendWriteCommand(function, d);
                     btnBrightnessText.Text = dimmerBar.Progress + "%";
                 };
                 //20201223 鍒犻櫎婊戝姩鍙戦�佸懡浠わ紝闃叉鎺т欢璺冲姩
                 dimmerBar.OnProgressChangedEvent = (sender, e) =>
                 {
-                    dimmerBar.SetProgressBarColors(CSS_Color.AuxiliaryColor1, CSS_Color.AuxiliaryColor1);
-                //function.fadeTime = 0;
-                //if (!btnSwitch.IsSelected)
-                //{
-                //    dimmerBar.SetProgressBarColors(CSS_Color.AuxiliaryColor1, CSS_Color.AuxiliaryColor1);
-                //}
-                //btnSwitch.IsSelected = e > 0 ? true : false;
-                //function.brightness = e;
-                //function.trait_on_off.curValue = e > 0 ? "on" : "off";
-                //if (e == 0 || e == 100)
-                //{
-                //    //Control.Send(CommandType_A.write, this.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);
-                //}
-                //else
-                //{
-                //    if (200 < (DateTime.Now - function.refreshTime).TotalMilliseconds)
-                //    {
-                //        function.refreshTime = DateTime.Now;
-                //        new System.Threading.Thread(() =>
-                //        {
-                //            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();
-                //    }
-                //}
-                btnBrightnessText.Y = ((100 - dimmerBar.Progress) * Application.GetRealHeight(288 - 16 - 16) / 100) + Application.GetRealWidth(40);
+                    if (!btnSwitch.IsSelected)
+                    {
+                        dimmerBar.SetProgressBarColors(CSS_Color.AuxiliaryColor1, CSS_Color.AuxiliaryColor1);
+                    }
+                    btnSwitch.IsSelected = e > 0 ? true : false;
+                    function.SetAttrState(FunctionAttributeKey.Brightness, e);
+                    function.trait_on_off.curValue = e > 0 ? "on" : "off";
+                    if (e == 0 || e == 100)
+                    {
+                        //Control.Send(CommandType_A.write, this.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);
+                    }
+                    //else
+                    //{
+                    //    if (350 < (DateTime.Now - function.refreshTime).TotalMilliseconds)
+                    //    {
+                    //        function.refreshTime = DateTime.Now;
+                    //        new System.Threading.Thread(() =>
+                    //        {
+                    //            System.Collections.Generic.Dictionary<string, string> dic = new System.Collections.Generic.Dictionary<string, string>();
+                    //            dic.Add(FunctionAttributeKey.Brightness, e.ToString());
+                    //            Control.Ins.SendWriteCommand(function, dic);
+                    //        })
+                    //        { IsBackground = true }.Start();
+                    //    }
+                    //}
+                    btnBrightnessText.Y = ((100 - dimmerBar.Progress) * Application.GetRealHeight(288 - 16 - 16) / 100) + Application.GetRealWidth(40);
                     btnBrightnessText.Text = dimmerBar.Progress + "%";
                 };
             }
@@ -148,7 +166,7 @@
         {
             btnSwitch.MouseUpEventHandler += (sender, e) =>
             {
-                if (!function.online)
+                if (!function.isOnline())
                 {
                     new Tip()
                     {
@@ -172,18 +190,22 @@
                     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 (btnSwitch.IsSelected)
+                    if (function.GetAttribute(FunctionAttributeKey.FadeTime) != null)
                     {
-                        if(function.lastBrightness == 0)
-                        {
-                            function.lastBrightness = 100;
-                        }
-                        d.Add(FunctionAttributeKey.Brightness, function.lastBrightness.ToString());
+                        d.Add(FunctionAttributeKey.FadeTime, barFadeTime.Progress.ToString());
                     }
-                    else
-                    {
-                        function.lastBrightness = Convert.ToInt32( function.GetAttrState(FunctionAttributeKey.Brightness));
-                    }
+                    //if (btnSwitch.IsSelected)
+                    //{
+                    //    if(function.lastBrightness == 0)
+                    //    {
+                    //        function.lastBrightness = 100;
+                    //    }
+                    //    d.Add(FunctionAttributeKey.Brightness, function.lastBrightness.ToString());
+                    //}
+                    //else
+                    //{
+                    //    function.lastBrightness = Convert.ToInt32( function.GetAttrState(FunctionAttributeKey.Brightness));
+                    //}
                     Control.Ins.SendWriteCommand(function, d);
                 })
                 { IsBackground = true }.Start();

--
Gitblit v1.8.0