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 |  136 ++++++++++++++++++++++++++------------------
 1 files changed, 80 insertions(+), 56 deletions(-)

diff --git a/HDL_ON/UI/UI2/2-Classification/FunctionControlZoneBLL.cs b/HDL_ON/UI/UI2/2-Classification/FunctionControlZoneBLL.cs
index 66fc68d..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;
@@ -8,6 +9,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>
         void LoadEvent_FunctionCollection()
@@ -15,7 +66,7 @@
             btnCollectionIcon.MouseUpEventHandler += (sender, e) =>
             {
                 btnCollectionIcon.IsSelected = function.collection = !btnCollectionIcon.IsSelected;
-                DB_ResidenceData.residenceData.SaveResidenceData();
+                function.SaveFunctionData();
             };
         }
         /// <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);
             };
@@ -43,11 +94,11 @@
                 btnSwitch.IsSelected = !btnSwitch.IsSelected;
                 new System.Threading.Thread(() =>
                 {
-                    function.on_off = btnSwitch.IsSelected ? "on" : "off";
+                    function.trait_on_off.value = btnSwitch.IsSelected ? "on" : "off";
                     //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.on_off.ToString());
-                    Control.SendWriteCommand(function, d);
+                    d.Add("on_off", function.trait_on_off.value.ToString());
+                    Control.ins.SendWriteCommand(function, d);
                 })
                 { IsBackground = true }.Start();
             };
@@ -67,11 +118,11 @@
                     if (function.functionCategory == FunctionCategory.Light)
                     {
                         var light = function as Light;
-                        light.on_off = btnSwitch.IsSelected ? "on" : "off";
+                        light.trait_on_off.value = btnSwitch.IsSelected ? "on" : "off";
                         //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.on_off.ToString());
-                        Control.SendWriteCommand(function, d);
+                        d.Add("on_off", function.trait_on_off.value.ToString());
+                        Control.ins.SendWriteCommand(function, d);
                     }
                 })
                 { IsBackground = true }.Start();
@@ -83,76 +134,49 @@
         /// </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;
-                    light.on_off = e > 0 ? "on" : "off";
+                    light.trait_on_off.value = e > 0 ? "on" : "off";
 
                     if (e == 0 || e == 100)
                     {
                         //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!!");
-                        }
                     }
                 };
-
             }
 
         }
@@ -173,11 +197,11 @@
                 btnClose.IsSelected = true;
                 btnStop.IsSelected = false;
                 btnOpen.IsSelected = false;
-                curtain.on_off = "off";
-                //Control.Send(CommandType_A.write, curtain);
+                curtain.trait_on_off.value = "off";
+                curtain.percent = 0;
                 System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
-                d.Add("on_off", curtain.on_off.ToString());
-                Control.SendWriteCommand(curtain, d);
+                d.Add("on_off", curtain.trait_on_off.value.ToString());
+                Control.ins.SendWriteCommand(curtain, d);
             };
 
             btnStop.MouseDownEventHandler = (sender, e) =>
@@ -191,11 +215,11 @@
                 btnOpen.IsSelected = true;
                 btnClose.IsSelected = false;
                 btnStop.IsSelected = false;
-                curtain.on_off = "stop";
-                //Control.Send(CommandType_A.write, curtain);
+                curtain.trait_on_off.value = "stop";
+                //curtain.percent = 0;
                 System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
-                d.Add("on_off", curtain.on_off.ToString());
-                Control.SendWriteCommand(curtain, d);
+                d.Add("on_off", curtain.trait_on_off.value.ToString());
+                Control.ins.SendWriteCommand(curtain, d);
             };
 
             btnOpen.MouseUpEventHandler = (sender, e) =>
@@ -203,11 +227,11 @@
                 btnOpen.IsSelected = true;
                 btnClose.IsSelected = false;
                 btnStop.IsSelected = false;
-                curtain.on_off = "on";
-                //Control.Send(CommandType_A.write, curtain);
+                curtain.trait_on_off.value = "on";
+                curtain.percent = 100;
                 System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
-                d.Add("on_off", curtain.on_off.ToString());
-                Control.SendWriteCommand(curtain, d);
+                d.Add("on_off", curtain.trait_on_off.value.ToString());
+                Control.ins.SendWriteCommand(curtain, d);
             };
         }
         #endregion

--
Gitblit v1.8.0