From 8983da138cb92e35b0bbeaece1cf1c454a5a79d4 Mon Sep 17 00:00:00 2001
From: wei <kaede@kaededeMacBook-Air.local>
Date: 星期二, 01 十二月 2020 16:31:28 +0800
Subject: [PATCH] 20201201

---
 HDL_ON/Entity/Function/Function.cs |  284 +++++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 207 insertions(+), 77 deletions(-)

diff --git a/HDL_ON/Entity/Function/Function.cs b/HDL_ON/Entity/Function/Function.cs
index be61b11..d5646d3 100644
--- a/HDL_ON/Entity/Function/Function.cs
+++ b/HDL_ON/Entity/Function/Function.cs
@@ -13,23 +13,12 @@
         public Function()
         {
         }
-        /// <summary>
-        /// 鏁版嵁瀛樺偍鏂囦欢鍚�
-        /// </summary>
-        [Newtonsoft.Json.JsonIgnore]
-        public string savePath
-        {
-            get
-            {
-                return "FunctionData_" + sid;
-            }
-        }
 
         #region base info
         /// <summary>
         /// HDL缁熶竴鍗忚鏍煎紡锛�14bytes
         /// 涓句緥锛� 鏉ユ簮   鍘傚晢浠g爜 閫氳鏂瑰紡  浜у搧鏃堕棿鎴�   浜у搧绫诲埆 鐗╂ā鍨嬬被  閫氶亾鍙�   澶у皬绫诲埆
-        //       1byte	1byte	1byte	  4byte	    1byte	2byte   2byte   2byte
+        ///       1byte	1byte	1byte	  4byte	    1byte	2byte   2byte   2byte
         /// 鏉ユ簮锛�00	榛樿鍘熺敓鎬佺郴缁熸暟鎹� 銆�01	缃戝叧鎴栬�呭叾浠朅璁惧銆�02	璋冭瘯杞欢銆�03	APP搴旂敤绋嬪簭銆�04	绗笁鏂圭綉鍏虫垨鑰呭钩鍙�
         /// 鍘傚晢浠g爜锛�01	HDL
         /// 閫氳鏂瑰紡锛�01	HDL Bus銆�02	Zigbee銆�03 KNX銆�04 Z-Wave
@@ -49,25 +38,75 @@
         /// 灏忕被鍒�	1byte	锛堥鐣欙級
         /// </summary>
         public string sid = "0301011234567801012301230123";
+        /// <summary>
+        /// 澶囨敞
+        /// </summary>
+        public string name;
+        /// <summary>
+        /// 璁惧ID
+        /// 浜戠璐熻矗鐢熸垚
+        /// </summary>
+        public string deviceId = "0";
+        /// <summary>
+        /// 璁惧spk
+        /// </summary>
+        public string spk = "";
+        /// <summary>
+        /// 鍔熻兘绫诲埆
+        /// 濡傦細绌鸿皟绫汇�佺伅鍏夌被銆佺獥甯樼被
+        /// </summary>
+        public FunctionCategory functionCategory
+        {
+            get
+            {
+                try
+                {
+                    var _functionCategoryString = sid.Substring(16, 2);
+                    var _functionCategory = Convert.ToInt32(_functionCategoryString, 16);
+                    return (FunctionCategory)Enum.ToObject(typeof(FunctionCategory), _functionCategory);
+                }
+                catch (Exception ex)
+                {
+                    MainPage.Log($"get FunctionCategory error : {ex.Message}");
+                    return FunctionCategory.UnKown;
+                }
+            }
+        }
+        /// <summary>
+        /// 鍔熻兘绫诲瀷
+        /// </summary>
+        public FunctionType functionType
+        {
+            get
+            {
+                var _functionTypeString = sid.Substring(16, 4);
+                return (FunctionType)Enum.ToObject(typeof(FunctionType), Convert.ToInt32(_functionTypeString, 16));
+            }
+        }
 
         /// <summary>
         /// A鍗忚鍔熻兘鐨勭壒鎬�
         /// 濡傦細鏄疉C鍔熻兘锛氱壒鎬э細on_off,mode,fan,temperature
         /// attri
         /// </summary>
