From e3ad42ffa2fa67c8f6cb4519ca626fa275c8947d Mon Sep 17 00:00:00 2001 From: wxr <464027401@qq.com> Date: 星期三, 02 十二月 2020 16:34:40 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/CJL-NEW' --- HDL_ON/Entity/DB_ResidenceData.cs | 230 ++++++++++++++++++++++++++++++++++++++++++--------------- 1 files changed, 168 insertions(+), 62 deletions(-) diff --git a/HDL_ON/Entity/DB_ResidenceData.cs b/HDL_ON/Entity/DB_ResidenceData.cs index 84db410..442564e 100644 --- a/HDL_ON/Entity/DB_ResidenceData.cs +++ b/HDL_ON/Entity/DB_ResidenceData.cs @@ -1,7 +1,7 @@ 锘縰sing System; using System.Collections.Generic; -using HDL_ON.DAL; -using HDL_ON.DAL.Net; +using System.Threading; +using HDL_ON.DAL.Server; using Shared; namespace HDL_ON.Entity @@ -13,10 +13,14 @@ } /// <summary> + /// 涓讳汉token + /// </summary> + public string MasterToken; + /// <summary> /// 0:bus缃戝叧 /// 1:A鍗忚缃戝叧 /// </summary> - public int GatewayType = 0; + public int GatewayType = 1; /// <summary> /// 浣忓畢鍩虹淇℃伅 /// </summary> @@ -30,24 +34,51 @@ } else { - var curRegion = MainPage.LoginUser.regionList.Find((obj) => obj.RegionID == CurReginID); + var curRegion = UserInfo.Current.regionList.Find((obj) => obj.RegionID == CurReginID); //if (curRegion == null) //{ - // CurReginID = MainPage.LoginUser.regionList[0].RegionID; - // return MainPage.LoginUser.regionList[0]; + // CurReginID = UserInfo.Current.regionList[0].RegionID; + // return UserInfo.Current.regionList[0]; //} return curRegion; } } } + + ///// <summary> + ///// 鑾峰彇缃戝叧鍒楄〃 + ///// </summary> + //void GetHomeGatewayList() + //{ + // new Thread(() => + // { + // //鍒囨崲浣忓畢鍚庯紝鏌ヨ涓�娆$綉鍏冲垪琛� + // new HttpServerRequest().GetHomeGatewayList(); + // }) + // { IsBackground = true }.Start(); + + //} + + //string curReginID; + ///// <summary> + ///// 褰撳墠閫夋嫨鐨勪綇瀹呯储寮� + ///// </summary> + //public string CurReginID + //{ + // set + // { + // curReginID = value; + // GetHomeGatewayList(); + // } + // get + // { + // return curReginID; + // } + //} /// <summary> /// 褰撳墠閫夋嫨鐨勪綇瀹呯储寮� /// </summary> public string CurReginID = ""; - /// <summary> - /// 妤煎眰鍒楄〃 - /// </summary> - public List<Floor> floors = new List<Floor>(); /// <summary> /// 鍔熻兘绫诲瀷鍒楄〃 /// </summary> @@ -63,7 +94,7 @@ try { var residenceDataBytes = FileUtils.ReadFile("DB_ResidenceData"); - var userConfigString = CommonPage.MyEncodingUTF8.GetString(residenceDataBytes); + var userConfigString = System.Text.Encoding.UTF8.GetString(residenceDataBytes); DB_ResidenceData temp = null; if (!string.IsNullOrEmpty(userConfigString)) @@ -92,21 +123,24 @@ instance.SaveResidenceData(); } - //new Light() - //{ - // sid = "030101123456780202010005ABCD", - // name = "鍚婄伅", - // function = new List<Trait>() { - // new Trait { name="on_off", max=100,min = 0, value_key= new List<string> { "on","off"} }, - // }, - // roomIdList = new List<string>() { "0001" }, - // bus_Data = new BusData - // { - // SubnetID = 42, - // DeviceID = 6, - // LoopID = 1, - // }, - //}.SaveFunctionData(); + new Light() + { + sid = "030101123456780202010005ABCD", + name = "鐏厜1", + attributes = new List<FunctionAttributes>() { + new FunctionAttributes { key="on_off", max=100,min = 0, value= new List<string> { "on","off"} }, + }, + roomIds = new List<string>() { "0001" }, + bus_Data = new BusData + { + addresses = "2A06", + loopId = 1, + }, + }.SaveFunctionData(); + + + + } @@ -133,8 +167,59 @@ ins_Function = null; if (MainPage.IsRemote) { - Mqtt_Cloud.DisConnectRemoteMqttClient("閫�鍑虹櫥褰曪紝鎴栬�呭垏鎹綇瀹�"); + DAL.Mqtt.MqttClient.DisConnectRemote("閫�鍑虹櫥褰曪紝鎴栬�呭垏鎹綇瀹�"); } + } + + /// <summary> + /// 缃戝叧璇︾粏淇℃伅 + /// </summary> + public HomeGatewayInfo HomeGateway; + + /// <summary> + /// 妫�娴嬩綇瀹呮槸鍚︾粦瀹氫簡缃戝叧 + /// </summary> + /// <returns></returns> + public bool CheckWhetherGatewayIsBound() + { + if (HomeGateway != null && !string.IsNullOrEmpty(HomeGateway.mac)) + { + return true; + } + else + { + return false; + } + } + + /// <summary> + /// 褰撳墠浣忓畢鐨勭綉鍏矼AC + /// </summary> + public string residenceGatewayMAC + { + get + { + if (CheckWhetherGatewayIsBound()) + { + return HomeGateway.mac.ToUpper(); + } + else + { + return ""; + } + } + set + { + if (CheckWhetherGatewayIsBound()) + { + HomeGateway.mac = value; + } + else + { + HomeGateway = new HomeGatewayInfo() { mac = value }; + } + } + } /// <summary> @@ -144,7 +229,7 @@ /// <summary> /// 褰撳墠浣忓畢鐨勭綉鍏矼AC /// </summary> - public string residenceGatewayMAC = "00964E19C4467B1E"; + //public string residenceGatewayMAC = "4E47323347591243";//"0281B9078C000000";// "00964E19C4467B1E"; /// <summary> /// 淇濆瓨浣忓畢鏁版嵁 /// </summary> @@ -152,7 +237,7 @@ { if (this == null || this.residecenInfo == null) return; - var ssd = CommonPage.MyEncodingUTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(this)); + var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(this)); FileUtils.WriteFileByBytes("DB_ResidenceData", ssd); MainPage.Log("Save DB_ResidenceData"); } @@ -162,20 +247,23 @@ /// </summary> public string CurFoor = Language.StringByID(StringId.All); + + #region 鎴块棿鏁版嵁鐩稿叧 /// <summary> /// 鍒濆鍖栨瘡涓埧闂寸殑鍔熻兘鏁版嵁 /// </summary> public static void InitRoomFunction() { - new System.Threading.Thread(() => + new Thread(() => { try { //鍒濆鍖栦綇瀹呮墍鏈夋埧闂村姛鑳芥暟鎹� - foreach (var r in rooms) + foreach (var r in Rooms) { r.GetRoomFunctions(true); + r.GetRoomScenes(true); } } catch (Exception ex) @@ -187,7 +275,7 @@ } static List<Room> ins_Room; - public static List<Room> rooms + public static List<Room> Rooms { get { @@ -203,7 +291,7 @@ if (filePath.StartsWith("RoomData_")) { var roomDataBytes = FileUtils.ReadFile(filePath); - var roomDataString = CommonPage.MyEncodingUTF8.GetString(roomDataBytes); + var roomDataString = System.Text.Encoding.UTF8.GetString(roomDataBytes); var room = Newtonsoft.Json.JsonConvert.DeserializeObject<Room>(roomDataString); if (room != null) { @@ -220,19 +308,33 @@ return ins_Room; } } + + /// <summary> + /// 澧炲姞鎴块棿 + /// </summary> + /// <param name="room"></param> + public void AddRoom(Room room) + { + Rooms.Add(room); + room.SaveRoomData(); + } /// <summary> /// 鍒犻櫎鎴块棿 /// </summary> - /// <param name="delRoom"></param> - public static void DelRoom(Room delRoom) + /// <param name="room"></param> + public void DelRoom(Room room) { - var tRoom = rooms.Find((obj) => obj.sid == delRoom.sid); + var tRoom = Rooms.Find((obj) => obj.uid == room.uid); if (tRoom != null) { - FileUtils.DeleteFile(delRoom.roomSavePath); - rooms.Remove(tRoom); + FileUtils.DeleteFile(room.roomSavePath); + Rooms.Remove(room); + room.modifyTime = ""; } + room.SaveRoomData(); } + + #endregion #region 鍔熻兘鏁版嵁 @@ -264,7 +366,7 @@ case FunctionType.AC: //鎭㈠绌鸿皟鏁版嵁 var acDataBytes = FileUtils.ReadFile(filePath); - var acString = CommonPage.MyEncodingUTF8.GetString(acDataBytes); + var acString = System.Text.Encoding.UTF8.GetString(acDataBytes); ins_Function.aCs.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<AC>(acString)); break; case FunctionType.Relay: @@ -272,7 +374,7 @@ case FunctionType.RGB: //鎭㈠鐏厜鏁版嵁 var lightsDataBytes = FileUtils.ReadFile(filePath); - var lightsString = CommonPage.MyEncodingUTF8.GetString(lightsDataBytes); + var lightsString = System.Text.Encoding.UTF8.GetString(lightsDataBytes); ins_Function.lights.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<Light>(lightsString)); break; case FunctionType.Curtain: @@ -280,13 +382,13 @@ case FunctionType.RollingShutter: //鎭㈠绐楀笜鏁版嵁 var curtainsDataBytes = FileUtils.ReadFile(filePath); - var curtainsString = CommonPage.MyEncodingUTF8.GetString(curtainsDataBytes); + var curtainsString = System.Text.Encoding.UTF8.GetString(curtainsDataBytes); ins_Function.curtains.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<Curtain>(curtainsString)); break; case FunctionType.FloorHeating: //鎭㈠鍦扮儹鏁版嵁 var fhDataBytes = FileUtils.ReadFile(filePath); - var fhString = CommonPage.MyEncodingUTF8.GetString(fhDataBytes); + var fhString = System.Text.Encoding.UTF8.GetString(fhDataBytes); ins_Function.floorHeatings.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<FloorHeating>(fhString)); break; case FunctionType.PM25: @@ -296,31 +398,31 @@ case FunctionType.Humidity: //鎭㈠鐜鏁版嵁 var sesDataBytes = FileUtils.ReadFile(filePath); - var sesString = CommonPage.MyEncodingUTF8.GetString(sesDataBytes); + var sesString = System.Text.Encoding.UTF8.GetString(sesDataBytes); ins_Function.sensorsEnvironmentalScience.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<Sensor>(sesString)); break; case FunctionType.Socket: //鎭㈠鎻掑骇鏁版嵁 var eleDataBytes = FileUtils.ReadFile(filePath); - var eleString = CommonPage.MyEncodingUTF8.GetString(eleDataBytes); + var eleString = System.Text.Encoding.UTF8.GetString(eleDataBytes); ins_Function.switchSockets.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<SwitchSocket>(eleString)); break; case FunctionType.TV: //鎭㈠鐢佃鏁版嵁 var eleDataBytes1 = FileUtils.ReadFile(filePath); - var eleString1 = CommonPage.MyEncodingUTF8.GetString(eleDataBytes1); + var eleString1 = System.Text.Encoding.UTF8.GetString(eleDataBytes1); ins_Function.tVs.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<TV>(eleString1)); break; case FunctionType.Fan: //鎭㈠椋庢墖鏁版嵁 var eleDataBytes2 = FileUtils.ReadFile(filePath); - var eleString2 = CommonPage.MyEncodingUTF8.GetString(eleDataBytes2); + var eleString2 = System.Text.Encoding.UTF8.GetString(eleDataBytes2); ins_Function.fans.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<Fan>(eleString2)); break; case FunctionType.Scene: //鎭㈠鍦烘櫙鏁版嵁 var scenesDataBytes = FileUtils.ReadFile(filePath); - var scenesString = CommonPage.MyEncodingUTF8.GetString(scenesDataBytes); + var scenesString = System.Text.Encoding.UTF8.GetString(scenesDataBytes); ins_Function.scenes.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<Scene>(scenesString)); break; @@ -387,18 +489,18 @@ foreach (var function in functionList.GetAllDeviceFunctionList()) { System.Threading.Thread.Sleep(100); - //if (function.bus_Data != null) + switch (function.functionCategory) { - switch (function.functionCategory) - { - case FunctionCategory.Light: - case FunctionCategory.Electrical: - case FunctionCategory.SwitchDevice: - case FunctionCategory.Curtain: - case FunctionCategory.Thermostat: - Control.SendReadCommand(function); - break; - } + case FunctionCategory.Light: + case FunctionCategory.Electrical: + case FunctionCategory.SwitchDevice: + case FunctionCategory.Curtain: + case FunctionCategory.Thermostat: + if (DB_ResidenceData.residenceData.GatewayType == 0) + { + DriverLayer.Control.Ins.SendReadCommand(function); + } + break; } } } @@ -414,6 +516,11 @@ #endregion #region oid鍒楄〃 a鍗忚杞琤us鍗忚鎺у埗浣跨敤 + /// <summary> + /// oid鏁版嵁淇濆瓨鐨勬枃浠跺悕 + /// </summary> + [Newtonsoft.Json.JsonIgnore] + public static string OidSavePathName = "AProtocolData_FunctionOid"; static List<FunctionOid> ins_OidList; public static List<FunctionOid> functionOidList { @@ -421,7 +528,7 @@ { if (ins_OidList == null) { - var bytes = FileUtils.ReadFile("AProtocolData_FunctionOid"); + var bytes = FileUtils.ReadFile(OidSavePathName); if (bytes == null || bytes.Length == 0) { ins_OidList = new List<FunctionOid>(); @@ -453,12 +560,11 @@ /// <summary> /// 淇濆瓨oid鏁版嵁锛屾瘡娆′繚瀛橀兘浼氳鐩� /// </summary> - public static void SaveFunctionOidJsonDataList(string oidJsonString) + public static void SaveOidList(string oidJsonString) { - oidJsonString = oidJsonString.Replace("add", "get_list_response"); var oidBytes = System.Text.Encoding.UTF8.GetBytes(oidJsonString); - FileUtils.WriteFileByBytes("AProtocolData_FunctionOid", oidBytes); + FileUtils.WriteFileByBytes(OidSavePathName, oidBytes); } #endregion -- Gitblit v1.8.0