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 |  123 ++++++++++++++++++++++++++++------------
 1 files changed, 85 insertions(+), 38 deletions(-)

diff --git a/HDL_ON/DriverLayer/Control.cs b/HDL_ON/DriverLayer/Control.cs
index 812afed..f1eb051 100644
--- a/HDL_ON/DriverLayer/Control.cs
+++ b/HDL_ON/DriverLayer/Control.cs
@@ -16,17 +16,16 @@
         /// </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 static void Send(string commandType, Function function)
         {
             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)
                 {
@@ -50,7 +49,6 @@
                 //jObject.Add("Data", data);
                 //return revBytes;
             }
-            return null;
         }
 
 
@@ -59,7 +57,7 @@
         /// </summary>
         /// <param name="commandString"></param>
         /// <returns></returns>
-        static byte[] DataConversion_Bus(JObject commandString,BusData bus_Data, Function function)
+        static void ControlBusData(Function function,string command)//JObject commandString,BusData bus_Data, 
         {
             //鍙嶉:
             //{
@@ -69,45 +67,97 @@
             //}] }
             try
             {
-                var subnetId = bus_Data.SubnetID;
-                var deviceId = bus_Data.DeviceID;
-                var loopId = bus_Data.LoopID;
+                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 (commandString.GetValue("Command").ToString())
+                //var jobj = JObject.FromObject(commandString.GetValue("objects"));
+                //var functionType = jobj.GetValue("sid").ToString().Substring(22, 2);//鎴彇24锛�25瀛楃鑾峰彇鎺у埗鐨勮澶囩殑绫诲瀷
+                switch (command)
                 {
                     case "write":
-                        switch ((FunctionType)Enum.ToObject(typeof(FunctionType), Convert.ToInt32(functionType)))
+                        switch (function.functionCategory)
                         {
                             case FunctionType.Light:
-                                if (jobj.ContainsKey("brightness"))
+                                var light = function as Light;
+                                switch (light.functionType)
                                 {
-                                    var state = Convert.ToByte(jobj.GetValue("brightness"));
-                                    var bytes = new byte[] { Convert.ToByte(loopId), state, 0, 0 };
-                                    return ControlBytesSendHasReturn(Command.SetSingleLight, subnetId, deviceId, bytes);
+                                    case "RGB":
+                                        byte b = 100;//寮�鍏虫搷浣滀緷鎹畂n_off瀛楁锛屽疄闄呭紑鍏冲�间緷鎹産rightness锛屽綋on_off涓烘墦寮�锛宐rightness涓嶈兘涓�0
+                                        if (light.on_off == 0)
+                                        {
+                                            b = 0;
+                                        }
+                                        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;
                                 }
-                                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;
+                            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;
-                        }
+                        //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;
                 }
 
@@ -115,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