From af1cb3ecd0f4b0589e00b28f7f9edccf39e6e12b Mon Sep 17 00:00:00 2001
From: wxr <464027401@qq.com>
Date: 星期四, 10 九月 2020 16:15:11 +0800
Subject: [PATCH] 202009101

---
 HDL_ON/DriverLayer/Control.cs |  154 +++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 119 insertions(+), 35 deletions(-)

diff --git a/HDL_ON/DriverLayer/Control.cs b/HDL_ON/DriverLayer/Control.cs
index 968b248..6f71392 100644
--- a/HDL_ON/DriverLayer/Control.cs
+++ b/HDL_ON/DriverLayer/Control.cs
@@ -8,9 +8,34 @@
 {
     public partial class Control
     {
+        /// <summary>
+        /// 鍙戦�佸懡浠�
+        /// </summary>
         public static void Send(Function function)
         {
-            ControlBusScenes(function as Scene);
+            switch(function.functionCategory)
+            {
+                case FunctionCategory.Scene:
+                    ControlScene(function as Scene);
+                    break;
+
+            }
+        }
+
+        /// <summary>
+        /// 鍦烘櫙鎺у埗鍏ュ彛
+        /// </summary>
+        /// <param name="scene"></param>
+        static void ControlScene(Scene scene)
+        {
+            if (DB_ResidenceData.residenceData.GatewayType == 0)
+            {
+                ControlBusScenes(scene);
+            }
+            else
+            {
+                ControlAProtocolScene(scene);
+            }
         }
 
         /// <summary>
@@ -79,47 +104,106 @@
         /// </summary>
         static void ControlBusScenes(Scene scene)
         {
-            foreach(var busSceneData in scene.bus_SceneData)
+            foreach (var function in scene.sceneFunctionList)
             {
-                foreach(var function in DB_ResidenceData.functionList.GetAllDeviceFunctionList())
+                switch (function.functionType)
                 {
-                    if(busSceneData.Key == function.sid)
-                    {
-                        switch (function.functionType)
+                    case FunctionType.Curtain:
+                        byte curtainState = 0;
+                        if (function.trait_on_off.value.ToString() == "on")
                         {
-                            case FunctionType.Curtain:
-                                ControlBytesSend(Command.SetCurtainModelStutas, function.bus_Data.SubnetID, function.bus_Data.DeviceID, busSceneData.Value);
+                            curtainState = 1;
+                        }
+                        else if (function.trait_on_off.value.ToString() =="off")
+                        {
+                            curtainState = 2;
+                        }
+                        ControlBytesSend(Command.SetCurtainModelStutas, function.bus_Data.SubnetID, function.bus_Data.DeviceID,
+                            new byte[] {
+                                function.bus_Data.LoopID,
+                                curtainState,
+                            });
+                        break;
+                    case FunctionType.AC:
+                        var aC = function as AC;
+                        ControlBytesSend(Command.InstructionPanelKey, aC.bus_Data.SubnetID, aC.bus_Data.DeviceID, new byte[] { 3, aC.trait_on_off.value.ToString() == "on" ? (byte)1 : (byte)0, aC.bus_Data.LoopID });
+                        ControlBytesSend(Command.InstructionPanelKey, aC.bus_Data.SubnetID, aC.bus_Data.DeviceID, new byte[] { 6, aC.curModeIndex, aC.bus_Data.LoopID });
+                        ControlBytesSend(Command.InstructionPanelKey, aC.bus_Data.SubnetID, aC.bus_Data.DeviceID, new byte[] { 5, aC.curFanIndex, aC.bus_Data.LoopID });
+                        byte modeKey = 4;
+                        switch (aC.curModeIndex)
+                        {
+                            case 3:
+                                modeKey = 8;
                                 break;
-                            case FunctionType.AC:
-                                ControlBytesSend(Command.SetACMode, function.bus_Data.SubnetID, function.bus_Data.DeviceID, busSceneData.Value);
+                            case 0:
+                                modeKey = 4;
                                 break;
-                            case FunctionType.Relay:
-                            case FunctionType.Dimmer:
-                                ControlBytesSend(Command.SetSingleLight, function.bus_Data.SubnetID, function.bus_Data.DeviceID, busSceneData.Value);
+                            case 1:
+                                modeKey = 7;
                                 break;
-                            case FunctionType.RGB:
-                                ControlBytesSend(Command.SetLogicLoopColor, function.bus_Data.SubnetID, function.bus_Data.DeviceID, busSceneData.Value);
+                            case 4:
+                                modeKey = 19;
                                 break;
-                            case FunctionType.FloorHeating:
-                                var fh = function as FloorHeating;
-                                if (fh.modeTemp.Count == 4)
-                                {
-                                    byte b1 = fh.trait_on_off.value.ToString() == "on" ? (byte)1 : (byte)0;
-                                    if (fh.workMode > 0)
-                                    {
-                                        b1 += (byte)(16 + fh.workMode);
-                                    }
-                                    ControlBytesSend(Command.SetFloorHeat, function.bus_Data.SubnetID, function.bus_Data.DeviceID, new byte[] { fh.bus_Data.LoopID, b1, (byte)fh.curTempType, fh.curModeIndex, fh.modeTemp["normal"], fh.modeTemp["day"], fh.modeTemp["night"], fh.modeTemp["away"], 0, 0 });
-                                }
-                                break;
-                            case FunctionType.Socket:
-                                var s = function as SwitchSocket;
-                                ControlBytesSend(Command.SetSingleLight, function.bus_Data.SubnetID, function.bus_Data.DeviceID, new byte[] { s.bus_Data.LoopID, s.trait_on_off.value.ToString() == "on" ? (byte)100 : (byte)0 });
+                            case 2:
+                                modeKey = 2;
                                 break;
                         }
-                    }
+                        ControlBytesSend(Command.InstructionPanelKey, aC.bus_Data.SubnetID, aC.bus_Data.DeviceID, new byte[] { modeKey, Convert.ToByte(aC.trait_temp.value), aC.bus_Data.LoopID });
+
+                        break;
+                    case FunctionType.Relay:
+                    case FunctionType.Dimmer:
+                        byte brightness = 0;
+                        if(function.trait_on_off.value.ToString() == "on")
+                        {
+                            var brightnessTrait = function.function.Find((obj) => obj.name == "brightness");
+                            if (brightnessTrait != null)
+                            {
+                                brightness = Convert.ToByte(brightnessTrait.value);
+                            }
+                        }
+                        ControlBytesSend(Command.SetSingleLight, function.bus_Data.SubnetID, function.bus_Data.DeviceID,
+                            new byte[] {
+                                function.bus_Data.LoopID,brightness
+                            });
+                        break;
+                    case FunctionType.RGB:
+                        //ControlBytesSend(Command.SetLogicLoopColor, function.bus_Data.SubnetID, function.bus_Data.DeviceID,
+                        //    new byte[] {
+                        //    });
+                        break;
+                    case FunctionType.FloorHeating:
+                        var fh = function as FloorHeating;
+                        if (fh.modeTemp.Count == 4)
+                        {
+                            byte b1 = fh.trait_on_off.value.ToString() == "on" ? (byte)1 : (byte)0;
+                            if (fh.workMode > 0)
+                            {
+                                b1 += (byte)(16 + fh.workMode);
+                            }
+                            ControlBytesSend(Command.SetFloorHeat, function.bus_Data.SubnetID, function.bus_Data.DeviceID, new byte[] { fh.bus_Data.LoopID, b1, (byte)fh.curTempType, fh.curModeIndex, fh.modeTemp["normal"], fh.modeTemp["day"], fh.modeTemp["night"], fh.modeTemp["away"], 0, 0 });
+                        }
+                        break;
+                    case FunctionType.Socket:
+                        var s = function as SwitchSocket;
+                        ControlBytesSend(Command.SetSingleLight, function.bus_Data.SubnetID, function.bus_Data.DeviceID, new byte[] { s.bus_Data.LoopID, s.trait_on_off.value.ToString() == "on" ? (byte)100 : (byte)0 });
+                        break;
                 }
             }
+        }
+        /// <summary>
+        /// 鎺у埗a鍗忚鍦烘櫙
+        /// </summary>
+        /// <param name="scene"></param>
+        static void ControlAProtocolScene(Scene scene)
+        {
+            var sendSidObj = new AProtocolSendingObject();
+            //sendSidObj.from_oid = "";
+            //sendSidObj.to_oid = "";
+            sendSidObj.time_stamp = "";
+            sendSidObj.type = "device_sid";
+            sendSidObj.command = "get_list_response";
+            //杞崲鎴恇us闇�瑕佺殑鏁版嵁鏍煎紡
         }
 
         /// <summary>
@@ -230,13 +314,13 @@
                                     switch (dic.Key)
                                     {
                                         case "on_off":
-                                            Control.ControlBytesSend(Command.InstructionPanelKey, aC.bus_Data.SubnetID, aC.bus_Data.DeviceID, new byte[] { 3, aC.trait_on_off.value.ToString() == "on" ? (byte)1 : (byte)0, aC.bus_Data.LoopID });
+                                            ControlBytesSend(Command.InstructionPanelKey, aC.bus_Data.SubnetID, aC.bus_Data.DeviceID, new byte[] { 3, aC.trait_on_off.value.ToString() == "on" ? (byte)1 : (byte)0, aC.bus_Data.LoopID });
                                             break;
                                         case "mode":
-                                            Control.ControlBytesSend(Command.InstructionPanelKey, aC.bus_Data.SubnetID, aC.bus_Data.DeviceID, new byte[] { 6, aC.curModeIndex, aC.bus_Data.LoopID });
+                                            ControlBytesSend(Command.InstructionPanelKey, aC.bus_Data.SubnetID, aC.bus_Data.DeviceID, new byte[] { 6, aC.curModeIndex, aC.bus_Data.LoopID });
                                             break;
                                         case "fan":
-                                            Control.ControlBytesSend(Command.InstructionPanelKey, aC.bus_Data.SubnetID, aC.bus_Data.DeviceID, new byte[] { 5, aC.curFanIndex, aC.bus_Data.LoopID });
+                                            ControlBytesSend(Command.InstructionPanelKey, aC.bus_Data.SubnetID, aC.bus_Data.DeviceID, new byte[] { 5, aC.curFanIndex, aC.bus_Data.LoopID });
                                             break;
                                         case "temp":
                                             byte modeKey = 4;
@@ -258,7 +342,7 @@
                                                     modeKey = 2;
                                                     break;
                                             }
-                                            Control.ControlBytesSend(Command.InstructionPanelKey, aC.bus_Data.SubnetID, aC.bus_Data.DeviceID, new byte[] { modeKey, Convert.ToByte(aC.trait_temp.value), aC.bus_Data.LoopID });
+                                            ControlBytesSend(Command.InstructionPanelKey, aC.bus_Data.SubnetID, aC.bus_Data.DeviceID, new byte[] { modeKey, Convert.ToByte(aC.trait_temp.value), aC.bus_Data.LoopID });
                                             break;
                                         default:
                                             MainPage.Log($"鍔熻兘鏈敮鎸� : {dic.Key}");

--
Gitblit v1.8.0