From 1026814d931de92f0da5f15a58870565a94100e0 Mon Sep 17 00:00:00 2001
From: 陈嘉乐 <cjl@hdlchina.com.cn>
Date: 星期一, 11 一月 2021 14:37:38 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/NewFilePath' into WJC

---
 HDL_ON/UI/UI2/2-Classification/ClassificationPageBLL.cs |  144 +++++++++++++++++++++++++++++------------------
 1 files changed, 89 insertions(+), 55 deletions(-)

diff --git a/HDL_ON/UI/UI2/2-Classification/ClassificationPageBLL.cs b/HDL_ON/UI/UI2/2-Classification/ClassificationPageBLL.cs
index 7f604b2..f4713bc 100644
--- a/HDL_ON/UI/UI2/2-Classification/ClassificationPageBLL.cs
+++ b/HDL_ON/UI/UI2/2-Classification/ClassificationPageBLL.cs
@@ -17,7 +17,7 @@
         /// <param name="function"></param>
         public static void UpdataInfo(Function function)
         {
-            Application.RunOnMainThread(() => {
+            Application.RunOnMainThread((Action)(() => {
                 if (bodyView == null)
                     return;
                 try
@@ -47,20 +47,20 @@
                             vv = ShowFunction.Electric;
                             break;
                     }
-                    UpdataFunctionOnCount(vv, function.functionType);
+                    UpdataFunctionOnCount(vv, function.spk);
                     UpdataCloseAllButton(function);
                 }
                 catch
                 {
                 }
-            });
+            }));
         }
 
         /// <summary>
         /// 鏇存柊鍔熻兘鎵撳紑鏁伴噺
         /// </summary>
         /// <param name="functionCategory"></param>