-        public List<FunctionAttributes> function = new List<FunctionAttributes>();
+        public List<FunctionAttributes> attributes = new List<FunctionAttributes>();
 
         /// <summary>
         /// 鎴块棿ID鍒楄〃
         /// 璇ュ姛鑳芥坊鍔犲埌鍒版埧闂村垪琛�
         /// </summary>
-        public List<string> roomIdList = new List<string>();
+        public List<string> roomIds = new List<string>();
 
         /// <summary>
         /// bus鍗忚鏁版嵁鏍煎紡
         /// 浣跨敤A鍗忚鎺у埗鏃讹紝鏀瑰睘鎬т负绌�
         /// </summary>
         public BusData bus_Data;
+        /// <summary>
+        /// 鏄惁鏀惰棌
+        /// </summary>
+        public bool collect = false;
+        #endregion
         /// <summary>
         /// 寤舵椂
         /// </summary>
@@ -102,43 +141,6 @@
                 return text;
             }
         }
-        #endregion
-
-        /// <summary>
-        /// 鍔熻兘绫诲埆
-        /// 濡傦細绌鸿皟绫汇�佺伅鍏夌被銆佺獥甯樼被
-        /// </summary>
-        public FunctionCategory functionCategory
-        {
-            get
-            {
-                try
-                {
-                    var _functionCategoryString = sid.Substring(16, 2);
-                    var _functionCategory = Convert.ToInt32(_functionCategoryString, 16);
-                    return (FunctionCategory)Enum.ToObject(typeof(FunctionCategory), _functionCategory);
-                }
-                catch (Exception ex)
-                {
-                    MainPage.Log($"get FunctionCategory error : {ex.Message}");
-                    return FunctionCategory.UnKown;
-                }
-            }
-        }
-
-        public FunctionType functionType
-        {
-            get
-            {
-                var _functionTypeString = sid.Substring(16, 4);
-                return (FunctionType)Enum.ToObject(typeof(FunctionType), Convert.ToInt32(_functionTypeString, 16));
-            }
-        }
-
-        /// <summary>
-        /// 澶囨敞
-        /// </summary>
-        public string name;
 
         /// <summary>
         /// 鏈�鍚庢帶鍒剁殑涓�娆$姸鎬�
