From a715181089be0d31cd737a5367ffd02690b9d77f Mon Sep 17 00:00:00 2001
From: wxr <464027401@qq.com>
Date: 星期四, 12 十一月 2020 13:36:01 +0800
Subject: [PATCH] 20201112

---
 HDL_ON/UI/UI2/2-Classification/FunctionControlZoneBLL.cs |  112 ++++++++++++++++++++++++++++++++++----------------------
 1 files changed, 68 insertions(+), 44 deletions(-)

diff --git a/HDL_ON/UI/UI2/2-Classification/FunctionControlZoneBLL.cs b/HDL_ON/UI/UI2/2-Classification/FunctionControlZoneBLL.cs
index 0d61dd1..5795611 100644
--- a/HDL_ON/UI/UI2/2-Classification/FunctionControlZoneBLL.cs
+++ b/HDL_ON/UI/UI2/2-Classification/FunctionControlZoneBLL.cs
@@ -1,4 +1,5 @@
 锘縰sing System;
+using HDL_ON.DriverLayer;
 using HDL_ON.Entity;
 using HDL_ON.UI.Music;
 using Shared;
@@ -7,6 +8,56 @@
 {
     public partial class FunctionControlZone
     {
+        /// <summary>
+        /// 鏇存柊寮�鍏崇姸鎬�
+        /// </summary>
+        /// <param name="upfunc"></param>
+        public static void UpdataOnOffState(Function upfunc)
+        {
+            if(bodyDiv!= null)
+            {
+                Application.RunOnMainThread(() => {
+                    if(bodyDiv.Tag.ToString() == upfunc.sid)
+                    {
+                        for (var o = 0; o < bodyDiv.ChildrenCount; o++)
+                        {
+                            if (bodyDiv.GetChildren(o).GetType() == typeof(Button))
+                            {
+                                var btn = bodyDiv.GetChildren(o) as Button;
+                                if (btn.Tag != null)
+                                {
+                                    if (btn.Tag.ToString() == upfunc.sid + "_Switch")// + "_DimmerBar")
+                                    {
+                                        btn.IsSelected = upfunc.trait_on_off.value.ToString() == "on";
+                                    }
+                                }
+                            }
+                            else if (bodyDiv.GetChildren(o).GetType() == typeof(DiyImageSeekBar))
+                            {
+                                var btn = bodyDiv.GetChildren(o) as DiyImageSeekBar;
+                                if (btn.Tag != null)
+                                {
+                                    if (btn.Tag.ToString() == upfunc.sid + "_DimmerBar")
+                                    {
+                                        //btn.Progress = (upfunc as Light).trait_brightness.value.value.ToString() == "on";
+                                    }
+                                }
+                            }
+                        }
+
+                    }
+                });
+            }
+        }
+        /// <summary>
+        /// 鏇存柊浜害鐘舵��
+        /// </summary>
+        /// <param name="upfunc"></param>
+        static void UpdataBrightnessState(Function upfunc)
+        {
+
+        }
+
         /// <summary>
         /// 鍔犺浇鍔熻兘鏀惰棌鎸夐挳浜嬩欢
         /// </summary>
@@ -24,7 +75,7 @@
         void LoadEvent_ControlScene()
         {
             EventHandler<MouseEventArgs> upEvent = (sender, e) => {
-                Control.Send(function);
+                Control.ins.ControlScene(function as Scene);
                 string msg = function.name + Language.StringByID(StringId.AlreadyOpened);
                 new PublicAssmebly().TipMsgAutoClose(msg, false);
             };
@@ -47,7 +98,7 @@
                     //Control.Send(CommandType_A.write, function);
                     System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
                     d.Add("on_off", function.trait_on_off.value.ToString());
-                    Control.SendWriteCommand(function, d);
+                    Control.ins.SendWriteCommand(function, d);
                 })
                 { IsBackground = true }.Start();
             };
@@ -71,7 +122,7 @@
                         //Control.Send(CommandType_A.write, function);
                         System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
                         d.Add("on_off", function.trait_on_off.value.ToString());
-                        Control.SendWriteCommand(function, d);
+                        Control.ins.SendWriteCommand(function, d);
                     }
                 })
                 { IsBackground = true }.Start();
