From f35f1397c980efdc2542dff7aaa23b1a7dbb65e7 Mon Sep 17 00:00:00 2001
From: 陈嘉乐 <cjl@hdlchina.com.cn>
Date: 星期三, 16 十二月 2020 10:53:34 +0800
Subject: [PATCH] 2020-12-16-1

---
 HDL_ON/Entity/Function/Function.cs |  472 ++++++++++++++++++++++------------------------------------
 1 files changed, 182 insertions(+), 290 deletions(-)

diff --git a/HDL_ON/Entity/Function/Function.cs b/HDL_ON/Entity/Function/Function.cs
index 1a642f7..0fb021f 100644
--- a/HDL_ON/Entity/Function/Function.cs
+++ b/HDL_ON/Entity/Function/Function.cs
@@ -42,10 +42,10 @@
         /// 浜у搧鏃堕棿鎴筹細4bytes	浠�2020骞�1鏈�1鏃ョ畻鍑虹殑鏃堕棿鎴�0.1s涓哄崟浣� 
         /// 浜у搧绫诲埆锛�01	璋冨厜鍣ㄣ��02 缁х數鍣ㄣ��03	骞叉帴鐐规ā鍧椼��04	浼犳劅鍣ㄣ��05 闈㈡澘
         /// 鐗╂ā鍨嬬被鍨嬶細
-		///     01	寮�鍏崇被锛�01 寮�鍏炽��02 鎻掑骇銆�03	
-		///     02	鐓ф槑锛� 01 寮�鍏炽��02	璋冨厜銆�03	鑹叉俯銆�04	LED
+        ///     01	寮�鍏崇被锛�01 寮�鍏炽��02 鎻掑骇銆�03	
+        ///     02	鐓ф槑锛� 01 寮�鍏炽��02	璋冨厜銆�03	鑹叉俯銆�04	LED
         ///     03	閬槼锛� 01	绐楀笜鐢垫満銆�02 鐧惧彾绐椼��03 寮�鍚堝笜銆�04 鍗峰笜
-		///     04	鎭掓俯鍣細01 绌鸿皟銆�02 鍦版殩銆�03 姣涚粏绌鸿皟
+        ///     04	鎭掓俯鍣細01 绌鸿皟銆�02 鍦版殩銆�03 姣涚粏绌鸿皟
         ///     05	鏂伴		
         ///     06	褰遍煶		
         ///     07	闊充箰		
@@ -89,15 +89,16 @@
                 }
             }
         }
-        /// <summary>
-        /// 鍔熻兘绫诲瀷
-        /// </summary>
+        ///// <summary>
+        ///// 鍔熻兘绫诲瀷
+        ///// </summary>
         public FunctionType functionType
         {
             get
             {
                 var _functionTypeString = sid.Substring(16, 4);
                 return (FunctionType)Enum.ToObject(typeof(FunctionType), Convert.ToInt32(_functionTypeString, 16));
+
             }
         }
 
@@ -123,6 +124,25 @@
         /// 鏄惁鏀惰棌
         /// </summary>
         public bool collect = false;
+        /// <summary>
+        /// 鏄惁鍦ㄧ嚎
+        /// </summary>
+        public bool online = true;
+        /// <summary>
+        /// 浜戠鏁版嵁鍒涘缓鐨勬椂闂�
+        /// </summary>
+        public string createTime = "";
+        /// <summary>
+        /// 浜戠鏁版嵁淇敼鐨勬渶鍚庢椂闂�
+        /// </summary>
+        public string modifyTime = "";
+        /// <summary>
+        /// 鍒犻櫎鏍囪
+        /// 闇�瑕佸垹闄ゆ暟鎹椂锛屾爣璁颁负锛歵rue
+        /// 鐢变簯绔垹闄ゆ垚鍔熶箣鍚庯紝杩斿洖鏁版嵁鍐嶆竻闄ゆ湰鍦版暟鎹�
+        /// </summary>
+        public bool DeleteSign = false;
+
         #endregion
         /// <summary>
         /// 寤舵椂
@@ -213,7 +233,7 @@
         /// </summary>
         public int fixedSerialNumber = int.MaxValue;
 