@@ -154,7 +156,7 @@
             {
                 if (_trait_on_off == null)
                 {
-                    _trait_on_off = function.Find((obj) => obj.key == "on_off");
+                    _trait_on_off = attributes.Find((obj) => obj.key == "on_off");
                     //鎵句笉鍒板睘鎬ч渶瑕佸0鏄庝竴涓紝闃叉鎶ラ敊闂��
                     if (_trait_on_off == null)
                     {
@@ -175,11 +177,6 @@
             //    _trait_on_off = value;
             //}
         }
-
-        /// <summary>
-        /// 鏄惁鏀惰棌
-        /// </summary>
-        public bool collection = false;
 
         /// <summary>
         /// 浣跨敤娆℃暟
@@ -204,7 +201,7 @@
             string busId = "";
             if (bus_Data != null)
             {
-                busId = bus_Data.SubnetID + "_" + bus_Data.DeviceID + "_" + bus_Data.LoopID;
+                busId = bus_Data.SubnetID + "_" + bus_Data.DeviceID + "_" + bus_Data.loopId;
             }
             return busId;
         }
@@ -216,7 +213,7 @@
         public string GetRoomListName()
         {
             string roomNameList = "";
-            foreach(var roomId in roomIdList)
+            foreach(var roomId in roomIds)
             {
                 var findRoom = DB_ResidenceData.rooms.Find(obj => obj.sid == roomId);
                 if (findRoom == null)
@@ -236,13 +233,38 @@
             return roomNameList;
         }
         /// <summary>
+        /// 鏁版嵁瀛樺偍鏂囦欢鍚�
+        /// </summary>
+        [Newtonsoft.Json.JsonIgnore]
+        public string savePath
+        {
+            get
+            {
+                return "FunctionData_" + sid;
+            }
+        }
+        /// <summary>
         /// 淇濆瓨鍔熻兘鏁版嵁
         /// </summary>
         public void SaveFunctionData()
         {
             var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(this));
-            FileUtils.WriteFileByBytes("FunctionData_" + this.sid, ssd);
+            FileUtils.WriteFileByBytes( savePath + this.sid, ssd);
             MainPage.Log($"Save FunctionData {this.functionType} : {this.sid}");
+        }
+
+        /// <summary>
+        /// 杞崲鎴愬満鏅姛鑳藉璞�
+        /// </summary>
+        /// <returns></returns>
+        public SceneFunction ConvertSceneFunction()
+        {
+            var sFunc = new SceneFunction();
+            foreach (var attr in attributes)
+            {
+                sFunc.status.Add(new SceneFunctionStatus() { key = attr.key, value = attr.curValue.ToString() });
+            }
+            return sFunc;
         }
 
         /// <summary>
@@ -251,21 +273,21 @@
         public DateTime refreshTime = DateTime.MinValue;
 
         /// <summary>
-        /// 鑾峰彇鎺у埗鍙戦�佹暟鎹�
+        /// 鑾峰彇鏈湴鎺у埗鏁版嵁
         /// </summary>
-        public AprotocolControlObj GetControlSendData(Dictionary<string, string> commandDictionary)
+        public GatewayAlinkControlObj GetGatewayAlinkControlData(Dictionary<string, string> commandDictionary)
         {
-            var sendDataObj = new AprotocolControlObj();
+            var sendDataObj = new GatewayAlinkControlObj();
             sendDataObj.id = Control.Ins.msg_id.ToString();
             sendDataObj.time_stamp = Control.Ins.Get_TimeStamp();
 
 
-            var acd = new AprotocolControlData();
+            var acd = new AlinkControlData();
             acd.sid = sid;
 #if DEBUG
             acd.sid = "0001016FB925AB02020100010101";
 #endif
-            var aca = new AprotocolControlAttribute();
+            var aca = new AlinkControlAttributes();
             foreach(var dic in commandDictionary)
             {
                 aca.key = dic.Key;
@@ -277,14 +299,53 @@
 
             return sendDataObj;
         }
+        /// <summary>
+        /// 鑾峰彇Api鎺у埗鏁版嵁
+        /// </summary>
+        /// <returns></returns>
+        public ApiAlinkControlActionObj GetApiControlData(Dictionary<string,string> keyValues)
+        {
+            ApiAlinkControlActionObj aaao = new ApiAlinkControlActionObj();
+            aaao.deviceId = this.deviceId;
+            aaao.spk = this.spk;
+            foreach (var kv in keyValues)
+            {
+                aaao.attributes.Add(new AlinkControlAttributes()
+                {
+                    key = kv.Key,
+                    value = kv.Value,
+                });
+            }
+            return aaao;
+        }
     }
 
     /// <summary>
+    /// 杩滅▼鎺у埗
+    /// api a鍗忚鎺у埗鍔ㄤ綔瀵硅薄
+    /// </summary>
+    public class ApiAlinkControlActionObj
+    {
+        /// <summary>
+        /// 璁惧ID
+        /// </summary>
+        public string deviceId = "0";
+        /// <summary>
+        /// spk
+        /// 鍒�:light.switch
+        /// </summary>
+        public string spk = "";
+
+        public List<AlinkControlAttributes> attributes = new List<AlinkControlAttributes>();
+    }
+
+    /// <summary>
+    /// 鏈湴鎺у埗
     /// A鍗忚鎺у埗鏁版嵁鐨勫璞�
     /// </summary>
-    public class AprotocolControlObj
+    public class GatewayAlinkControlObj
     {
-        public List<AprotocolControlData> objects = new List<AprotocolControlData>();
+        public List<AlinkControlData> objects = new List<AlinkControlData>();
 
         public string time_stamp = "";
         public string id = "";
@@ -292,19 +353,26 @@
     /// <summary>
     /// A鍗忚鎺у埗鏁版嵁
     /// </summary>
-    public class AprotocolControlData
+    public class AlinkControlData
     {
-        
         public string sid = "";
-        public List<AprotocolControlAttribute> status = new List<AprotocolControlAttribute>();
+        public List<AlinkControlAttributes> status = new List<AlinkControlAttributes>();
     }
     /// <summary>
-    /// A鍗忚鎺у埗灞炴�у璞�
+    /// a鍗忚鎺у埗鍔ㄤ綔鏁版嵁
     /// </summary>
-    public class AprotocolControlAttribute
+    public class AlinkControlAttributes
     {
-        public string key;
-        public string value;
+        /// <summary>
+        /// 灞炴�у悕
+        /// 鍒�:on_off
+        /// </summary>
+        public string key = "";
+        /// <summary>
+        /// 灞炴�у��
+        /// 鍒�:on
+        /// </summary>
+        public string value = "";
     }
 
     /// <summary>
@@ -329,17 +397,14 @@
         /// 鏈�灏忓��
         /// </summary>
         public int min;
-
         /// <summary>
         /// 鏁版嵁绫诲瀷
         /// </summary>
         public string data_type = "";
-
         /// <summary>
         /// 褰撳墠鍊�
         /// </summary>
         public object curValue = new object();
-
 
         //----app鑷畾涔�
         /// <summary>
@@ -607,6 +672,48 @@
         }
     }
     /// <summary>
