From 5428935270159bfc42c2934ed7fb1091554fc9a4 Mon Sep 17 00:00:00 2001 From: 黄学彪 <hxb@hdlchina.com.cn> Date: 星期四, 09 七月 2020 17:12:42 +0800 Subject: [PATCH] 修改了 sokect --- ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlRoomLogic.cs | 356 +++++++++++++++++++++++++++++++++++------------------------ 1 files changed, 212 insertions(+), 144 deletions(-) diff --git a/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlRoomLogic.cs b/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlRoomLogic.cs index 75af7bc..a777b63 100755 --- a/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlRoomLogic.cs +++ b/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlRoomLogic.cs @@ -61,14 +61,18 @@ this.dicRooms.Clear(); //妫�娴嬫垜鐨勫枩鐖辫繖涓埧闂村璞� this.CheckLoveRoom(); - - foreach (var roomId in Config.Instance.Home.ListRooms) + + var listFile = Global.FileListByHomeId(); + foreach (var fileName in listFile) { - //浠庢枃浠堕噷闈㈣幏鍙栨埧闂村璞� - var room = this.GetRoomByFilePath($"Room_{roomId}.json"); - if (room != null) + if (fileName.StartsWith("Room_") == true) { - this.dicRooms[room.Id] = (room); + //浠庢枃浠堕噷闈㈣幏鍙栨埧闂村璞� + var room = this.GetRoomByFilePath(fileName); + if (room != null) + { + this.dicRooms[room.Id] = (room); + } } } //璁剧疆褰撳墠妤煎眰鐨処D @@ -84,9 +88,6 @@ /// </summary> public void RefreshAllRoomByLocation() { - var homeTemp = Config.Instance.Home; - homeTemp.ListRooms.Clear(); - var listFile = Global.FileListByHomeId(); //鎴戠殑鍠滅埍鐨勬埧闂村繀椤昏鍦ㄧ0浣嶆墠琛� @@ -94,7 +95,6 @@ if (listFile.Contains(fRoom) == true) { listFile.Remove(fRoom); - homeTemp.ListRooms.Add("Favorite"); } var listRoomFile = new List<string>(); @@ -103,7 +103,6 @@ if (fileName.StartsWith("Room_")) { string roomId = fileName.Replace("Room_", string.Empty).Replace(".json", string.Empty); - homeTemp.ListRooms.Add(roomId); listRoomFile.Add(fileName); } } @@ -117,8 +116,7 @@ this.CheckAdminFloorData(listRoomFile); } - homeTemp.Save(false); - InitAllRoom(); + this.InitAllRoom(); } /// <summary> @@ -128,7 +126,7 @@ { Application.RunOnMainThread(() => { - MainPage.ListRoomViewFrom.Instance?.RefreshListRoom(); + MainPage.LeftListRoomViewFrom.Instance?.RefreshListRoom(); }); } @@ -215,15 +213,12 @@ /// <param name="rorefreshRoomViewom">鏄惁鍒锋柊鎴块棿瑙嗗浘鍒楄〃鐣岄潰</param> public void AddRoom(Room room, bool refreshRoomView = true) { - if (Global.IsExistsByHomeId(room.FileName) == true - || Config.Instance.Home.ListRooms.Contains(room.Id) == true) + if (Global.IsExistsByHomeId(room.FileName) == true) { return; } //娣诲姞鍒扮紦瀛� this.dicRooms[room.Id] = room; - //鎶婃埧闂碔D娣诲姞鍒颁綇瀹� - Config.Instance.Home.AddRoomId(room.Id); //鐢熸垚鏂囦欢 room.Save(); //澶囦唤 @@ -243,8 +238,9 @@ /// 鍒犻櫎鎴块棿 /// </summary> /// <param name="roomId">鎴块棿ID</param> + /// <param name="refreshLeftView">鏄惁鍒锋柊宸︽粦鐣岄潰(姝ゅ彉閲忕洰鍓嶆槸缁欏垹闄ゅ叏閮ㄦ埧闂寸敤鐨�)</param> /// <returns></returns> - public void RemoveRoom(string roomId) + public void RemoveRoom(string roomId, bool refreshLeftView = true) { //鏍规嵁鎴块棿Id锛岃幏鍙栨埧闂村璞� var room = this.GetRoomById(roomId); @@ -279,8 +275,6 @@ } loveRoom.Save(false); } - - Config.Instance.Home.RemoveRoomId(roomId); this.dicRooms.Remove(roomId); string roomFilePath = room.FileName; @@ -293,9 +287,31 @@ //鏍规嵁鎴块棿ID,绉婚櫎鎸囧畾鐨勭湡瀹炵墿鐞嗚澶囩殑鎵�灞炴埧闂磋褰� Common.LocalDevice.Current.DeleteRealDeviceByRoomId(roomId); + if (refreshLeftView == true) + { + //HdlAutoBackupLogic.DeleteFile(roomFilePath); + //鍒锋柊鎴块棿瑙嗗浘鍒楄〃 + this.RefreshRoomListView(); + } + } - //鍒锋柊鎴块棿瑙嗗浘鍒楄〃 - this.RefreshRoomListView(); + /// <summary> + /// 鍒犻櫎鍏ㄩ儴鐨勬埧闂� + /// </summary> + public void DeleteAllRoom() + { + var listRoomId = new List<string>(); + foreach (var room in this.dicRooms.Values) + { + if (room.IsLove == false) + { + listRoomId.Add(room.Id); + } + } + foreach (var roomId in listRoomId) + { + this.RemoveRoom(roomId, false); + } } #endregion @@ -357,7 +373,7 @@ public string GetRoomNameByDevice(CommonDevice device) { var room = this.GetRoomByDevice(device); - return this.GetFloorRoomName(room); + return this.GetRoomName(room); } /// <summary> @@ -365,7 +381,7 @@ /// </summary> /// <returns>鎴块棿鍚�</returns> /// <param name="room">鎴块棿瀵硅薄</param> - public string GetFloorRoomName(Room room) + public string GetRoomName(Room room) { if (room == null) { @@ -480,7 +496,7 @@ { listRoom.Add(room); } - return listRoom; + return this.SortRoom(listRoom); } /// <summary> @@ -609,25 +625,6 @@ return true; } return false; - } - - /// <summary> - /// 鑾峰彇鎴块棿鎵�鍦ㄥ尯鍩� - /// 妤煎眰,鎴块棿鍚� - /// </summary> - /// <returns></returns> - public string GetZoneName(Room i_room) - { - if (string.IsNullOrEmpty(i_room.FloorId)) - { - return i_room.Name; - } - var floorName = HdlResidenceLogic.Current.GetFloorNameById(i_room.FloorId); - if (floorName == null) - { - return i_room.Name; - } - return $"{floorName}锛寋i_room.Name}"; } #endregion @@ -935,85 +932,87 @@ { i_floorKeys = string.Empty; } - Dictionary<string, List<string>> dicAllSort = new Dictionary<string, List<string>>(); - //璇诲彇鎴块棿椤哄簭 - string fullName = UserCenterLogic.CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.RoomSortFile); - var strData = UserCenterLogic.LoadFileContent(fullName); - if (strData != null) - { - dicAllSort = Newtonsoft.Json.JsonConvert.DeserializeObject<Dictionary<string, List<string>>>(strData); - } - - var listRoomSort = new List<string>(); - if (dicAllSort.ContainsKey(i_floorKeys) == true) - { - listRoomSort = dicAllSort[i_floorKeys]; - } - else - { - dicAllSort[i_floorKeys] = listRoomSort; - } - - var dicRoom = new Dictionary<string, Common.Room>(); + var listRoom = new List<Room>(); foreach (var room in this.dicRooms.Values) { - if (room.FloorId != i_floorKeys && i_floorKeys != string.Empty) + if (room.FloorId != i_floorKeys && i_floorKeys != string.Empty + || room.IsLove == true) { - //涓嶆槸鍚屼竴涓ゼ灞� + //涓嶆槸鍚屼竴涓ゼ灞�,涓嶈鎴戠殑鍠滅埍 continue; - } - if (room.IsLove == true) - { - //涓嶈鎴戠殑鍠滅埍 - continue; - } - if (listRoomSort.Contains(room.Id) == false) - { - //鏂版坊鍔犵殑鎴块棿 - listRoomSort.Add(room.Id); } if (getShard == false && room.IsSharedRoom == true) { //涓嶈鍒嗕韩鐨勬埧闂� continue; } - dicRoom[room.Id] = room; + listRoom.Add(room); } - - var listSortRoom = new List<Room>(); - for (int i = 0; i < listRoomSort.Count; i++) - { - if (dicRoom.ContainsKey(listRoomSort[i]) == true) - { - listSortRoom.Add(dicRoom[listRoomSort[i]]); - } - } - - //淇濆瓨椤哄簭 - UserCenterLogic.SaveFileContent(fullName, dicAllSort); - return listSortRoom; + return this.SortRoom(listRoom); } /// <summary> - /// 淇濆瓨鎴块棿鐨勯『搴� + /// 鎺掑簭鎴块棿瀵硅薄 /// </summary> - /// <param name="i_floorKeys">妤煎眰涓婚敭</param> - /// <param name="listSort">鎴块棿椤哄簭(鎴块棿鐨勪富閿�)</param> - public void SaveRoomSort(string i_floorKeys, List<string> listSort) + /// <param name="listRoom"></param> + /// <returns></returns> + public List<Room> SortRoom(List<Room> listRoom) { - Dictionary<string, List<string>> dicAllSort = new Dictionary<string, List<string>>(); - //璇诲彇鎴块棿椤哄簭 - string fullName = UserCenterLogic.CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.RoomSortFile); - var strData = UserCenterLogic.LoadFileContent(fullName); - if (strData != null) + //浠庝竴鍫嗘枃瀛椾腑,鑾峰彇杩欎竴鍫嗘枃瀛楅噷闈㈡暟瀛楀瓧绗︿覆鐨勬渶闀块暱搴� + var listName = new List<string>(); + foreach (var room in listRoom) { - dicAllSort = Newtonsoft.Json.JsonConvert.DeserializeObject<Dictionary<string, List<string>>>(strData); + listName.Add(room.Name); } + int numberLength = this.GetNumberMaxLength(listName); - //淇濆瓨椤哄簭 - dicAllSort[i_floorKeys] = listSort; - UserCenterLogic.SaveFileContent(fullName, dicAllSort); - dicAllSort.Clear(); + var listSort = new List<string[]>(); + foreach (var room in listRoom) + { + var strArry = new string[2]; + strArry[0] = room.Id; + strArry[1] = string.Empty; + + string value = string.Empty; + foreach (var c in room.Name) + { + if (char.IsNumber(c) == true) + { + //鏁板瓧 + value += c.ToString(); + continue; + } + else if (value != string.Empty) + { + //濡傛灉鎴块棿鍚嶅瓧甯︽湁鏁板瓧鐨勮瘽,鍒欏乏杈瑰姞闆�,鍥犱负杩欓噷鏈変釜鎺掑簭鐨勯棶棰� + strArry[1] += value.PadLeft(numberLength, '0'); + value = string.Empty; + } + strArry[1] += c.ToString(); + } + if (value != string.Empty) + { + //浠ユ暟瀛楃粨灏剧殑璇� + strArry[1] += value.PadLeft(numberLength, '0'); + } + listSort.Add(strArry); + } + //鎺掑簭 + listSort.Sort((obj1, obj2) => + { + if (obj1[1].CompareTo(obj2[1]) > 0) + { + return 1; + } + return -1; + }); + var listSortRoom = new List<Room>(); + foreach (var strArry in listSort) + { + var room = this.GetRoomById(strArry[0]); + listSortRoom.Add(room); + } + return listSortRoom; } /// <summary> @@ -1022,46 +1021,61 @@ /// <returns></returns> public Dictionary<string, string> GetFloorSortList() { - //璇诲彇妤煎眰椤哄簭 - var listFloorSort = new List<string>(); - string fullName = UserCenterLogic.CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.FloorSortFile); - var strData = UserCenterLogic.LoadFileContent(fullName); - if (strData != null) + //浠庝竴鍫嗘枃瀛椾腑,鑾峰彇杩欎竴鍫嗘枃瀛楅噷闈㈡暟瀛楀瓧绗︿覆鐨勬渶闀块暱搴� + var listName = new List<string>(); + foreach (var floorName in Config.Instance.Home.FloorDics.Values) { - listFloorSort = Newtonsoft.Json.JsonConvert.DeserializeObject<List<string>>(strData); + listName.Add(floorName); } - foreach (string keys in Common.Config.Instance.Home.FloorDics.Keys) - { - if (listFloorSort.Contains(keys) == false) - { - //鏂版坊鍔犵殑妤煎眰 - listFloorSort.Add(keys); - } - } + int numberLength = this.GetNumberMaxLength(listName); + var listSort = new List<string[]>(); + foreach (var floorId in Config.Instance.Home.FloorDics.Keys) + { + var strArry = new string[2]; + strArry[0] = floorId; + strArry[1] = string.Empty; + + string value = string.Empty; + string floorName = Config.Instance.Home.FloorDics[floorId]; + foreach (var c in floorName) + { + if (char.IsNumber(c) == true) + { + //鏁板瓧 + value += c.ToString(); + continue; + } + else if (value != string.Empty) + { + //濡傛灉鎴块棿鍚嶅瓧甯︽湁鏁板瓧鐨勮瘽,鍒欏乏杈瑰姞闆�,鍥犱负杩欓噷鏈変釜鎺掑簭鐨勯棶棰� + strArry[1] += value.PadLeft(numberLength, '0'); + value = string.Empty; + } + strArry[1] += c.ToString(); + } + if (value != string.Empty) + { + //浠ユ暟瀛楃粨灏剧殑璇� + strArry[1] += value.PadLeft(numberLength, '0'); + } + listSort.Add(strArry); + } + //妤煎眰鎺掑簭 + listSort.Sort((obj1, obj2) => + { + if (obj1[1].CompareTo(obj2[1]) > 0) + { + return 1; + } + return -1; + }); var dic = new Dictionary<string, string>(); - for (int i = 0; i < listFloorSort.Count; i++) + foreach (var strArry in listSort) { - if (Config.Instance.Home.FloorDics.ContainsKey(listFloorSort[i]) == true) - { - dic[listFloorSort[i]] = Config.Instance.Home.FloorDics[listFloorSort[i]]; - } + dic[strArry[0]] = Config.Instance.Home.FloorDics[strArry[0]]; } - - //淇濆瓨椤哄簭 - UserCenterLogic.SaveFileContent(fullName, listFloorSort); return dic; - } - - /// <summary> - /// 淇濆瓨妤煎眰鐨勯『搴� - /// </summary> - /// <param name="listSort">妤煎眰鐨勪富閿�</param> - public void SaveFloorSort(List<string> listSort) - { - string fullName = UserCenterLogic.CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.FloorSortFile); - //淇濆瓨椤哄簭 - UserCenterLogic.SaveFileContent(fullName, listSort); } #endregion @@ -1094,24 +1108,78 @@ #region 鈻� 涓�鑸柟娉昣__________________________ /// <summary> + /// 鑾峰彇鎴块棿鎬绘暟 + /// </summary> + /// <returns></returns> + public int GetRoomCount() + { + return this.dicRooms.Count; + } + + /// <summary> /// 妫�娴嬫垜鐨勫枩鐖辫繖涓埧闂村璞� /// </summary> private void CheckLoveRoom() { - if (Config.Instance.Home.ListRooms.Contains("Favorite") == false) + if (this.dicRooms.ContainsKey("Favorite") == true) + { + return; + } + //璇诲彇鏈湴鎴戠殑鍠滅埍鏂囦欢 + string favoriteFile = System.IO.Path.Combine(Common.Config.Instance.FullPath, "Room_Favorite.json"); + var fileContent = HdlFileLogic.Current.ReadFileTextContent(favoriteFile); + if (fileContent != null) + { + var love = Newtonsoft.Json.JsonConvert.DeserializeObject<Room>(fileContent); + this.dicRooms["Favorite"] = love; + } + else { //榛樿娣诲姞鍠滅埍鐨勬埧闂�--绂佹淇敼鎴块棿鍚� var love = new Room { Name = Language.StringByID(R.MyInternationalizationString.Favorite), BackgroundImage = "RoomIcon/0.jpg", Id = "Favorite" }; love.Save(false); - //娣诲姞鍒癶ouse 鎴块棿璺緞鍒楄〃 - var currentHome = Config.Instance.Home; - currentHome.ListRooms.Insert(0, love.Id); - currentHome.Save(false); - this.dicRooms["Favorite"] = love; } } + /// <summary> + /// 浠庝竴鍫嗘枃瀛椾腑,鑾峰彇杩欎竴鍫嗘枃瀛楅噷闈㈡暟瀛楀瓧绗︿覆鐨勬渶闀块暱搴� + /// </summary> + /// <param name="listText"></param> + /// <returns></returns> + private int GetNumberMaxLength(List<string> listText) + { + int maxLength = 0; + foreach (var text in listText) + { + string value = string.Empty; + foreach (var c in text) + { + if (char.IsNumber(c) == true) + { + //鏁板瓧 + value += c.ToString(); + continue; + } + else if (value != string.Empty) + { + //鍒ゆ柇鏁板瓧闀垮害 + if (maxLength <= value.Length) + { + maxLength = value.Length; + } + value = string.Empty; + } + } + //鍒ゆ柇鏁板瓧闀垮害 + if (maxLength <= value.Length) + { + maxLength = value.Length; + } + } + return maxLength; + } + #endregion } } -- Gitblit v1.8.0