From 37c33341f75841dc39c535eb62a3603f596516a1 Mon Sep 17 00:00:00 2001 From: wxr <464027401@qq.com> Date: 星期四, 27 二月 2020 17:11:53 +0800 Subject: [PATCH] 20200227 --- HDL_ON/Entity/DB_ResidenceData.cs | 249 +++++++++++++++++++++++++++++++++++-------------- 1 files changed, 178 insertions(+), 71 deletions(-) diff --git a/HDL_ON/Entity/DB_ResidenceData.cs b/HDL_ON/Entity/DB_ResidenceData.cs index b2ba18d..d7ba290 100644 --- a/HDL_ON/Entity/DB_ResidenceData.cs +++ b/HDL_ON/Entity/DB_ResidenceData.cs @@ -21,10 +21,13 @@ /// 鎴块棿鍒楄〃 /// </summary> public List<Room> rooms = new List<Room>(); + /// <summary> /// 鍔熻兘鍒楄〃 /// </summary> - public List<Function> functions = new List<Function>(); + //[Newtonsoft.Json.JsonIgnore] + public FunctionList functions = new FunctionList(); + /// <summary> /// 鍦烘櫙鍒楄〃 /// </summary> @@ -39,7 +42,7 @@ { try { - var residenceDataBytes = MyIO.FileUtils.ReadFile("DB_ResidenceData"); + var residenceDataBytes = FileUtils.ReadFile("DB_ResidenceData"); var userConfigString = CommonPage.MyEncodingUTF8.GetString(residenceDataBytes); DB_ResidenceData temp = null; if (userConfigString != null) @@ -54,90 +57,194 @@ { instance = temp; } + new System.Threading.Thread(() => + { + //鍒濆鍖栦綇瀹呭姛鑳芥暟鎹� + instance.functions.GetAllFunction(); + //鍒濆鍖栦綇瀹呮墍鏈夋埧闂村姛鑳芥暟鎹� + foreach (var r in instance.rooms) + { + foreach (var func in instance.functions.functions) + { + if (func.roomIdList.Contains(r.sid)) + { + r.functions.Add(func); + } + } + } + }) + { IsBackground = true }.Start(); + } catch { } -#if DEBUG instance.residenceName = "濡効鐨勫"; instance.residenceImage = "Classification/Room/Roombg.png"; - var r = new Room() { sid = "0001", name = "Room-1", floor = "1F", backgroundImage = "Classification/Room/Roombg.png" }; - r.functions.Add(new Function() - { - sid = "000000000000000000000000000000000001", - funcType = FunctionType.AC, - Name = "绌鸿皟", - roomIdList = new List<string>() { "0001" }, - lastState = "鍒跺喎 涓 18掳C" - }); - r.functions.Add(new Function() - { - sid = "000000000000000000000000000000000002", - funcType = FunctionType.Light, - Name = "瀹㈠巺鐏�", - roomIdList = new List<string>() { "0001" }, - lastState = "鎵撳紑20%浜害" - }); - r.functions.Add(new Function() - { - sid = "000000000000000000000000000000000003", - funcType = FunctionType.Curtain, - Name = "绐楀笜", - roomIdList = new List<string>() { "0001" }, - lastState = "鎵撳紑20%" - }); - r.functions.Add(new Function() - { - sid = "000000000000000000000000000000000004", - funcType = FunctionType.FloorHeating, - Name = "鍦扮儹", - roomIdList = new List<string>() { "0001" }, - lastState = "" - }); - //-------------------- - instance.functions.Add(new Function() +#if DEBUG + if (instance.rooms.Count == 0) { - sid = "000000000000000000000000000000000001", - funcType = FunctionType.AC, - Name = "绌鸿皟", - roomIdList = new List<string>() { "0001" }, - lastState = "鍒跺喎 涓 18掳C" - }); - instance.functions.Add(new Function() - { - sid = "000000000000000000000000000000000002", - funcType = FunctionType.Light, - Name = "瀹㈠巺鐏�", - roomIdList = new List<string>() { "0001" }, - lastState = "鎵撳紑20%浜害" - }); - instance.functions.Add(new Function() - { - sid = "000000000000000000000000000000000003", - funcType = FunctionType.Curtain, - Name = "绐楀笜", - roomIdList = new List<string>() { "0001" }, - lastState = "鎵撳紑20%" - }); - instance.functions.Add(new Function() - { - sid = "000000000000000000000000000000000004", - funcType = FunctionType.FloorHeating, - Name = "鍦扮儹", - roomIdList = new List<string>() { "0001" }, - lastState = "" - }); + //-------------------- + var r111 = new Room() { sid = "0001", name = "Room-1", floor = "1F", backgroundImage = "Classification/Room/Roombg.png" }; + instance.rooms.Add(r111); + instance.functions.aCs.Add(new AC() + { + sid = "12341212345678901234560600000001", + name = "绌鸿皟", + trait = "Switch,mode,fan,temperature", + roomIdList = new List<string>() { "0001" }, + lastState = "鍒跺喎 涓 18掳C", + bus_Data = new BusData + { + SubnetID = 4, + DeviceID = 8, + LoopID = 1, + }, + }); + instance.functions.lights.Add(new Light() + { + sid = "12341212345678901234560400000002", + name = "瀹㈠巺鐏�", + trait = "brightness", + roomIdList = new List<string>() { "0001" }, + lastState = "20%", + bus_Data = new BusData + { + SubnetID = 14, + DeviceID = 8, + LoopID = 1, + }, - instance.rooms.Add(r); + }); + instance.functions.curtains.Add(new Curtain() + { + sid = "12341212345678901234560500000003", + name = "绐楀笜", + roomIdList = new List<string>() { "0001" }, + lastState = "20%", + bus_Data = new BusData + { + SubnetID = 42, + DeviceID = 7, + LoopID = 1, + }, + }); + instance.functions.floorHeatings.Add(new FloorHeating() + { + sid = "12341212345678901234560700000004", + name = "鍦扮儹", + roomIdList = new List<string>() { "0001" }, + lastState = "" + }); + instance.functions.lights.Add(new Light() + { + sid = "12341212345678901234560400000005", + name = "瀹㈠巺澶х伅", + trait = "switch", + roomIdList = new List<string>() { "0001" }, + bus_Data = new BusData + { + SubnetID = 111, + DeviceID = 6, + LoopID = 1, + }, + }); + instance.functions.lights.Add(new Light() + { + sid = "12341212345678901234560400000006", + name = "瀹㈠巺RGB鐏�", + trait = "brightness,color", + roomIdList = new List<string>() { "0001" }, + bus_Data = new BusData + { + SubnetID = 214, + DeviceID = 8, + LoopID = 1, + }, + }); + + //鍒濆鍖栦綇瀹呭姛鑳芥暟鎹� + instance.InitRoomFunction(); + } #endif } return instance; } } + /// <summary> + /// 浣忓畢鏁版嵁鏄惁瀛樺湪鍙樺寲 + /// </summary> + bool hasChange = false; + /// <summary> + /// 淇濆瓨浣忓畢鏁版嵁 + /// </summary> public void SaveResidenceData() { - var ssd = CommonPage.MyEncodingUTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(this)); - MyIO.FileUtils.WriteFileByBytes("DB_ResidenceData", ssd); + hasChange = true; + new System.Threading.Thread(() => + { + while (hasChange) + { + hasChange = false; + System.Threading.Thread.Sleep(5000); + } + + var ssd = CommonPage.MyEncodingUTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(this)); + FileUtils.WriteFileByBytes("DB_ResidenceData", ssd); + MainPage.Log("Save DB_ResidenceData"); + }) + { IsBackground = true }.Start(); + } + + /// <summary> + /// 鍒锋柊浣忓畢閲岄潰鐨勬悳绱㈣澶囩姸鎬� + /// </summary> + public void RefreshResidenceFunctionStatus() + { + new System.Threading.Thread(() => + { + foreach (var function in functions.functions) + { + System.Threading.Thread.Sleep(100); + if (function.bus_Data!= null) + { + if (function.functionCategory == FunctionType.Light) + { + Control.Send("read", function, 3); + } + } + else + { + + } + } + }) + { IsBackground = true }.Start(); + } + + /// <summary> + /// 鍒濆鍖栨瘡涓埧闂寸殑鍔熻兘鏁版嵁 + /// </summary> + public void InitRoomFunction() + { + new System.Threading.Thread(() => + { + //鍒濆鍖栦綇瀹呭姛鑳芥暟鎹� + instance.functions.GetAllFunction(); + //鍒濆鍖栦綇瀹呮墍鏈夋埧闂村姛鑳芥暟鎹� + foreach (var r in instance.rooms) + { + foreach (var func in instance.functions.functions) + { + if (func.roomIdList.Contains(r.sid)) + { + r.functions.Add(func); + } + } + } + }) + { IsBackground = true }.Start(); + } } } -- Gitblit v1.8.0