From 002a3f2e9d2f9579c01f88af12bd8a320003569f Mon Sep 17 00:00:00 2001
From: wxr <464027401@qq.com>
Date: 星期二, 31 三月 2020 08:57:19 +0800
Subject: [PATCH] 20200331

---
 HDL_ON/UI/UI2/2-Classification/ClassificationPageBLL.cs |  204 ++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 192 insertions(+), 12 deletions(-)

diff --git a/HDL_ON/UI/UI2/2-Classification/ClassificationPageBLL.cs b/HDL_ON/UI/UI2/2-Classification/ClassificationPageBLL.cs
index d0c0e9f..28f6aaf 100644
--- a/HDL_ON/UI/UI2/2-Classification/ClassificationPageBLL.cs
+++ b/HDL_ON/UI/UI2/2-Classification/ClassificationPageBLL.cs
@@ -1,5 +1,6 @@
 锘縰sing System;
 using System.Collections.Generic;
+using HDL_ON.Entity;
 using HDL_ON.UI.CSS;
 using Shared;
 
@@ -7,6 +8,159 @@
 {
     public partial class ClassificationPage
     {
+        /// <summary>
+        /// 鏇存柊鐣岄潰淇℃伅
+        /// </summary>
+        /// <param name="function"></param>
+        public static void UpdataInfo(Function function)
+        {
+            Application.RunOnMainThread(() => {
+                if (bodyView == null)
+                    return;
+                UpdataFunctionOnCount(function.functionCategory);
+                UpdataCloseAllButton(function);
+            });
+        }
+
+        /// <summary>
+        /// 鏇存柊鍔熻兘鎵撳紑鏁伴噺
+        /// </summary>
+        /// <param name="functionCategory"></param>
+        static void UpdataFunctionOnCount(FunctionCategory functionCategory)
+        {
+            for (int i = 0; i < bodyView.functionsPageView.ChildrenCount; i++)
+            {
+                if (bodyView.functionsPageView.GetChildren(i).GetType() == typeof(FrameLayout))
+                {
+                    var view1 = bodyView.functionsPageView.GetChildren(i) as FrameLayout;
+                    for (int j = 0; j < view1.ChildrenCount; j++)
+                    {
+                        if (view1.GetChildren(j).GetType() == typeof(FrameLayout))
+                        {
+                            var view2 = view1.GetChildren(j) as FrameLayout;
+                            for (var k = 0; k < view2.ChildrenCount; k++)
+                            {
+                                if (view2.GetChildren(k).GetType() == typeof(FrameLayout))
+                                {
+                                    var view3 = view2.GetChildren(j) as FrameLayout;
+                                    for (var o = 0; o < view3.ChildrenCount; o++)
+                                    {
+                                        if (view3.GetChildren(o).GetType() == typeof(Button))
+                                        {
+                                            var btn = view3.GetChildren(o) as Button;
+                                            if (btn.Tag != null && btn.Tag.ToString() == functionCategory + "_onCount")
+                                            {
+                                                string btnText = "0/0";
+                                                switch (functionCategory)
+                                                {
+                                                    case FunctionCategory.AC:
+                                                        btnText = DB_ResidenceData.residenceData.functionList.aCs.FindAll((obj) => obj.on_off == "on").Count + "/" + DB_ResidenceData.residenceData.functionList.lights.Count;
+                                                        break;
+                                                    case FunctionCategory.Curtain:
+                                                        btnText = DB_ResidenceData.residenceData.functionList.curtains.FindAll((obj) => obj.on_off == "on").Count + "/" + DB_ResidenceData.residenceData.functionList.lights.Count;
+                                                        break;
+                                                    case FunctionCategory.Light:
+                                                        btnText = DB_ResidenceData.residenceData.functionList.lights.FindAll((obj) => obj.on_off == "on").Count + "/" + DB_ResidenceData.residenceData.functionList.lights.Count;
+                                                        break;
+                                                }
+                                                btn.Text = btnText;
+                                            }
+                                        }
+                                    }
+                                }
+                            }
+                        }
+                    }
+                }
+            }
+        }
+
+        /// <summary>
+        /// 鏇存柊鍏ㄥ叧鍔熻兘鐘舵��
+        /// </summary>
+        static void UpdataCloseAllButton(Function function)
+        {
+            for (int i = 0; i < bodyView.roomListView.ChildrenCount; i++)
+            {
+                if (bodyView.roomListView.GetChildren(i).GetType() == typeof(FrameLayout))
+                {
+                    var view1 = bodyView.roomListView.GetChildren(i) as FrameLayout;
+                    if (!function.roomIdList.Contains(view1.Tag.ToString()))
+                        continue;
+                    for (int j = 0; j < view1.ChildrenCount; j++)
+                    {
+                        if (view1.GetChildren(j).GetType() == typeof(Button))
+                        {
+                            var btn = view1.GetChildren(j) as Button;
+                            if (btn.Tag != null && btn.Tag.ToString() == "AllClose")
+                            {
+                                if (function.on_off == "on")
+                                {
+                                    btn.Visible = true;
+                                }
+                                else
+                                {
+                                    foreach (var rId in function.roomIdList)
+                                    {
+                                        var r = DB_ResidenceData.residenceData.rooms.Find(s => s.sid == rId);
+                                        var ssd = r.functions.FindAll((obj) => obj.on_off == "on" && obj.functionCategory != FunctionCategory.Scene);
+                                        var sss = ssd.Count;
+                                        if (sss == 0)
+                                        {
+                                            btn.Visible = false;
+                                        }
+                                    }
+                                }
+                            }
+                        }
+                    }
+                }
+            }
+        }
+
+        /// <summary>
+        /// 鍔犺浇鍏抽棴鎴块棿鎵�鏈夊姛鑳戒簨浠�
+        /// </summary>
+        void LoadEvent_CloseAllFunction(Button btn, Room room)
+        {
+            try
+            {
+                btn.Visible = false;
+                foreach (var f in room.functions)
+                {
+                    if(f.functionCategory == FunctionCategory.Scene)
+                    {
+                        continue;
+                    }
+                    if (f.on_off == "on")
+                    {
+                        btn.Visible = true;
+                        return;
+                    }
+                }
+                btn.MouseUpEventHandler = (sender, e) =>
+                {
+                    Action action = () =>
+                    {
+                        foreach (var f in room.functions)
+                        {
+                            if (f.functionCategory == FunctionCategory.Scene)
+                            {
+                                continue;
+                            }
+                            f.on_off = "off";
+                            Control.Send(CommandType_A.write, f);
+                        }
+                        btn.Visible = false;
+                    };
+                    new PublicAssmebly().TipMsg(StringId.Tip, StringId.TipCloseAllFunctionInRoom, action);
+                };
+            }
+            catch (Exception ex)
+            {
+                MainPage.Log($"load close all function : {ex.Message}");
+            }
+        }
 
         /// <summary>
         /// 鍔犺浇浜嬩欢鍒楄〃
@@ -72,34 +226,55 @@
         #endregion
 
         /// <summary>
-        /// 鍏抽棴鎵撳紑鍏ㄩ儴鐏厜
+        /// 鍏抽棴鎵撳紑鍏ㄩ儴閫変腑绫诲瀷鍔熻兘
         /// </summary>
-        void LoadEvent_LightsPower(Button btn)
+        void LoadEvent_SwitchFunction(Button btn,FunctionCategory functionCategory)
         {
-            btn.IsSelected = !btn.IsSelected;
-            if (btn.IsSelected)
-            {
+            btn.MouseUpEventHandler = (sender, e) => {
+                btn.IsSelected = !btn.IsSelected;
+                switch(functionCategory)
+                {
+                    case FunctionCategory.AC:
+                        foreach(var f in DB_ResidenceData.residenceData.functionList.aCs)
+                        {
+                            f.on_off = btn.IsSelected ? "on" : "off";
+                            Control.Send(CommandType_A.write, f);
+                        }
+                        break;
+                    case FunctionCategory.Curtain:
+                      
+                        break;
+                    case FunctionCategory.Light:
+                        foreach (var f in DB_ResidenceData.residenceData.functionList.lights)
+                        {
+                            f.on_off = btn.IsSelected ? "on" : "off";
+                            Control.Send(CommandType_A.write, f);
+                        }
+                        break;
+                }
 
-            }
-            else
-            {
-
-            }
+            };
         }
+
 
         /// <summary>
         /// 绐楀笜鍏ㄥ紑鍏ㄥ叧
         /// </summary>
-        void LoadEvent_CurtainSwitch(Button btnClose,Button btnOpen)
+        void LoadEvent_CurtainSwitch(Button btnClose, Button btnOpen)
         {
             btnOpen.MouseUpEventHandler = (sender, e) =>
             {
-                if(btnOpen.IsSelected)
+                if (btnOpen.IsSelected)
                 {
                     return;
                 }
                 btnOpen.IsSelected = true;
                 btnClose.IsSelected = false;
+                foreach (var f in DB_ResidenceData.residenceData.functionList.curtains)
+                {
+                    f.on_off = "on";
+                    Control.Send(CommandType_A.write, f);
+                }
             };
 
             btnClose.MouseUpEventHandler = (sender, e) =>
@@ -110,6 +285,11 @@
                 }
                 btnClose.IsSelected = true;
                 btnOpen.IsSelected = false;
+                foreach (var f in DB_ResidenceData.residenceData.functionList.curtains)
+                {
+                    f.on_off =  "off";
+                    Control.Send(CommandType_A.write, f);
+                }
             };
 
 

--
Gitblit v1.8.0