+    /// 鍔熻兘灞炴�ч敭鍚嶅垪琛�
+    /// </summary>
+    public static class FunctionAttributeKey
+    {
+        /// <summary>
+        /// 寮�鍏�
+        /// </summary>
+        public const string OnOff = "on_off";
+        /// <summary>
+        /// 浜害
+        /// </summary>
+        public const string Brightness = "brightness";
+        /// <summary>
+        /// 棰滆壊
+        /// </summary>
+        public const string Color = "color";
+        /// <summary>
+        /// 妯″紡
+        /// </summary>
+        public const string Mode = "mode";
+        /// <summary>
+        /// 椋庨��
+        /// </summary>
+        public const string FanSpeed = "fan";
+        /// <summary>
+        /// 娓╁害
+        /// </summary>
+        public const string Temp = "temperature";
+        /// <summary>
+        /// 寤舵椂
+        /// </summary>
+        public const string Delay = "delay";
+        /// <summary>
+        /// 鑹叉俯
+        /// </summary>
+        public const string CCT = "cct";
+        /// <summary>
+        /// 鐧惧垎姣�
+        /// </summary>
+        public const string Percent = "percent";
+    }
+    /// <summary>
     /// 璁惧鍔熻兘oid
     /// </summary>
     public class FunctionOid
@@ -619,4 +726,27 @@
         public string channels;
     }
 
+    /// <summary>
+    /// 鍏煎鏃у崗璁帶鍒�
+    /// </summary>
+    public class BusData
+    {
+        public string addresses = "FFFF";
+        public byte SubnetID
+        {
+            get
+            {
+                return Convert.ToByte(addresses.Substring(0, 2), 16);
+            }
+        }
+        public byte DeviceID
+        {
+            get
+            {
+                return Convert.ToByte(addresses.Substring(2, 2), 16);
+            }
+        }
+        public byte loopId;
+    }
+
 }

--
Gitblit v1.8.0