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