From 0c1e29166e6b188939c092d16f87ce2a27662c5f Mon Sep 17 00:00:00 2001 From: tzy <hxb@hdlchina.com.cn> Date: 星期五, 26 三月 2021 10:11:38 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/temp-wxr' into dev-tzy --- HDL_ON/DAL/DriverLayer/Control_Udp.cs | 211 ++++++++++++++++++++++++++++++++++------------------ 1 files changed, 137 insertions(+), 74 deletions(-) diff --git a/HDL_ON/DAL/DriverLayer/Control_Udp.cs b/HDL_ON/DAL/DriverLayer/Control_Udp.cs index 73d66fe..0646116 100644 --- a/HDL_ON/DAL/DriverLayer/Control_Udp.cs +++ b/HDL_ON/DAL/DriverLayer/Control_Udp.cs @@ -288,50 +288,72 @@ case SPK.LightRGB: break; case SPK.FloorHeatStandard: - byte onoff_1 = 0; - byte setTemp_1 = 0; - byte mode_1 = 0; - foreach (var attr in f.status) + if (f.status.Find((obj)=>obj.key ==FunctionAttributeKey.Mode) == null) { - switch (attr.key) + foreach (var dic in f.status) { - case FunctionAttributeKey.OnOff: - if (attr.value == "on") - { - onoff_1 = 1; - } - else - { - onoff_1 = 0; - } - break; - case FunctionAttributeKey.SetTemp: - setTemp_1 = Convert.ToByte(attr.value); - break; - case FunctionAttributeKey.Mode: - switch (attr.value) - { - case "day": - mode_1 = 2; - break; - case "night": - mode_1 = 3; - break; - case "away": - mode_1 = 4; - break; - case "normal": - mode_1 = 1; - break; - case "timer": - mode_1 = 5; - break; - } - break; + switch (dic.key) + { + case FunctionAttributeKey.OnOff: + ControlBytesSend(Command.InstructionPanelKey, f.localFunction.bus.SubnetID, f.localFunction.bus.DeviceID, new byte[] { 20, dic.value.ToString() == "on" ? (byte)1 : (byte)0, f.localFunction.bus.LoopId }); + break; + case "mode": + ControlBytesSend(Command.InstructionPanelKey, f.localFunction.bus.SubnetID, f.localFunction.bus.DeviceID, new byte[] { 21, Convert.ToByte(dic.value), f.localFunction.bus.LoopId }); + break; + case FunctionAttributeKey.SetTemp: + ControlBytesSend(Command.InstructionPanelKey, f.localFunction.bus.SubnetID, f.localFunction.bus.DeviceID, new byte[] { + 25, Convert.ToByte(dic.value), f.localFunction.bus.LoopId }); + break; + } } } - ControlBytesSend(Command.SetFloorHeat, f.localFunction.bus.SubnetID, f.localFunction.bus.DeviceID, new byte[] { + else + { + byte onoff_1 = 0; + byte setTemp_1 = 0; + byte mode_1 = 0; + foreach (var attr in f.status) + { + switch (attr.key) + { + case FunctionAttributeKey.OnOff: + if (attr.value == "on") + { + onoff_1 = 1; + } + else + { + onoff_1 = 0; + } + break; + case FunctionAttributeKey.SetTemp: + setTemp_1 = Convert.ToByte(attr.value); + break; + case FunctionAttributeKey.Mode: + switch (attr.value) + { + case "day": + mode_1 = 2; + break; + case "night": + mode_1 = 3; + break; + case "away": + mode_1 = 4; + break; + case "normal": + mode_1 = 1; + break; + case "timer": + mode_1 = 5; + break; + } + break; + } + } + ControlBytesSend(Command.SetFloorHeat, f.localFunction.bus.SubnetID, f.localFunction.bus.DeviceID, new byte[] { f. localFunction.bus.LoopId, onoff_1, 0, setTemp_1, mode_1, setTemp_1, setTemp_1, setTemp_1, 0, 0 }); + } break; case SPK.ElectricSocket: foreach (var attr in f.status) @@ -518,9 +540,9 @@ { case SPK.AcStandard: var ac = new AC(); - ControlBytesSend(Command.SetACMode, subnetId, deviceId, new byte[] { function.bus.LoopId, 0, 32, 32, 32, 32, 32, 0, function.trait_on_off.curValue.ToString() == "on" ? (byte)1 : (byte)0, - ac.GetModeIndex(function), - ac.GetFanIndex(function), Convert.ToByte(function.GetAttrState(FunctionAttributeKey.SetTemp)), 0 }); + //ControlBytesSend(Command.SetACMode, subnetId, deviceId, new byte[] { function.bus.LoopId, 0, 32, 32, 32, 32, 32, 0, function.trait_on_off.curValue.ToString() == "on" ? (byte)1 : (byte)0, + // ac.GetModeIndex(function), + // ac.GetFanIndex(function), Convert.ToByte(function.GetAttrState(FunctionAttributeKey.SetTemp)), 0 }); foreach (var dic in commandDictionary) { switch (dic.Key) @@ -534,7 +556,7 @@ case "fan": ControlBytesSend(Command.InstructionPanelKey, function.bus.SubnetID, function.bus.DeviceID, new byte[] { 5, ac.GetFanIndex(function), function.bus.LoopId }); break; - case "temp": + case FunctionAttributeKey.SetTemp: byte modeKey = 4; switch (ac.GetModeIndex(function)) { @@ -573,42 +595,83 @@ case SPK.FloorHeatStandard: if (function.Fh_Mode_Temp.Count == 4) { - var onoffString = function.trait_on_off.curValue.ToString(); - byte b1 = 1; - if(onoffString == "off") + if (function.GetAttribute(FunctionAttributeKey.Mode) == null) { - b1 = 0; - } - var wm = fhTemp.GetWorkModeIndex(function); - if (wm > 0) - { - b1 += (byte)(16 + wm); - } - if (commandDictionary.ContainsKey("temp")) - { - var dicTempString = ""; - commandDictionary.TryGetValue("temp", out dicTempString); - var dicTemp = Convert.ToByte(dicTempString); - var mode = function.GetAttrState(FunctionAttributeKey.Mode); - switch (mode) + foreach (var dic in commandDictionary) { - case "day": - function.Fh_Mode_Temp["day"] = dicTemp; - break; - case "night": - function.Fh_Mode_Temp["night"] = dicTemp; - break; - case "away": - function.Fh_Mode_Temp["away"] = dicTemp; - break; - case "normal": - function.Fh_Mode_Temp["normal"] = dicTemp; - break; + switch (dic.Key) + { + case FunctionAttributeKey.OnOff: + ControlBytesSend(Command.InstructionPanelKey, function.bus.SubnetID, function.bus.DeviceID, new byte[] { 20, function.trait_on_off.curValue.ToString() == "on" ? (byte)1 : (byte)0, function.bus.LoopId }); + break; + case "mode": + ControlBytesSend(Command.InstructionPanelKey, function.bus.SubnetID, function.bus.DeviceID, new byte[] { 21, fhTemp.GetModeIndex(function), function.bus.LoopId }); + break; + case FunctionAttributeKey.SetTemp: + byte modeKey = 25; + switch (fhTemp.GetModeIndex(function)) + { + case 1: + modeKey = 25; + break; + case 2: + modeKey = 26; + break; + case 3: + modeKey = 27; + break; + case 4: + modeKey = 28; + break; + } + ControlBytesSend(Command.InstructionPanelKey, function.bus.SubnetID, function.bus.DeviceID, new byte[] { + modeKey, Convert.ToByte(function.GetAttrState(FunctionAttributeKey.SetTemp)), function.bus.LoopId }); + break; + default: + MainPage.Log($"鍔熻兘鏈敮鎸� : {dic.Key}"); + break; + } } } - var tt = fhTemp.GetTempUintIndex(function); - ControlBytesSend(Command.SetFloorHeat, subnetId, deviceId, new byte[] { function.bus.LoopId, b1, + else + { + var onoffString = function.trait_on_off.curValue.ToString(); + byte b1 = 1; + if (onoffString == "off") + { + b1 = 0; + } + var wm = fhTemp.GetWorkModeIndex(function); + if (wm > 0) + { + b1 += (byte)(16 + wm); + } + if (commandDictionary.ContainsKey("temp")) + { + var dicTempString = ""; + commandDictionary.TryGetValue("temp", out dicTempString); + var dicTemp = Convert.ToByte(dicTempString); + var mode = function.GetAttrState(FunctionAttributeKey.Mode); + switch (mode) + { + case "day": + function.Fh_Mode_Temp["day"] = dicTemp; + break; + case "night": + function.Fh_Mode_Temp["night"] = dicTemp; + break; + case "away": + function.Fh_Mode_Temp["away"] = dicTemp; + break; + case "normal": + function.Fh_Mode_Temp["normal"] = dicTemp; + break; + } + } + var tt = fhTemp.GetTempUintIndex(function); + ControlBytesSend(Command.SetFloorHeat, subnetId, deviceId, new byte[] { function.bus.LoopId, b1, (byte)tt,fhTemp.GetModeIndex(function), function.Fh_Mode_Temp["normal"], function.Fh_Mode_Temp["day"], function.Fh_Mode_Temp["night"], function.Fh_Mode_Temp["away"], 0, 0 }); + } } break; } -- Gitblit v1.8.0