From a715181089be0d31cd737a5367ffd02690b9d77f Mon Sep 17 00:00:00 2001 From: wxr <464027401@qq.com> Date: 星期四, 12 十一月 2020 13:36:01 +0800 Subject: [PATCH] 20201112 --- HDL_ON/DriverLayer/Control.cs | 271 +++++++++++++++++++++++++++++++++++++----------------- 1 files changed, 185 insertions(+), 86 deletions(-) diff --git a/HDL_ON/DriverLayer/Control.cs b/HDL_ON/DriverLayer/Control.cs index 812afed..ea4b55e 100644 --- a/HDL_ON/DriverLayer/Control.cs +++ b/HDL_ON/DriverLayer/Control.cs @@ -1,13 +1,145 @@ using System; using System.Collections.Generic; using HDL_ON.Entity; -using Newtonsoft.Json.Linq; -using Shared; -namespace HDL_ON +namespace HDL_ON.DriverLayer { - public partial class Control + + /// <summary> + /// 閫氳鏂瑰紡 + /// </summary> + public enum CommunicationMode { + /// <summary> + /// 鏈湴udp + /// </summary> + local_BusUdp, + /// <summary> + /// 鏈湴tcp鏈嶅姟绔� + /// </summary> + tcp_local_server, + /// <summary> + /// 鏈湴tcp瀹㈡埛绔� + /// </summary> + tcp_local_client, + } + + + + public class Control + { + static Control _control; + public static Control ins + { + get + { + if (_control == null) + { + _control = new Control(); + } + return _control; + } + } + /// <summary> + /// 閫氳鍦板潃IP + /// </summary> + public string reportIp = "255.255.255.255"; + /// <summary> + /// tcp鏈嶅姟绔� + /// </summary> + public Control_TcpServer myTcpServer = null; + /// <summary> + /// tcp瀹㈡湇绔� + /// </summary> + public Control_TcpClient myTcpClient = null; + /// <summary> + /// 鏈湴udp + /// </summary> + public Control_Udp_Bus myUdp = null; + + /// <summary> + /// 閫氳鏂瑰紡 + /// </summary> + public CommunicationMode communicationMode; + + /// <summary> + /// 鏀瑰彉閫氳鏂瑰紡 + /// </summary> + public void ChangeCommunicationMode(CommunicationMode communicationMode) + { + this.communicationMode = communicationMode; + + + switch (this.communicationMode) + { + case CommunicationMode.local_BusUdp: + if (myUdp == null) + { + myUdp = new Control_Udp_Bus(); + } + UdpSocket._BusSocket.Start(); + if (myTcpServer != null) + { + myTcpClient.Close(); + myTcpClient = null; + } + if (myTcpClient != null) + { + myTcpClient.Close(); + myTcpClient = null; + } + break; + case CommunicationMode.tcp_local_server: + if (myTcpServer == null) + { + myTcpServer = new Control_TcpServer(); + myTcpServer.OpenServer(); + } + if (myTcpClient != null) + { + myTcpClient.Close(); + myTcpClient = null; + } + if(myUdp != null) + { + UdpSocket._BusSocket.Stop(); + myUdp = null; + } + break; + case CommunicationMode.tcp_local_client: + if (myTcpClient == null) + { + myTcpClient = new Control_TcpClient(reportIp); + myTcpClient.Connect(); + } + if (myTcpServer != null) + { + myTcpClient.Close(); + myTcpClient = null; + } + if (myUdp != null) + { + UdpSocket._BusSocket.Stop(); + myUdp = null; + } + break; + } + } + + /// <summary> + /// 鍦烘櫙鎺у埗鍏ュ彛 + /// </summary> + public void ControlScene(Scene scene) + { + if(myUdp!=null) + { + myUdp.ControlBusScenes(scene); + } + if(myTcpClient!= null) + { + ControlAProtocolScene(scene); + } + } /// <summary> /// 鍙戦�佸懡浠� @@ -16,107 +148,74 @@ /// </summary> /// <param name="commandString"></param> /// <param name="function"></param> - /// <param name="sendCount"></param> /// <returns></returns> - public static byte[] Send(string commandString, Function function, int sendCount = 3) + public void SendWriteCommand(Function function, Dictionary<string, string> commandDictionary) { - if (function.bus_Data!=null) + function.usageCount++; + function.refreshTime = DateTime.Now; + if (DB_ResidenceData.residenceData.GatewayType == 0) { try { - var ssd = function.GetSendJObject(commandString); - var revBytes = DataConversion_Bus(ssd, function.bus_Data, function); - return revBytes; + if(myUdp != null) + { + myUdp.WriteBusData(function, commandDictionary); + } } catch (Exception ex) { - MainPage.Log($"鍙戦�佹暟鎹紓甯革細 {ex.Message}"); + MainPage.Log($"鍙戦�佹暟鎹紓甯�: {ex.Message}"); } } else { - - //var jObject = new JObject { - //{ "DeviceAddr", 11}, - //{ "Epoint", 22}, - // { "Cluster_ID", 8 }, - // { "Command", 33}, - // { "SendMode", 2 } - //}; - //var data = new JObject { - // { "Level", 1 }, - // { "TransitionTime", 0 } - //}; - //jObject.Add("Data", data); - //return revBytes; + if (myTcpClient != null) + { + var sendDataObj = function.GetControlSendData(commandDictionary); + var sendJson = Newtonsoft.Json.JsonConvert.SerializeObject(sendDataObj); + var sendBytes = System.Text.Encoding.UTF8.GetBytes(sendJson); + myTcpClient.SendMessage(sendBytes); + } } - return null; } + /// <summary> + /// 鍙戦�佽鍙栧懡浠� + /// 鑷姩鍒ゆ柇鏄惁涓篈鍗忚璁惧 + /// </summary> + public void SendReadCommand(Function function) + { + function.refreshTime = DateTime.Now; + if (function.bus_Data != null) + { + try + { + //ReadBusData(function); + } + catch (Exception ex) + { + MainPage.Log($"鍙戦�佹暟鎹紓甯�: {ex.Message}"); + } + } + else + { + //var commandObj = function.GetSendJObject(CommandType_A.read); + //var commandString = Newtonsoft.Json.JsonConvert.SerializeObject(commandObj); + //var commandBytes = System.Text.Encoding.UTF8.GetBytes(commandString); + //MqttCommon.MqttRemoteSend(commandBytes); + } + } /// <summary> - /// 灏咥鍗忚鎺у埗鏁版嵁杞崲绋媌us鍗忚鐨勬帶鍒舵暟鎹� + /// 鎺у埗a鍗忚鍦烘櫙 /// </summary> - /// <param name="commandString"></param> - /// <returns></returns> - static byte[] DataConversion_Bus(JObject commandString,BusData bus_Data, Function function) + /// <param name="scene"></param> + static void ControlAProtocolScene(Scene scene) { - //鍙嶉: - //{ - //"Namespace": "HDL", "Command": "writeRespone", - //鈥淭ype鈥�:鈥漝evice鈥�, "objects": [{ - //"sid": "0001002019101209000025670100010001鈥�, "statue": "success鈥� - //}] } - try - { - var subnetId = bus_Data.SubnetID; - var deviceId = bus_Data.DeviceID; - var loopId = bus_Data.LoopID; - - var jobj = JObject.FromObject(commandString.GetValue("objects")); - var functionType = jobj.GetValue("sid").ToString().Substring(22, 2);//鎴彇24锛�25瀛楃鑾峰彇鎺у埗鐨勮澶囩殑绫诲瀷 - switch (commandString.GetValue("Command").ToString()) - { - case "write": - switch ((FunctionType)Enum.ToObject(typeof(FunctionType), Convert.ToInt32(functionType))) - { - case FunctionType.Light: - if (jobj.ContainsKey("brightness")) - { - var state = Convert.ToByte(jobj.GetValue("brightness")); - var bytes = new byte[] { Convert.ToByte(loopId), state, 0, 0 }; - return ControlBytesSendHasReturn(Command.SetSingleLight, subnetId, deviceId, bytes); - } - else if (jobj.ContainsKey("switch"))//缁х數鍣� - { - var state = jobj.GetValue("switch").ToString() == "0" ? (byte)0 : (byte)100; - var bytes = new byte[] { Convert.ToByte(loopId), state, 0, 0 }; - return ControlBytesSendHasReturn(Command.SetSingleLight, subnetId, deviceId, bytes); - } - break; - } - break; - case "read": - switch ((FunctionType)Enum.ToObject(typeof(FunctionType), Convert.ToInt32(functionType))) - { - case FunctionType.Light: - if (jobj.ContainsKey("switch"))//缁х數鍣� - { - var state = jobj.GetValue("switch").ToString() == "0" ? (byte)0 : (byte)100; - var bytes = new byte[] { Convert.ToByte(loopId), state, 0, 0 }; - return ControlBytesSendHasReturn(Command.ReadLightSingleLoopBrightness, subnetId, deviceId, bytes); - } - break; - } - break; - } - - } - catch (Exception ex) { - MainPage.Log($"DataConversion_Bus Erorr : {ex.Message}"); - } - - return null; + var sendSidObj = new AProtocolSendingObject(); + sendSidObj.time_stamp = ""; + sendSidObj.type = "device_sid"; + sendSidObj.command = "get_list_response"; } } -- Gitblit v1.8.0