From 5eeafe3af80bfd88306bd8ad9e76c8f4b51ca35f Mon Sep 17 00:00:00 2001 From: hxb <hxb@hdlchina.com.cn> Date: 星期四, 17 十二月 2020 14:16:20 +0800 Subject: [PATCH] 增加本地发送的重发机制 --- HDL_ON/DAL/DriverLayer/Packet.cs | 38 +++++++++++++++++++------------------- 1 files changed, 19 insertions(+), 19 deletions(-) diff --git a/HDL_ON/DAL/DriverLayer/Packet.cs b/HDL_ON/DAL/DriverLayer/Packet.cs index 1ab2a79..4f04a07 100644 --- a/HDL_ON/DAL/DriverLayer/Packet.cs +++ b/HDL_ON/DAL/DriverLayer/Packet.cs @@ -116,8 +116,8 @@ { case Command.SetSingleLightACK: var queryList = new List<Function>(); - queryList.AddRange(DB_ResidenceData.functionList.electricals); - queryList.AddRange(DB_ResidenceData.functionList.lights); + queryList.AddRange(FunctionList.List.electricals); + queryList.AddRange(FunctionList.List.lights); foreach (var updataObj in queryList) { if (updataObj.GetBusId() == subnetID + "_" + deviceID + "_" + receiveBytes[0]) @@ -163,7 +163,7 @@ case Command.ReadLightAllLoopBrightnessACK: for (int i = 0; i < receiveBytes[0]; i++) { - var light = DB_ResidenceData.functionList.lights.Find((obj) => obj.bus_Data.SubnetID == subnetID && obj.bus_Data.DeviceID == deviceID && obj.bus_Data.loopId == (i + 1)); + var light = FunctionList.List.lights.Find((obj) => obj.bus_Data.SubnetID == subnetID && obj.bus_Data.DeviceID == deviceID && obj.bus_Data.loopId == (i + 1)); if (light != null) { if (light.functionType != FunctionType.RGB) @@ -191,7 +191,7 @@ } else { - var e = DB_ResidenceData.functionList.electricals.Find((obj) => obj.bus_Data.SubnetID == subnetID && obj.bus_Data.DeviceID == deviceID && obj.bus_Data.loopId == i); + var e = FunctionList.List.electricals.Find((obj) => obj.bus_Data.SubnetID == subnetID && obj.bus_Data.DeviceID == deviceID && obj.bus_Data.loopId == i); if (e != null) { var fan = e as Fan; @@ -220,7 +220,7 @@ break; case Command.SetLogicLoopColorACK: case Command.ReadLogicLoopColorACK: - foreach (var rgb in DB_ResidenceData.functionList.lights) + foreach (var rgb in FunctionList.List.lights) { if (rgb.GetBusId() == subnetID + "_" + deviceID + "_" + receiveBytes[0]) { @@ -247,7 +247,7 @@ break; case Command.SetCurtainModelStutasACK: case Command.ReadCurtainStutasACK: - foreach (var curtain in DB_ResidenceData.functionList.curtains) + foreach (var curtain in FunctionList.List.curtains) { if (curtain.bus_Data.SubnetID == subnetID && curtain.bus_Data.DeviceID == deviceID) { @@ -304,12 +304,12 @@ break; case Command.SetACModeACK: case Command.ReadACModeACK: - foreach (var ac in DB_ResidenceData.functionList.aCs) + foreach (var ac in FunctionList.List.aCs) { if (ac.GetBusId() == subnetID + "_" + deviceID + "_" + receiveBytes[0]) { ac.curTempType = receiveBytes[1]; - ac.indoorTemp = receiveBytes[2]; + ac.trait_IndoorTemp.curValue = receiveBytes[2]; ac.trait_on_off.curValue = receiveBytes[8] == 1 ? "on" : "off"; ac.curModeIndex = receiveBytes[9]; ac.curFanIndex = receiveBytes[10]; @@ -359,7 +359,7 @@ break; case Command.ReadFloorHeatACK: case Command.SetFloorHeatACK: - foreach (var fh in DB_ResidenceData.functionList.floorHeatings) + foreach (var fh in FunctionList.List.floorHeatings) { if (fh.GetBusId() == subnetID + "_" + deviceID + "_" + receiveBytes[0]) { @@ -443,7 +443,7 @@ case Command.ReadDeviceLoopInfoACK: FunctionType dt = (FunctionType)(11 * 256 + receiveBytes[1]); string tag = receiveBytes[1] + "_" + subnetID + "_" + deviceID + "_" + receiveBytes[2]; - foreach (var sensor in DB_ResidenceData.functionList.sensorsEnvironmentalScience) + foreach (var sensor in FunctionList.List.sensorsEnvironmentalScience) { if (sensor.bus_Data != null) { @@ -476,7 +476,7 @@ break; case Command.New_Analog_Quantity_BROADCAST: string tag1 = receiveBytes[1] + "_" + subnetID + "_" + deviceID + "_" + receiveBytes[2]; - foreach (var sensor in DB_ResidenceData.functionList.sensorsEnvironmentalScience) + foreach (var sensor in FunctionList.List.sensorsEnvironmentalScience) { if (sensor.bus_Data != null) { @@ -524,7 +524,7 @@ { break; } - foreach (var ac in DB_ResidenceData.functionList.aCs) + foreach (var ac in FunctionList.List.aCs) { if (ac.GetBusId() == subnetID + "_" + deviceID + "_" + reACPanel) { @@ -559,11 +559,11 @@ break; case Command.ReadPanleTempACK://1944 case Command.PanleBroadcastTemp: - foreach (var ac in DB_ResidenceData.functionList.aCs) + foreach (var ac in FunctionList.List.aCs) { if (ac.GetBusId() == subnetID + "_" + deviceID + "_" + receiveBytes[0]) { - ac.indoorTemp = receiveBytes[1]; + ac.trait_IndoorTemp.curValue = receiveBytes[1]; FunctionPage.UpdataStates(ac); } } @@ -572,10 +572,10 @@ var mac = ByteToHex16(receiveBytes[5]) + ByteToHex16(receiveBytes[6]) + ByteToHex16(receiveBytes[7]) + ByteToHex16(receiveBytes[8]) + ByteToHex16(receiveBytes[9]) + ByteToHex16(receiveBytes[10]) + ByteToHex16(receiveBytes[11]) + ByteToHex16(receiveBytes[12]); var Name = Encoding.GetEncoding("gb2312").GetString(receiveBytes, 13, 20).Trim('\0'); ; MainPage.Log($"name : {Name} ; mac : {mac}"); - if (DB_ResidenceData.residenceData.residenceGatewayMAC == mac) + if (DB_ResidenceData.Instance.residenceGatewayMAC == mac) { - DriverLayer.Control.Ins.GatewayOnline = true; - DriverLayer.Control.Ins.IsRemote = false; + Control.Ins.GatewayOnline = true; + Control.Ins.IsRemote = false; DAL.Mqtt.MqttClient.DisConnectRemote();//鏂紑mqtt } break; @@ -644,12 +644,12 @@ receiveFlag += string.Format("{0},{1}", usefulBytes[0], usefulBytes[1]); break; case Command.ReadRemark: - DriverLayer.Control.Ins.myUdp.ReceiveReadRemark(usefulBytes); + new Control_Udp().ReceiveReadRemark(usefulBytes); break; default: break; } - DriverLayer.Control.Ins.myUdp.ReceiveRepeatManager(receiveFlag); + Control_Udp.ReceiveRepeatManager(receiveFlag,usefulBytes); } catch (Exception ex) { -- Gitblit v1.8.0