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