From af1cb3ecd0f4b0589e00b28f7f9edccf39e6e12b Mon Sep 17 00:00:00 2001
From: wxr <464027401@qq.com>
Date: 星期四, 10 九月 2020 16:15:11 +0800
Subject: [PATCH] 202009101

---
 HDL_ON/UI/UI2/FuntionControlView/Light/DimmerPageBLL.cs |   77 +++++++++++++++++++++++++++++---------
 1 files changed, 58 insertions(+), 19 deletions(-)

diff --git a/HDL_ON/UI/UI2/FuntionControlView/Light/DimmerPageBLL.cs b/HDL_ON/UI/UI2/FuntionControlView/Light/DimmerPageBLL.cs
index da9b79a..cc4fdb0 100644
--- a/HDL_ON/UI/UI2/FuntionControlView/Light/DimmerPageBLL.cs
+++ b/HDL_ON/UI/UI2/FuntionControlView/Light/DimmerPageBLL.cs
@@ -1,5 +1,6 @@
 锘縰sing System;
 using HDL_ON.Entity;
+using HDL_ON.UI.CSS;
 using Shared;
 namespace HDL_ON.UI
 {
@@ -18,9 +19,21 @@
                         return;
                     if (uFunction.functionType == bodyView.light.functionType && uFunction.sid == bodyView.light.sid)
                     {
-                        bodyView.dimmerBar.Progress = uFunction.brightness;
-                        bodyView.dimmerBar.WaveColor = uFunction.on_off == 1 ? CSS.CSS_Color.AuxiliaryColor1 : CSS.CSS_Color.PromptingColor2;
-                        bodyView.btnSwitch.IsSelected = uFunction.on_off == 1;
+                        if (!bodyView.onDimmerBar)
+                        {
+                            bodyView.dimmerBar.Progress = uFunction.brightness;
+                        }
+
+                        if (uFunction.trait_on_off.value.ToString() == "on")
+                        {
+                            bodyView.dimmerBar.SetProgressBarColors(CSS_Color.AuxiliaryColor1, CSS_Color.AuxiliaryColor1);
+                        }
+                        else
+                        {
+                            bodyView.dimmerBar.SetProgressBarColors(CSS_Color.DividingLineColor, CSS_Color.DividingLineColor);
+                        }
+                        //bodyView.dimmerBar.WaveColor = uFunction.on_off == "on" ? CSS.CSS_Color.AuxiliaryColor1 : CSS.CSS_Color.PromptingColor2;
+                        bodyView.btnSwitch.IsSelected = uFunction.trait_on_off.value.ToString() == "on";
                     }
                 }
                 catch (Exception ex)
@@ -49,7 +62,7 @@
         {
             btnCollection.MouseUpEventHandler += (sender, e) => {
                 btnCollection.IsSelected = light.collection = btnCollection_Out.IsSelected = !btnCollection.IsSelected;
-                DB_ResidenceData.residenceData.SaveResidenceData();
+                light.SaveFunctionData();
             };
         }
 
@@ -58,36 +71,52 @@
         /// </summary>
         void LoadEvent_DimmerBar()
         {
-            DateTime dimmerTime = DateTime.MinValue;
+            dimmerBar.OnStartTrackingTouchEvent = (sender, e) => {
+                onDimmerBar = true;
+            };
+            dimmerBar.OnStopTrackingTouchEvent = (sender, e) => {
+                onDimmerBar = false;
+                light.brightness = dimmerBar.Progress;
+                //Control.Send(CommandType_A.write, light);
+                System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
+                d.Add("brightness", light.brightness.ToString());
+                Control.SendWriteCommand(light, d);
+            };
             dimmerBar.OnProgressChangedEvent = (sender, e) => {
                 if (!btnSwitch.IsSelected)
                 {
-                    dimmerBar.WaveColor = CSS.CSS_Color.AuxiliaryColor1;
-                }
+                    dimmerBar.SetProgressBarColors(CSS_Color.AuxiliaryColor1, CSS_Color.AuxiliaryColor1);
+                }   
                 btnSwitch.IsSelected = e > 0 ? true : false;
                 light.brightness = e;
-                light.on_off = e > 0 ? 1 : 0;
+                light.trait_on_off.value = e > 0 ? "on" : "off";
 
                 if (e == 0 || e == 100)
                 {
-                    Control.Send("write", this.light);
+                    //Control.Send(CommandType_A.write, this.light);
+                    System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
+                    d.Add("brightness", light.brightness.ToString());
+                    Control.SendWriteCommand(light, d);
                 }
                 else
                 {
-                    if (dimmerTime.AddMilliseconds(500) < DateTime.Now)
+                    if (200 < (DateTime.Now - light.refreshTime).TotalMilliseconds)
                     {
-                        dimmerTime = DateTime.Now;
+                        light.refreshTime = DateTime.Now;
                         new System.Threading.Thread(() =>
                         {
-                            Control.Send("write", light);
+                            System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
+                            d.Add("brightness", light.brightness.ToString());
+                            Control.SendWriteCommand(light, d);
                         })
                         { IsBackground = true }.Start();
                     }
-                    else
-                    {
-                        MainPage.Log("skip control!!");
-                    }
                 }
+
+                MainPage.Log( dimmerBar.NowProgressY.ToString());
+                //btnBrightnessText.Y = dimmerBar.NowProgressY + Application.GetRealWidth(40);
+                btnBrightnessText.Y = ((100 - dimmerBar.Progress) * Application.GetRealHeight(288 - 16 - 16) / 100) + Application.GetRealWidth(40);
+                btnBrightnessText.Text = light.brightness + "%";
             };
         }
 
@@ -99,11 +128,21 @@
             btnSwitch.MouseUpEventHandler += (sender, e) =>
             {
                 btnSwitch.IsSelected = !btnSwitch.IsSelected;
-                dimmerBar.WaveColor = btnSwitch.IsSelected ? CSS.CSS_Color.AuxiliaryColor1 : CSS.CSS_Color.PromptingColor2;
+                if (btnSwitch.IsSelected)
+                {
+                    dimmerBar.SetProgressBarColors(CSS_Color.AuxiliaryColor1, CSS_Color.AuxiliaryColor1);
+                }
+                else
+                {
+                    dimmerBar.SetProgressBarColors(CSS_Color.DividingLineColor, CSS_Color.DividingLineColor);
+                }
                 new System.Threading.Thread(() =>
                 {
-                    light.on_off = btnSwitch.IsSelected ? 1 : 0;
-                    Control.Send("write", this.light);
+                    light.trait_on_off.value = btnSwitch.IsSelected ? "on" : "off";
+                    System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
+                    d.Add("on_off", light.trait_on_off.value.ToString());
+                    Control.SendWriteCommand(light, d);
+                    //Control.Send(CommandType_A.write, this.light);
                 })
                 { IsBackground = true }.Start();
             };

--
Gitblit v1.8.0