@@ -83,43 +134,20 @@
         /// </summary>
         void LoadEvent_LightDimming(DiyImageSeekBar dimmerControlBar)
         {
-            //if (function.functionType == FunctionType.Dimmer || function.functionType == FunctionType.RGB)
-            //{
-            //    if (dimmerControlBar == null)
-            //        return;
-            //    var light = function as Light;
-            //    dimmerControlBar.OnProgressChangedEvent += (sender, e) =>
-            //    {
-            //        if ((DateTime.Now - light.refreshTime).TotalMilliseconds > 200)//璋冨厜鍛戒护鍙戦�侀棿闅斾簨浠�
-            //        {
-            //            new System.Threading.Thread(() =>
-            //            {
-            //                light.refreshTime = DateTime.Now;
-            //                light.brightness = e;
-            //                Control.Send(CommandType_A.write, function);
-            //            })
-            //            { IsBackground = true }.Start();
-            //        }
-            //    };
-            //    dimmerControlBar.OnStopTrackingTouchEvent += (sender, e) =>
-            //    {
-            //        light.brightness = dimmerControlBar.Progress;
-            //        Control.Send(CommandType_A.write, function);
-            //    };
-            //}
             if(function.functionType == FunctionType.Dimmer || function.functionType == FunctionType.RGB)
             {
                 var light = function as Light;
                 dimmerControlBar.OnStartTrackingTouchEvent = (sender, e) => {
                     onDimmerBar = true;
+                    (bodyDiv.Parent as VerticalScrolViewLayout).ScrollEnabled = false;
                 };
                 dimmerControlBar.OnStopTrackingTouchEvent = (sender, e) => {
                     onDimmerBar = false;
+                    (bodyDiv.Parent as VerticalScrolViewLayout).ScrollEnabled = true;
                     light.brightness = dimmerControlBar.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);
+                    Control.ins.SendWriteCommand(light, d);
                 };
                 dimmerControlBar.OnProgressChangedEvent = (sender, e) => {
                     light.brightness = e;
@@ -130,29 +158,25 @@
                         //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);
+                        Control.ins.SendWriteCommand(light, d);
                     }
                     else
                     {
-                        if (200 < (DateTime.Now - light.refreshTime).TotalMilliseconds)
+                        var tm = (DateTime.Now - light.refreshTime).TotalMilliseconds;
+                        Console.WriteLine("skip time "+tm);
+                        if (300 < tm)
                         {
                             light.refreshTime = DateTime.Now;
                             new System.Threading.Thread(() =>
                             {
-                                //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);
+                                Control.ins.SendWriteCommand(light, d);
                             })
                             { IsBackground = true }.Start();
                         }
-                        else
-                        {
-                            MainPage.Log("skip dimmer control!!");
-                        }
                     }
                 };
-
             }
 
         }
@@ -174,10 +198,10 @@
                 btnStop.IsSelected = false;
                 btnOpen.IsSelected = false;
                 curtain.trait_on_off.value = "off";
-                //Control.Send(CommandType_A.write, curtain);
+                curtain.percent = 0;
                 System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
                 d.Add("on_off", curtain.trait_on_off.value.ToString());
-                Control.SendWriteCommand(curtain, d);
+                Control.ins.SendWriteCommand(curtain, d);
             };
 
             btnStop.MouseDownEventHandler = (sender, e) =>
@@ -192,10 +216,10 @@
                 btnClose.IsSelected = false;
                 btnStop.IsSelected = false;
                 curtain.trait_on_off.value = "stop";
-                //Control.Send(CommandType_A.write, curtain);
+                //curtain.percent = 0;
                 System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
                 d.Add("on_off", curtain.trait_on_off.value.ToString());
-                Control.SendWriteCommand(curtain, d);
+                Control.ins.SendWriteCommand(curtain, d);
             };
 
             btnOpen.MouseUpEventHandler = (sender, e) =>
@@ -204,10 +228,10 @@
                 btnClose.IsSelected = false;
                 btnStop.IsSelected = false;
                 curtain.trait_on_off.value = "on";
-                //Control.Send(CommandType_A.write, curtain);
+                curtain.percent = 100;
                 System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
                 d.Add("on_off", curtain.trait_on_off.value.ToString());
-                Control.SendWriteCommand(curtain, d);
+                Control.ins.SendWriteCommand(curtain, d);
             };
         }
         #endregion

--
Gitblit v1.8.0