-        static void UpdataFunctionOnCount(ShowFunction functionCategory, FunctionType functionType)
+        static void UpdataFunctionOnCount(ShowFunction functionCategory, string functionType)
         {
             try
             {
@@ -192,7 +192,7 @@
                                         {
                                             continue;
                                         }
-                                        var ssd = r.GetRoomFunctions(false).FindAll((obj) => obj.trait_on_off.curValue.ToString() == "on" && obj.functionCategory != FunctionCategory.Scene);
+                                        var ssd = r.GetRoomFunctions(false).FindAll((obj) => obj.trait_on_off.curValue.ToString() == "on");
                                         var sss = ssd.Count;
                                         if (sss == 0)
                                         {
@@ -222,11 +222,6 @@
                         {
                             foreach (var f in room.GetRoomFunctions(false))
                             {
-                                if (f.functionCategory == FunctionCategory.Scene)
-                                {
-                                    continue;
-                                }
-
                                 f.trait_on_off.curValue = "off";
                                 Dictionary<string, string> d = new Dictionary<string, string>();
                                 d.Add("on_off", f.trait_on_off.curValue.ToString());
@@ -249,10 +244,6 @@
                 };
                 foreach (var f in room.GetRoomFunctions(false))
                 {
-                    if (f.functionCategory == FunctionCategory.Scene)
-                    {
-                        continue;
-                    }
                     if (f.trait_on_off.curValue.ToString() == "on")
                     {
                         btn.Visible = true;
@@ -345,48 +336,91 @@
                 {
                     try
                     {
-                        switch (functionCategory)
+                        if (DB_ResidenceData.Instance.GatewayType == 0 && !Control.Ins.IsRemote)
                         {
-                            case ShowFunction.AC:
-                                foreach (var f in FunctionList.List.aCs)
-                                {
-                                    f.trait_on_off.curValue = onoff;
-                                    Dictionary<string, string> d = new Dictionary<string, string>();
-                                    d.Add(FunctionAttributeKey.OnOff, f.trait_on_off.curValue.ToString());
-                                    Control.Ins.SendWriteCommand(f, d);
-                                    System.Threading.Thread.Sleep(100);
-                                }
-                                break;
-                            case ShowFunction.FloorHeating:
-                                foreach (var f in FunctionList.List.floorHeatings)
-                                {
-                                    f.trait_on_off.curValue = onoff;
-                                    Dictionary<string, string> d = new Dictionary<string, string>();
-                                    d.Add(FunctionAttributeKey.OnOff, f.trait_on_off.curValue.ToString());
-                                    Control.Ins.SendWriteCommand(f, d);
-                                    System.Threading.Thread.Sleep(100);
-                                }
-                                break;
-                            case ShowFunction.Light:
-                                foreach (var f in FunctionList.List.lights)
-                                {
-                                    f.trait_on_off.curValue = onoff;
-                                    Dictionary<string, string> d = new Dictionary<string, string>();
-                                    d.Add(FunctionAttributeKey.OnOff, f.trait_on_off.curValue.ToString());
-                                    Control.Ins.SendWriteCommand(f, d);
-                                    System.Threading.Thread.Sleep(100);
-                                }
-                                break;
-                            case ShowFunction.Electric:
-                                foreach (var f in FunctionList.List.electricals)
-                                {
-                                    f.trait_on_off.curValue = onoff;
-                                    Dictionary<string, string> d = new Dictionary<string, string>();
-                                    d.Add(FunctionAttributeKey.OnOff, f.trait_on_off.curValue.ToString());
-                                    Control.Ins.SendWriteCommand(f, d);
-                                    System.Threading.Thread.Sleep(100);
-                                }
-                                break;
+                            switch (functionCategory)
+                            {
+                                case ShowFunction.AC:
+                                    foreach (var f in FunctionList.List.aCs)
+                                    {
+                                        f.trait_on_off.curValue = onoff;
+                                        Dictionary<string, string> d = new Dictionary<string, string>();
+                                        d.Add(FunctionAttributeKey.OnOff, f.trait_on_off.curValue.ToString());
+                                        Control.Ins.SendWriteCommand(f, d);
+                                        System.Threading.Thread.Sleep(100);
+                                    }
+                                    break;
+                                case ShowFunction.FloorHeating:
+                                    foreach (var f in FunctionList.List.floorHeatings)
+                                    {
+                                        f.trait_on_off.curValue = onoff;
+                                        Dictionary<string, string> d = new Dictionary<string, string>();
+                                        d.Add(FunctionAttributeKey.OnOff, f.trait_on_off.curValue.ToString());
+                                        Control.Ins.SendWriteCommand(f, d);
+                                        System.Threading.Thread.Sleep(100);
+                                    }
+                                    break;
+                                case ShowFunction.Light:
+                                    foreach (var f in FunctionList.List.lights)
+                                    {
+                                        f.trait_on_off.curValue = onoff;
+                                        Dictionary<string, string> d = new Dictionary<string, string>();
+                                        d.Add(FunctionAttributeKey.OnOff, f.trait_on_off.curValue.ToString());
+                                        Control.Ins.SendWriteCommand(f, d);
+                                        System.Threading.Thread.Sleep(100);
+                                    }
+                                    break;
+                                case ShowFunction.Electric:
+                                    foreach (var f in FunctionList.List.electricals)
+                                    {
+                                        f.trait_on_off.curValue = onoff;
+                                        Dictionary<string, string> d = new Dictionary<string, string>();
+                                        d.Add(FunctionAttributeKey.OnOff, f.trait_on_off.curValue.ToString());
+                                        Control.Ins.SendWriteCommand(f, d);
+                                        System.Threading.Thread.Sleep(100);
+                                    }
+                                    break;
+                            }
+                        }
+                        else
+                        {
+                            switch (functionCategory)
+                            {
+                                case ShowFunction.AC:
+                                    List<Function> acList = new List<Function>();
+                                    foreach(var f in FunctionList.List.aCs)
+                                    {
+                                        acList.Add(f);
+                                    }
+                                    Control.Ins.SwtichFunctions(onoff == "on", acList);
+                                    break;
+                                case ShowFunction.FloorHeating:
+                                    List<Function> fhList = new List<Function>();
+                                    foreach (var f in FunctionList.List.floorHeatings)
+                                    {
+                                        fhList.Add(f);
+                                    }
+                                    Control.Ins.SwtichFunctions(onoff == "on", fhList);
+                                    break;
+                                case ShowFunction.Light:
+                                    List<Function> lightList = new List<Function>();
+                                    foreach (var f in FunctionList.List.lights)
+                                    {
+                                        lightList.Add(f);
+                                    }
+                                    Control.Ins.SwtichFunctions(onoff == "on", lightList);
+                                    break;
+                                case ShowFunction.Electric:
+                                    List<Function> eleList = new List<Function>();
+                                    foreach (var f in FunctionList.List.electricals)
+                                    {
+                                        eleList.Add(f);
+                                    }
+                                    Control.Ins.SwtichFunctions(onoff == "on", eleList);
+                                    break;
+                            }
+
+
                         }
                     }
                     catch (Exception ex)

--
Gitblit v1.8.0