From d07d62be7111d78b2aaa44c9cdee23a7d22b4dda Mon Sep 17 00:00:00 2001
From: wei <kaede@kaededeMacBook-Air.local>
Date: 星期二, 22 十二月 2020 10:38:15 +0800
Subject: [PATCH] 20201222-1

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

diff --git a/HDL_ON/UI/UI2/FuntionControlView/Light/RGBPageBLL.cs b/HDL_ON/UI/UI2/FuntionControlView/Light/RGBPageBLL.cs
index 15c1c32..e6aa12a 100644
--- a/HDL_ON/UI/UI2/FuntionControlView/Light/RGBPageBLL.cs
+++ b/HDL_ON/UI/UI2/FuntionControlView/Light/RGBPageBLL.cs
@@ -19,22 +19,26 @@
                         return;
                     if (uFunction.functionType == bodyView.light.functionType && uFunction.sid == bodyView.light.sid)
                     {
-                        if (!bodyView.onDimmerBar)
-                        {
-                            bodyView.dimmerBar.Progress = uFunction.brightness;
-                        }
+                        
                         if (uFunction.trait_on_off.curValue.ToString() == "on")
                         {
                             bodyView.colorPicker.ColorImagePath = "FunctionIcon/Light/ColorWheel.png";
                             bodyView.dimmerBar.ProgressBarColor = CSS.CSS_Color.AuxiliaryColor1;
                             bodyView.btnSwitch.IsSelected = true;
                             bodyView.btnCurColor.BackgroundColor = (uint)(0xFF000000 + bodyView.light.GetRGBcolor());
+                            if (!bodyView.onDimmerBar)
+                            {
+                                bodyView.dimmerBar.Progress = uFunction.brightness;
+                            }
                         }
-                        else
+                        //鐘舵�佷竴鏍锋椂,涓嶅啀鍒锋柊瑙嗗浘
+                        else if (uFunction.trait_on_off.curValue.ToString() == "off" && bodyView.btnSwitch.IsSelected == true)
                         {
                             bodyView.colorPicker.ColorImagePath = "FunctionIcon/Light/ColorWheelGray.png";
                             bodyView.dimmerBar.ProgressBarColor = CSS.CSS_Color.PromptingColor2;
                             bodyView.btnSwitch.IsSelected = false;
+                            //鑹茬洏鐨勫渾鐐归殣钘�
+                            bodyView.btnWhiteRound.Visible = false;
                         }
                     }
                 }
@@ -58,7 +62,6 @@
             actionRefresh = () => {
                 btnFunctionName.Text = btnFunctionName_Out.Text = light.name;
                 btnFromFloor_Out.Text = btnFromFoorAndRoom.Text = light.GetRoomListName();
-                //light.SaveFunctionData(true);
             };
         }
 
@@ -68,9 +71,17 @@
         void LoadColorChangeEvent()
         {
             DateTime colorChangeTime = DateTime.MinValue;
+
+            //褰撳墠鐐瑰嚮鐨勩�愮偣銆戞槸鍚︽纭�
+            bool pointIsRight = false;
+            //鍦嗙殑鍗婂緞(鑰冭檻杈圭晫,闇�瑕佽缃畠鐨勫崐寰勬瘮杈冨皬涓�鐐�)
+            int circleR = colorPicker.Width / 2 - Application.GetRealWidth(12);
+
             colorPicker.ColorChaged += (sender2, e2) => {
-                if(light.trait_on_off.curValue.ToString() == "off")
+                if (light.trait_on_off.curValue.ToString() == "off"
+                  || pointIsRight == false)
                 {
+                    //pointIsRight:鐐圭殑鍖哄煙涓嶆槸鍦嗙洏鍐�
                     return;
                 }
                 if ((DateTime.Now - colorChangeTime).TotalMilliseconds > 200)
@@ -78,19 +89,37 @@
                     light.SetRGBcolor(e2);
                     colorChangeTime = DateTime.Now;
                     btnCurColor.BackgroundColor = (uint)(0xFF000000 + light.GetRGBcolor());
-                    //Control.Send(CommandType_A.write, this.light);
                     System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
                     d.Add(FunctionAttributeKey.RGB, light.GetRGBcolorString());
                     Control.Ins.SendWriteCommand(light, d);
                 }
             };
-            colorPicker.MouseUpEventHandler = (sender, e) =>
+            colorPicker.MouseDownEventHandler += (sender, e) =>
             {
-                var ss = btnCurColor.BackgroundColor;
+                if (light.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;
+                }
             };