-        public string GetBusId ()
+        public string GetBusId()
         {
             string busId = "";
             if (bus_Data != null)
@@ -230,9 +250,9 @@
         public string GetRoomListName()
         {
             string roomNameList = "";
-            foreach(var roomId in roomIds)
+            foreach (var roomId in roomIds)
             {
-                var findRoom = DB_ResidenceData.Rooms.Find(obj => obj.uid == roomId);
+                var findRoom = SpatialInfo.CurrentSpatial.RoomList.Find(obj => obj.roomId == roomId);
                 if (findRoom == null)
                 {
                     continue;
@@ -263,12 +283,29 @@
         /// <summary>
         /// 淇濆瓨鍔熻兘鏁版嵁
         /// </summary>
-        public void SaveFunctionData()
+        public void SaveFunctionData(bool upSevser)
         {
-            var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(this));
-            FileUtils.WriteFileByBytes( savePath + this.sid, ssd);
-            MainPage.Log($"Save FunctionData {this.functionType} : {this.sid}");
+            if (upSevser)
+            {
+                var pm = new DAL.Server.HttpServerRequest();
+                var pack = pm.UpdataDevcieInfo(this);
+                if (pack.Code == DAL.Server.StateCode.SUCCESS)
+                {
+                    var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(this));
+                    Common.FileUtlis.Files.WriteFileByBytes(savePath, ssd);
+                }
+                else
+                {
+                    Utlis.ShowTip(Language.StringByID(StringId.EditFunctionInfoFail) + "\r\nCode:" + pack.Code);
+                }
+            }
+            else
+            {
+                var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(this));
+                Common.FileUtlis.Files.WriteFileByBytes(savePath, ssd);
+            }
         }
+      
 
         /// <summary>
         /// 杞崲鎴愬満鏅姛鑳藉璞�
@@ -280,6 +317,7 @@
             foreach (var attr in attributes)
             {
                 sFunc.status.Add(new SceneFunctionStatus() { key = attr.key, value = attr.curValue.ToString() });
+                sFunc.sid = this.sid;
             }
             return sFunc;
         }
@@ -292,20 +330,17 @@
         /// <summary>
         /// 鑾峰彇鏈湴鎺у埗鏁版嵁
         /// </summary>
