From 0f2e0147e8990e913d16d99bc1b94fb6bc53abd7 Mon Sep 17 00:00:00 2001 From: 陈嘉乐 <cjl@hdlchina.com.cn> Date: 星期四, 03 十二月 2020 15:35:42 +0800 Subject: [PATCH] 2020-12-03-1 --- HDL_ON/Entity/Function/Function.cs | 769 ++++++++++++++++++++++++++++++++++++++++++++++------------ 1 files changed, 607 insertions(+), 162 deletions(-) diff --git a/HDL_ON/Entity/Function/Function.cs b/HDL_ON/Entity/Function/Function.cs index 8f996e3..86daa59 100644 --- a/HDL_ON/Entity/Function/Function.cs +++ b/HDL_ON/Entity/Function/Function.cs @@ -1,57 +1,25 @@ 锘縰sing System; using System.Collections.Generic; -using System.Linq; -using Newtonsoft.Json.Linq; -using HDL_ON; +using HDL_ON.DriverLayer; +using Shared; namespace HDL_ON.Entity { /// <summary> - /// 鍔熻兘灞炴�� - /// 灞炴�у瓧娈佃В鏋愶細attri :灞炴�у唴瀹癸紝value 灞炴�х殑鍊硷紝max 鏈�澶у�� min 鏈�灏忓�� + /// 鍔熻兘绫昏兘婊¤冻鏁版嵁浣跨敤瑕佹眰锛屽瓙绫诲彧鏄负浜嗘柟渚夸娇鐢ㄥ睘鎬� /// </summary> - public class Trait - { - /// <summary> - /// 灞炴�у唴瀹� - /// </summary> - public string attri; - /// <summary> - /// 灞炴�х殑鍊� - /// </summary> - public List<string> value; - /// <summary> - /// 鏈�澶у�� - /// </summary> - public int max; - /// <summary> - /// 鏈�灏忓�� - /// </summary> - public int min; - - /// <summary> - /// - /// </summary> - public string data_type = ""; - - /// <summary> - /// 褰撳墠鍊� - /// app杞欢鑷畾涔夊睘鎬� - /// 鐢ㄦ潵璁板綍褰撳墠鐘舵�� - /// </summary> - public object curValues; - } - public class Function { public Function() { } + + #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 @@ -70,34 +38,20 @@ /// 澶х被鍒� 1bytes 锛堥鐣欙級 /// 灏忕被鍒� 1byte 锛堥鐣欙級 /// </summary> - public string sid = "03010112345678010123012301230101"; - + public string sid = "0301011234567801012301230123"; /// <summary> - /// A鍗忚鍔熻兘鐨勭壒鎬� - /// 濡傦細鏄疉C鍔熻兘锛氱壒鎬э細on_off,mode,fan,temperature - /// attri + /// 澶囨敞 /// </summary> - public List<Trait> function = new List<Trait>(); - + public string name; /// <summary> - /// 鎴块棿ID鍒楄〃 - /// 璇ュ姛鑳芥坊鍔犲埌鍒版埧闂村垪琛� + /// 璁惧ID + /// 浜戠璐熻矗鐢熸垚 /// </summary> - public List<string> roomIdList = new List<string>(); - + public string deviceId = "0"; /// <summary> - /// bus鍗忚鏁版嵁鏍煎紡 - /// 浣跨敤A鍗忚鎺у埗鏃讹紝鏀瑰睘鎬т负绌� + /// 璁惧spk /// </summary> - public BusData bus_Data; - #endregion - - - ///// <summary> - ///// 鍔熻兘闄勫甫鐨勫睘鎬т笌鍊肩殑鍒楄〃 - ///// </summary> - //public Dictionary<string, string> dicPropert; - + public string spk = ""; /// <summary> /// 鍔熻兘绫诲埆 /// 濡傦細绌鸿皟绫汇�佺伅鍏夌被銆佺獥甯樼被 @@ -119,125 +73,112 @@ } } } - + ///// <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 string name; + public List<FunctionAttributes> attributes = new List<FunctionAttributes>(); + /// <summary> - /// A鍗忚鍘傚晢浠g爜 + /// 鎴块棿ID鍒楄〃 + /// 璇ュ姛鑳芥坊鍔犲埌鍒版埧闂村垪琛� /// </summary> - public string vendor_code + public List<string> roomIds = new List<string>(); + + /// <summary> + /// bus鍗忚鏁版嵁鏍煎紡 + /// 浣跨敤A鍗忚鎺у埗鏃讹紝鏀瑰睘鎬т负绌� + /// </summary> + public BusData bus_Data; + /// <summary> + /// 鏄惁鏀惰棌 + /// </summary> + public bool collect = false; + #endregion + /// <summary> + /// 寤舵椂 + /// </summary> + public int delay = 0; + /// <summary> + /// 寤舵椂鏄剧ず鐨勬枃鏈� + /// </summary> + [Newtonsoft.Json.JsonIgnore] + public string delayText { get { - string vendorCode = "HDL"; - var code = sid.Substring(0, 4); - if (code == "0001") - vendorCode = "HDL"; - return vendorCode; + string text = ""; + switch (delay) + { + case 0: + text = Language.StringByID(StringId.NoDelay); + break; + case 30: + text = "30s"; + break; + case 60: + text = "1min"; + break; + case 120: + text = "2min"; + break; + case 300: + text = "5min"; + break; + } + return text; } } /// <summary> /// 鏈�鍚庢帶鍒剁殑涓�娆$姸鎬� /// </summary> + [Newtonsoft.Json.JsonIgnore] public string lastState = ""; + FunctionAttributes _trait_on_off; [Newtonsoft.Json.JsonIgnore] - public Trait trait_on_off; - /// <summary> - /// 寮�鍏崇姸鎬� - /// 0:鍏� - /// 1:寮� - /// </summary> - [Newtonsoft.Json.JsonIgnore] - public string on_off + public FunctionAttributes trait_on_off { get { - try + if (_trait_on_off == null) { - if (trait_on_off == null) + _trait_on_off = attributes.Find((obj) => obj.key == "on_off"); + //鎵句笉鍒板睘鎬ч渶瑕佸0鏄庝竴涓紝闃叉鎶ラ敊闂�� + if (_trait_on_off == null) { - trait_on_off = function.Find((obj) => obj.attri == "on_off"); - //鎵句笉鍒板睘鎬ч渶瑕佸0鏄庝竴涓紝闃叉鎶ラ敊闂�� - if (trait_on_off == null) + _trait_on_off = new FunctionAttributes() { - trait_on_off = new Trait() - { - attri = "on_off", - value = new List<string> { "on", "off" }, - max = 1, - min = 0, - }; - } - trait_on_off.curValues = trait_on_off.value[trait_on_off.min]; + key = "on_off", + value = new List<string> { "on", "off" }, + max = 1, + min = 0, + }; } - return trait_on_off.curValues.ToString(); + _trait_on_off.curValue = "on"; } - catch - { - MainPage.Log("on_off 鏁版嵁鑾峰彇澶辫触."); - function.Add( new Trait() - { - attri = "on_off", - value = new List<string> { "on", "off" }, - max = 1, - min = 0, - }); - return "off"; - } + return _trait_on_off; } - set - { - try - { - if (trait_on_off == null) - { - trait_on_off = function.Find((obj) => obj.attri == "on_off"); - //鎵句笉鍒板睘鎬ч渶瑕佸0鏄庝竴涓紝闃叉鎶ラ敊闂�� - if (trait_on_off == null) - { - trait_on_off = new Trait() - { - attri = "on_off", - value = new List<string> { "on", "off" }, - max = 1, - min = 0, - }; - } - trait_on_off.curValues = trait_on_off.min; - } - trait_on_off.curValues = value; - } - catch (Exception ex) - { - MainPage.Log($"on_off 鏁版嵁鍒锋柊澶辫触: {ex.Message}"); - function.Add(new Trait() - { - attri = "on_off", - value = new List<string> { "on", "off" }, - max = 1, - min = 0, - }); - } - } + //set + //{ + // _trait_on_off = value; + //} } - - /// <summary> - /// 鏄惁鏀惰棌 - /// </summary> - public bool collection = false; /// <summary> /// 浣跨敤娆℃暟 @@ -257,25 +198,12 @@ /// </summary> public int fixedSerialNumber = int.MaxValue; - /// <summary> - /// 鑾峰彇A鍗忚鎺у埗瀛楃涓� - /// </summary> - /// <param name="command">鎺у埗鍛戒护锛歸rite锛宺ead</param> - /// <returns></returns> - public virtual JObject GetSendJObject(CommandType_A command) - { - var sendJob = new JObject { { "vendor_code", vendor_code }, { "Command", command.ToString() }, { "Type", "device" }, }; - var data = new JObject { { "sid", sid } }; - sendJob.Add("objects", data); - return sendJob; - } - public string GetBusId () { 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; } @@ -287,23 +215,540 @@ public string GetRoomListName() { string roomNameList = ""; - foreach(var roomId in roomIdList) + foreach(var roomId in roomIds) { - var findRoom = DB_ResidenceData.residenceData.rooms.Find(obj => obj.sid == roomId); + var findRoom = DB_ResidenceData.rooms.Find(obj => obj.sid == roomId); if (findRoom == null) + { continue; - if(roomNameList != "") + } + if (roomNameList != "") { roomNameList += ","; } - roomNameList += findRoom.floor + "路" + findRoom.name; + roomNameList += findRoom.floorName + findRoom.name; + } + if (roomNameList == "" && functionType == FunctionType.Scene) + { + roomNameList = Language.StringByID(StringId.WholeHouseScene); } 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( 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> /// 鏇存柊鏃堕棿 /// </summary> public DateTime refreshTime = DateTime.MinValue; + + /// <summary> + /// 鑾峰彇鏈湴鎺у埗鏁版嵁 + /// </summary> + public GatewayAlinkControlObj GetGatewayAlinkControlData(Dictionary<string, string> commandDictionary) + { + var sendDataObj = new GatewayAlinkControlObj(); + 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) + { + aca.key = dic.Key; + aca.value = dic.Value; + acd.status.Add(aca); + } + + sendDataObj.objects.Add(acd); + + 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 GatewayAlinkControlObj + { + public List<AlinkControlData> objects = new List<AlinkControlData>(); + + public string time_stamp = ""; + public string id = ""; + } + /// <summary> + /// A鍗忚鎺у埗鏁版嵁 + /// </summary> + public class AlinkControlData + { + public string sid = ""; + public List<AlinkControlAttributes> status = new List<AlinkControlAttributes>(); + } + /// <summary> + /// a鍗忚鎺у埗鍔ㄤ綔鏁版嵁 + /// </summary> + public class AlinkControlAttributes + { + /// <summary> + /// 灞炴�у悕 + /// 鍒�:on_off + /// </summary> + public string key = ""; + /// <summary> + /// 灞炴�у�� + /// 鍒�:on + /// </summary> + public string value = ""; + } + + /// <summary> + /// 鍔熻兘灞炴�� + /// 灞炴�у瓧娈佃В鏋愶細attri :灞炴�у唴瀹癸紝value 灞炴�х殑鍊硷紝max 鏈�澶у�� min 鏈�灏忓�� + /// </summary> + public class FunctionAttributes + { + /// <summary> + /// 灞炴�ч敭鍚� + /// </summary> + public string key; + /// <summary> + /// 灞炴�х殑鍊煎垪琛� + /// </summary> + public List<string> value = new List<string>(); + /// <summary> + /// 鏈�澶у�� + /// </summary> + public int max; + /// <summary> + /// 鏈�灏忓�� + /// </summary> + public int min; + /// <summary> + /// 鏁版嵁绫诲瀷 + /// </summary> + public string data_type = ""; + /// <summary> + /// 褰撳墠鍊� + /// </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> + /// 鍔熻兘灞炴�ч敭鍚嶅垪琛� + /// </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 + { + public string oid; + public string name; + public string machine_id; + public string net_id; + public string dev_id; + 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