From b69d7735274b8d0f741da8a6bb8b8e1347477a5a Mon Sep 17 00:00:00 2001
From: wxr <464027401@qq.com>
Date: 星期四, 19 三月 2020 17:14:16 +0800
Subject: [PATCH] 20200319

---
 HDL_ON/DriverLayer/Control.cs |  130 +++++++++++++++++++++++++++++++------------
 1 files changed, 93 insertions(+), 37 deletions(-)

diff --git a/HDL_ON/DriverLayer/Control.cs b/HDL_ON/DriverLayer/Control.cs
index ddc4a95..f1eb051 100644
--- a/HDL_ON/DriverLayer/Control.cs
+++ b/HDL_ON/DriverLayer/Control.cs
@@ -9,16 +9,23 @@
     public partial class Control
     {
 
-
-        public static byte[] Send(string commandString, Function function, int sendCount = 3)
+        /// <summary>
+        /// 鍙戦�佸懡浠�
+        /// 鑷姩鍒ゆ柇鏄惁涓篈鍗忚璁惧锛�
+        /// 涓嶆槸A鍗忚锛岃嚜鍔ㄨ浆鍖朾us鍛戒护鏁版嵁
+        /// </summary>
+        /// <param name="commandString"></param>
+        /// <param name="function"></param>
+        /// <returns></returns>
+        public static void Send(string commandType, Function function)
         {
-            if (!string.IsNullOrEmpty(function.bus_Data))
+            if (function.bus_Data!=null)
             {
                 try
                 {
-                    var ssd = function.GetSendJObject(commandString);
-                    var revBytes = DataConversion_Bus(ssd, function.bus_Data, function);
-                    return revBytes;
+                    //var ssd = function.GetSendJObject(commandString);
+                    ControlBusData(function, commandType);
+                    //return revBytes;
                 }
                 catch (Exception ex)
                 {
@@ -42,7 +49,6 @@
                 //jObject.Add("Data", data);
                 //return revBytes;
             }
-            return null;
         }
 
 
@@ -51,7 +57,7 @@
         /// </summary>
         /// <param name="commandString"></param>
         /// <returns></returns>
-        static byte[] DataConversion_Bus(JObject commandString,string bus_Data, Function function)
+        static void ControlBusData(Function function,string command)//JObject commandString,BusData bus_Data, 
         {
             //鍙嶉:
             //{
@@ -61,44 +67,97 @@
             //}] }
             try
             {
-                var sss = JObject.Parse(bus_Data);
-                var subnetId = Convert.ToByte(sss.GetValue("SubnetID").ToString());
-                var deviceId = Convert.ToByte(sss.GetValue("DeviceID").ToString());
-                var loopId = sss.GetValue("LoopID").ToString();
-                switch (commandString.GetValue("Command").ToString())
+                var subnetId = function.bus_Data.SubnetID;
+                var deviceId = function.bus_Data.DeviceID;
+                var loopId = function.bus_Data.LoopID;
+
+                //var jobj = JObject.FromObject(commandString.GetValue("objects"));
+                //var functionType = jobj.GetValue("sid").ToString().Substring(22, 2);//鎴彇24锛�25瀛楃鑾峰彇鎺у埗鐨勮澶囩殑绫诲瀷
+                switch (command)
                 {
                     case "write":
-                        var jobj = JObject.FromObject(commandString.GetValue("objects"));
-                        var functionType = jobj.GetValue("sid").ToString().Substring(24, 2);//鎴彇24锛�25瀛楃鑾峰彇鎺у埗鐨勮澶囩殑绫诲瀷
-                        switch ((FunctionType)Enum.ToObject(typeof(FunctionType), Convert.ToInt32(functionType)))
+                        switch (function.functionCategory)
                         {
                             case FunctionType.Light:
-                                if (jobj.ContainsKey("Switch"))//缁х數鍣�
+                                var light = function as Light;
+                                switch (light.functionType)
                                 {
-                                    var state = jobj.GetValue("Switch").ToString() == "0" ? (byte)0 : (byte)100;
-                                    if (jobj.ContainsKey("Dimmer"))
-                                    {   //璋冨厜鍣�
-                                        var brightness = Convert.ToByte(jobj.GetValue("Dimmer").ToString());
-                                        if (brightness > 0)
+                                    case "RGB":
+                                        byte b = 100;//寮�鍏虫搷浣滀緷鎹畂n_off瀛楁锛屽疄闄呭紑鍏冲�间緷鎹産rightness锛屽綋on_off涓烘墦寮�锛宐rightness涓嶈兘涓�0
+                                        if (light.on_off == 0)
                                         {
-                                            (function as Dimmer).brightness = brightness;
+                                            b = 0;
                                         }
-                                        (function as Dimmer).state = state;
-                                        var bytes = new byte[] { Convert.ToByte(loopId), brightness, 0, 0 };
-                                        (function as Dimmer).lastState = Language.StringByID(StringId.Brightness) + " : " + brightness.ToString() + "%";
-                                        return ControlBytesSendHasReturn(Command.SetSingleLight, subnetId, deviceId, bytes);
-                                    }
-                                    else//缁х數鍣�
-                                    {
-                                        var bytes = new byte[] { Convert.ToByte(loopId), state, 0, 0 };
-                                        return ControlBytesSendHasReturn(Command.SetSingleLight, subnetId, deviceId, bytes);
-                                    }
+                                        else
+                                        {
+                                            b = (byte)light.brightness == 0 ? (byte)100 : (byte)light.brightness;
+                                        }
+                                        var bytes = new byte[] { function.bus_Data.LoopID,
+                                            b,
+                                            254, 0,0,3,
+                                            light.redColor,light.greenColor,
+                                            light.blueColor,
+                                            0,0};
+                                        ControlBytesSend(Command.SetLogicLoopColor, subnetId, deviceId, bytes);
+                                        break;
+                                    case "Dimmer":
+                                        byte b1 = 100;
+                                        if (light.on_off == 0)
+                                        {
+                                            b1 = 0;
+                                        }
+                                        else
+                                        {
+                                            b1 = (byte)light.brightness == 0 ? (byte)100 : (byte)light.brightness;
+                                        }
+                                        ControlBytesSend(Command.SetSingleLight, subnetId, deviceId, new byte[] {
+                                            function.bus_Data.LoopID,
+                                            b1,
+                                            0, 0 });
+                                        break;
+                                    case "Relay":
+                                        ControlBytesSend(Command.SetSingleLight, subnetId, deviceId, new byte[] { function.bus_Data.LoopID, light.on_off == 1 ? (byte)100 : (byte)0, 0, 0 });
+                                        break;
                                 }
+                                break;
+                            case FunctionType.Curtain:
+                                //if (jobj.ContainsKey("Curtain"))//on/off/stop
+                                //{
+                                //    byte state = 0;
+                                //    switch (jobj.GetValue("switch").ToString())
+                                //    {
+                                //        case "stop":
+                                //            state = 0;
+                                //            break;
+                                //        case "on":
+                                //            state = 1;
+                                //            break;
+                                //        case "off":
+                                //            state = 2;
+                                //            break;
+                                //    }
+                                //    return ControlBytesSendHasReturn(Command.SetCurtainModelStutas, subnetId, deviceId, new byte[] { function.bus_Data.LoopID, state });
+                                //}
+                                //else if (jobj.ContainsKey("MotorCurtain") || jobj.ContainsKey("RollingShutter"))
+                                //{
+                                //    var state = Convert.ToByte(jobj.GetValue("openLevel").ToString());
+                                //    return ControlBytesSendHasReturn(Command.SetCurtainModelStutas, subnetId, deviceId, new byte[] { 17, state });
+                                //}
                                 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;
                 }
 
@@ -106,9 +165,6 @@
             catch (Exception ex) {
                 MainPage.Log($"DataConversion_Bus Erorr : {ex.Message}");
             }
-
-            return null;
         }
-
     }
 }
\ No newline at end of file

--
Gitblit v1.8.0