-        public GatewayAlinkControlObj GetGatewayAlinkControlData(Dictionary<string, string> commandDictionary)
+        public AlinkFunctionStatusObj GetGatewayAlinkControlData(Dictionary<string, string> commandDictionary)
         {
-            var sendDataObj = new GatewayAlinkControlObj();
+            var sendDataObj = new AlinkFunctionStatusObj();
             sendDataObj.id = Control.Ins.msg_id.ToString();
             sendDataObj.time_stamp = Control.Ins.Get_TimeStamp();
 
 
             var acd = new AlinkControlData();
             acd.sid = sid;
-#if DEBUG
-            acd.sid = "0001016FB925AB02020100010101";
-#endif
             var aca = new AlinkControlAttributes();
-            foreach(var dic in commandDictionary)
+            foreach (var dic in commandDictionary)
             {
                 aca.key = dic.Key;
                 aca.value = dic.Value;
@@ -320,7 +355,7 @@
         /// 鑾峰彇Api鎺у埗鏁版嵁
         /// </summary>
         /// <returns></returns>
-        public ApiAlinkControlActionObj GetApiControlData(Dictionary<string,string> keyValues)
+        public ApiAlinkControlActionObj GetApiControlData(Dictionary<string, string> keyValues)
         {
             ApiAlinkControlActionObj aaao = new ApiAlinkControlActionObj();
             aaao.deviceId = this.deviceId;
@@ -354,18 +389,29 @@
         public string spk = "";
 
         public List<AlinkControlAttributes> attributes = new List<AlinkControlAttributes>();
+        //[Newtonsoft.Json.JsonIgnore]
+        public BusData bus = new BusData();
     }
 
     /// <summary>
-    /// 鏈湴鎺у埗
     /// A鍗忚鎺у埗鏁版嵁鐨勫璞�
     /// </summary>
-    public class GatewayAlinkControlObj
+    public class AlinkFunctionStatusObj
     {
         public List<AlinkControlData> objects = new List<AlinkControlData>();
 
         public string time_stamp = "";
         public string id = "";
+    }
+    /// <summary>
+    /// 鏈湴鐘舵�佽鍙�
+    /// A鍗忚鐘舵�佽鍙栨牸寮忓璞�
+    /// </summary>
+    public class AlinkReadFunctionStatusObj
+    {
+        public string id = "0";
+        public List<Dictionary<string, string>> objects = new List<Dictionary<string, string>>();
+        public string time_stamp = "";
     }
     /// <summary>
     /// A鍗忚鎺у埗鏁版嵁
@@ -409,11 +455,11 @@
         /// <summary>
         /// 鏈�澶у��
         /// </summary>
-        public int max;
+        public int max=100;
         /// <summary>
         /// 鏈�灏忓��
         /// </summary>
-        public int min;
+        public int min=0;
         /// <summary>
         /// 鏁版嵁绫诲瀷
         /// </summary>
@@ -423,270 +469,6 @@
         /// </summary>
         public object curValue = new object();
 
-        //----app鑷畾涔�
-        /// <summary>
-        /// 灞炴�у�煎崟浣�
-        /// </summary>
-        string _uintString;
-        [Newtonsoft.Json.JsonIgnore]
-        public string uintString
-        {
-            get
-            {
-                if (!string.IsNullOrEmpty(_uintString))
-                {
-                    return _uintString;
-                }
-                var us = "";
-                switch (key)
-                {
-                    case "temperature":
-                    case "set_temperature":
-                        us = "掳C";
-                        break;
-                    case "percent":
-                    case "brightness":
-                        us = "%";
-                        break;
-                }
-                return us;
-            }
-        }
-
-        /// <summary>
-        /// 灞炴�у悕绉版樉绀烘枃鏈�
-        /// 涓嫳鏂囨樉绀�
-        /// </summary>
-        [Newtonsoft.Json.JsonIgnore]
-        public string name_text
-        {
-            get
-            {
-                string text = "";
-                switch (key)
-                {
-                    case "on_off":
-                        text = Language.StringByID(StringId.OnOff);
-                        break;
-                    case "brightness":
-                        text = Language.StringByID(StringId.Brightness);
-                        break;
-                    case "color":
-                        text = Language.StringByID(StringId.ColorValue);
-                        break;
-                    case "mode":
-                        text = Language.StringByID(StringId.Mode);
-                        break;
-                    case "fan":
-                        text = Language.StringByID(StringId.FanSpeed);
-                        break;
-                    case "temperature":
-                case "set_temperature":
-                        text = Language.StringByID(StringId.Temp);
-                        break;
-                    case "delay":
-                        text = Language.StringByID(StringId.Delay);
-                        break;
-                    case "cct":
-                        text = "CCT";
-                        break;
-                    //case "fade_time":
-                    case "percent":
-                        text = Language.StringByID(StringId.PercentAdjustment);
-                        break;
-                        //case "lock":
-                        //case "ico":
-                        //case "swing":
-                        //case "set_point":
-                        //case "pm25":
-                        //case "volume":
-                        //case "vol_step":
-                        //case "source":
-                        //case "treble":
-                        //case "bass":
-                        //case "playlist":
-                        //case "song_name":
-                        //case "current_status":
-                        //case "enable":
-                        //case "lux":
-                        //case "adjust_value":
-                        //case "range":
-                        //case "humidity":
-                        //case "type":
-                        //case "state":
-                        //case "sensitivity":
-                        //case "pm25value":
-                }
-                return text;
-            }
-        }
-
-        /// <summary>
-        /// 鑾峰彇褰撳墠灞炴�х殑鏄剧ず鏂囨湰
-        /// 涓嫳鏂囨樉绀�
-        /// </summary>
-        public string GetCurValueText()
-        {
-            return GetValueText(curValue.ToString());
-        }
-
-        /// <summary>
-        /// 鑾峰彇鎸囧畾灞炴�х殑鏄剧ず鏂囨湰
-        /// 涓嫳鏂囨樉绀�
-        /// </summary>
-        public string GetValueText(string value)
-        {
-            string text = "";
-            value = value.Replace("{}", "");
-            switch (key)
-            {
-                case "on_off":
-                    text = value == "on" ? Language.StringByID(StringId.On) : Language.StringByID(StringId.OFF);
-                    break;
-                case "temperature":
-                case "set_temperature":
-                case "brightness":
-                case "percent":
-                    if (value == "")
-                    {
-                        this.curValue = this.min;
-                        text = this.min.ToString();
-                    }
-                    else
-                    {
-                        text = value;
-                    }
-                    break;
-                //case "color":
-                case "mode":
-                    switch (value)
-                    {
-                        //----绌鸿皟
-                        case "auto":
-                            text = Language.StringByID(StringId.Auto);
-                            break;
-                        case "cool":
-                            text = Language.StringByID(StringId.Cool);
-                            break;
-                        case "heat":
-                            text = Language.StringByID(StringId.Heat);
-                            break;
-                        case "dry":
-                            text = Language.StringByID(StringId.Dry);
-                            break;
-                        case "fan":
-                            text = Language.StringByID(StringId.AirSupply);
-                            break;
-                        //-----鍦扮儹
-                        case "day":
-                            text = Language.StringByID(StringId.Day);
-                            break;
-                        case "night":
-                            text = Language.StringByID(StringId.Night);
-                            break;
-                        case "away":
-                            text = Language.StringByID(StringId.Away);
-                            break;
-                        case "normal":
-                            text = Language.StringByID(StringId.Normal);
-                            break;
-                        case "timer":
-                            text = Language.StringByID(StringId.Timer);
-                            break;
-                        default:
-                            if (this.value.Contains("cool"))
-                            {
-                                this.curValue = "cool";
-                                text = Language.StringByID(StringId.Cool);
-                            }
-                            else if (this.value.Contains("day"))
-                            {
-                                this.curValue = "day";
-                                text = Language.StringByID(StringId.Day);
-                            }
-                            else
-                            {
-                                foreach (var v in this.value)
-                                {
-                                    this.curValue = v;
-                                    text = GetCurValueText();
-                                }
-                            }
-                            break;
-                    }
-                    break;
-                case "fan":
-                    switch (value)
-                    {
-                        case "high":
-                            text = Language.StringByID(StringId.HighWindSpeed);
-                            break;
-                        case "medium":
-                            text = Language.StringByID(StringId.MiddleWindSpeed);
-                            break;
-                        case "low":
-                            text = Language.StringByID(StringId.LowWindSpeed);
-                            break;
-                        case "auto":
-                            text = Language.StringByID(StringId.Auto);
-                            break;
-                        default:
-                            if (this.value.Contains("low"))
-                            {
-                                this.curValue = "low";
-                                text = Language.StringByID(StringId.LowWindSpeed);
-                            }
-                            else
-                            {
-                                foreach (var v in this.value)
-                                {
-                                    this.curValue = v;
-                                    text = GetCurValueText();
-                                }
-                            }
-                            break;
-                    }
-                    break;
-                //case "delay":
-                //case "cct":
-                //case "fade_time":
-                //case "lock":
-                //case "ico":
-                //case "swing":
-                //case "set_point":
-                //case "pm25":
-                //case "volume":
-                //case "vol_step":
-                //case "source":
-                //case "treble":
-                //case "bass":
-                //case "playlist":
-                //case "song_name":
-                //case "current_status":
-                //case "enable":
-                //case "lux":
-                //case "adjust_value":
-                //case "range":
-                //case "humidity":
-                //case "type":
-                //case "state":
-                //case "sensitivity":
-                //case "pm25value":
-                case "high":
-                    text = Language.StringByID(StringId.HighWindSpeed);
-                    break;
-                case "medium":
-                    text = Language.StringByID(StringId.MiddleWindSpeed);
-                    break;
-                case "low":
-                    text = Language.StringByID(StringId.LowWindSpeed);
-                    break;
-                case "auto":
-                    text = Language.StringByID(StringId.Auto);
-                    break;
-            }
-            return text;
-        }
     }
     /// <summary>
     /// 鍔熻兘灞炴�ч敭鍚嶅垪琛�
@@ -714,9 +496,9 @@
         /// </summary>
         public const string FanSpeed = "fan";
         /// <summary>
-        /// 娓╁害
+        /// 璁剧疆娓╁害
         /// </summary>
-        public const string Temp = "temperature";
+        public const string SetTemp = "set_temp";
         /// <summary>
         /// 寤舵椂
         /// </summary>
@@ -729,6 +511,10 @@
         /// 鐧惧垎姣�
         /// </summary>
         public const string Percent = "percent";
+        /// <summary>
+        /// 瀹ゅ唴娓╁害
+        /// </summary>
+        public const string IndoorTemp = "room_temp";
     }
     /// <summary>
     /// 璁惧鍔熻兘oid