-
+            colorPicker.MouseMoveEventHandler += (sender, e) =>
+            {
+                //褰撻紶鏍囩偣涓嬩簨浠跺鐞�
+                colorPicker.MouseDownEventHandler(sender, e);
+            };
         }
-
 
         /// <summary>
         /// 鏀惰棌鍔熻兘鎸夐挳浜嬩欢
@@ -113,7 +142,7 @@
             };
             dimmerBar.OnStopTrackingTouchEvent = (sender, e) => {
                 new System.Threading.Thread(() => {
-                    System.Threading.Thread.Sleep(100);
+                    System.Threading.Thread.Sleep(200);
                     onDimmerBar = false;
                 })
                 { IsBackground = true }.Start();
@@ -135,7 +164,6 @@
 
                 if (e == 0 || e == 100)
                 {
-                    //Control.Send(CommandType_A.write, this.light);
                     System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
                     d.Add(FunctionAttributeKey.Brightness, light.brightness.ToString());
                     Control.Ins.SendWriteCommand(light, d);
@@ -167,7 +195,7 @@
         /// </summary>
         void LoadEvet_ChangeFadeTime()
         {
-            barFadeTime.MouseUpEventHandler = (sender, e) =>
+            barFadeTime.OnStopTrackingTouchEvent = (sender, e) =>
             {
                 light.fadeTime = barFadeTime.Progress;
                 light.SaveFunctionData(true);
@@ -182,13 +210,20 @@
             {
                 btnSwitch.IsSelected = !btnSwitch.IsSelected;
                 dimmerBar.ProgressBarColor = btnSwitch.IsSelected ? CSS.CSS_Color.AuxiliaryColor1 : CSS.CSS_Color.PromptingColor2;
+                bodyView.colorPicker.ColorImagePath = btnSwitch.IsSelected ? "FunctionIcon/Light/ColorWheel.png" : "FunctionIcon/Light/ColorWheelGray.png";
                 new System.Threading.Thread(() =>
                 {
                     light.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, light.trait_on_off.curValue.ToString());
+                    d.Add(FunctionAttributeKey.FadeTime, light.fadeTime.ToString());
                     if (btnSwitch.IsSelected)
                     {
+                        if(light.lastBrightness == 0)
+                        {
+                            light.lastBrightness = 100;
+                            dimmerBar.Progress = 100;
+                        }
                         d.Add(FunctionAttributeKey.Brightness, light.lastBrightness.ToString());
                     }
                     else
@@ -207,6 +242,10 @@
         {
             btnRestoredPoint.MouseUpEventHandler = (sender, e) =>
             {
+                if(light.trait_on_off.curValue.ToString() == "off")
+                {
+                    return;
+                }
                 light.SetRGBcolor(new byte[] { 255, 255, 255 });
                 btnCurColor.BackgroundColor = 0xFFFFFFFF;
                 System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
@@ -214,5 +253,34 @@
                 Control.Ins.SendWriteCommand(light, d);
             };
         }
+
+        /// <summary>
+        /// 妫�娴嬬偣鍑荤偣
+        /// </summary>
+        /// <param name="circleR">鍦嗙殑鍗婂緞</param>
+        /// <param name="circleX">鍦嗗績X杞�</param>
+        /// <param name="circleY">鍦嗗績Y杞�</param>
+        /// <param name="pointX">鐐瑰嚮鐐圭殑X杞�</param>
+        /// <param name="pointY">鐐瑰嚮鐐圭殑Y杞�</param>
+        /// <returns></returns>
+        private bool CheckPoint(int circleR, int circleX, int circleY, int pointX, int pointY)
+        {
+            int dwidth = circleX - pointX;
+            if (dwidth < 0) { dwidth *= -1; }
+
+            int dHeight = circleY - pointY;
+            if (dHeight < 0) { dHeight *= -1; }
+
+            //鏍规嵁涓夎鍑芥暟,姹備笁瑙掑舰鐨勬枩杈归暱
+            int dlength = dwidth * dwidth + dHeight * dHeight;
+            //鍗婂緞闀垮害(涓嶅紑鏂�,鎵�浠ユ槸鎸夊钩鏂圭畻)
+            circleR *= circleR;
+            if (dlength < circleR)
+            {
+                //濡傛灉缁勬垚鐨勪笁瑙掑舰骞舵病鏈夐暱杩囧崐寰�,鍒欎唬琛ㄨ繕鍦ㄥ渾鍐�(涓嶅厑璁哥偣杈圭晫)
+                return true;
+            }
+            return false;
+        }
     }
 }

--
Gitblit v1.8.0