@@ -749,6 +535,7 @@
     public class BusData
     {
         public string addresses = "FFFF";
+        [Newtonsoft.Json.JsonIgnore]
         public byte SubnetID
         {
             get
@@ -756,6 +543,7 @@
                 return Convert.ToByte(addresses.Substring(0, 2), 16);
             }
         }
+        [Newtonsoft.Json.JsonIgnore]
         public byte DeviceID
         {
             get
@@ -766,4 +554,108 @@
         public byte loopId;
     }
 
+    public static class SPK
+    {
+        /// <summary>
+        /// 锛堝紑鍏崇伅锛�
+        /// </summary>
+        public const string LightSwitch = "light.switch";
+        /// <summary>
+        /// 锛堣皟鍏夌伅锛�
+        /// </summary>
+        public const string LightDimming = "light.dimming";
+        /// <summary>
+        /// 锛圧GB鐏級
+        /// </summary>
+        public const string LightRGB = "light.rgb";
+        /// <summary>
+        /// 锛圧GBW鐏級
+        /// </summary>
+        public const string LightRGBW = "light.rgbw";
+        /// <summary>
+        /// 锛圕CT鐏級
+        /// </summary>
+        public const string LightCCT = "light.cct";
+        /// <summary>
+        /// 锛堝紑鍏崇獥甯橈級
+        /// </summary>
+        public const string CurtainSwitch = "curtain.switch";
+        /// <summary>
+        /// 锛堝紑鍚堝笜锛�
+        /// </summary>
+        public const string CurtainTrietex = "curtain.trietex";
+        /// <summary>
+        /// 锛堢櫨鍙跺笜锛�
+        /// </summary>
+        public const string CurtainShades = "curtain.shades";
+        /// <summary>
+        /// 锛堝嵎甯橈級
+        /// </summary>
+        public const string CurtainRoller = "curtain.roller";
+        /// <summary>
+        /// 锛堢┖璋冿級
+        /// </summary>
+        public const string AcStandard = "ac.standard";
+        /// <summary>
+        /// 锛堝湴鐑級
+        /// </summary>
+        public const string FloorHeatStandard = "floorHeat.standard";
+        /// <summary>
+        /// 锛堟柊椋庯級
+        /// </summary>
+        public const string AirFreshStandard = "airFresh.standard";
+        /// <summary>
+        /// 锛堥煶涔愶級
+        /// </summary>
+        public const string MusicStandard = "music.standard";
+        /// <summary>
+        /// 锛堜寒搴︿紶鎰熷櫒锛�
+        /// </summary>
+        public const string SensorLight = "sensor.light";
+        /// <summary>
+        /// 锛堟俯搴︿紶鎰熷櫒锛�
+        /// </summary>
+        public const string SensorTemperature = "sensor.temperature";
+        /// <summary>
+        /// (绾㈠绉诲姩浼犳劅鍣�)
+        /// </summary>
+        public const string SensorPir = "sensor.pir";
+        /// <summary>
+        /// 锛堥棬绐椾紶鎰熷櫒锛�
+        /// </summary>
+        public const string SensorDoorWindow = "sensor.doorwindow";
+        /// <summary>
+        /// 锛圥M2.5浼犳劅鍣級
+        /// </summary>
+        public const string SensorPm25 = "sensor.pm25";
+        /// <summary>
+        /// co2浼犳劅鍣�
+        /// </summary>
+        public const string SensorCO2 = "sensor.co2";
+        /// <summary>
+        /// tvoc浼犳劅鍣�
+        /// </summary>
+        public const string SensorTVOC = "sensor.tvoc";
+        /// <summary>
+        /// 婀垮害浼犳劅鍣�
+        /// </summary>
+        public const string SensorHumidity = "sensor.humidity";
+        /// <summary>
+        /// 锛堝共鎺ョ偣锛�
+        /// </summary>
+        public const string DryContact = "dryContact.standard";
+        /// <summary>
+        /// 瀹剁數銆佹彃搴�
+        /// </summary>
+        public const string ElectricSocket = "electric.socket ";
+        /// <summary>
+        /// 瀹剁數銆佺數瑙�
+        /// </summary>
+        public const string ElectricTV = "electric.tv";
+        /// <summary>
+        /// 瀹剁數銆侀鎵�
+        /// </summary>
+        public const string ElectricFan = "electric.fan";
+    }
+
 }

--
Gitblit v1.8.0