From 25429f085093d89d543a0b90e30d0d62d1b7dac9 Mon Sep 17 00:00:00 2001 From: hxb <hxb@hdlchina.com.cn> Date: 星期二, 30 八月 2022 09:37:38 +0800 Subject: [PATCH] 合并了IOS的代码 --- ZigbeeApp/Shared/Phone/Device/Logic/SkipView.cs | 470 ++++++++++++++++++++++++++++++++++------------------------ 1 files changed, 278 insertions(+), 192 deletions(-) diff --git a/ZigbeeApp/Shared/Phone/Device/Logic/SkipView.cs b/ZigbeeApp/Shared/Phone/Device/Logic/SkipView.cs index 81ca490..23ba748 100755 --- a/ZigbeeApp/Shared/Phone/Device/Logic/SkipView.cs +++ b/ZigbeeApp/Shared/Phone/Device/Logic/SkipView.cs @@ -8,17 +8,19 @@ namespace Shared.Phone.Device.Logic { - public class SkipView + public class SkipView:FrameLayout { + /// <summary> /// 鍏跺畠鐣岄潰璺宠繘鏉ョ殑鍏ュ彛 /// </summary> - public static void SkipAddLogic(int intvalue,DoorLock doorLock=null,UserCenter.MemberInfoRes accountObj = null) + public async static void SkipAddLogic(int intvalue, DoorLock doorLock = null, UserCenter.MemberInfoRes accountObj = null) { - /// 0.姝e父鑷姩鍖�;1.闂ㄩ攣鑷姩鍖�;2.闂ㄩ攣甯稿紑.鍏�; + /// 0.姝e父鑷姩鍖�;1.闂ㄩ攣鑷姩鍖�;2.Sone闂ㄩ攣; switch (intvalue) { - case 0: { + case 0: + { //new涓�涓柊閫昏緫瀵硅薄锛� //鏂板姝e父鑷姩鍖栧叆鍙� Common.Logic.CurrentLogic = new Common.Logic(); @@ -29,92 +31,62 @@ UserView.HomePage.Instance.AddChidren(addLogicPage); UserView.HomePage.Instance.PageIndex += 1; addLogicPage.Show(); - } break; - case 1: { + } + break; + case 1: + { //杩涘叆闂ㄩ攣鑱斿姩浜嬩欢鍏ュ彛 - Send.UserMemberInfoRes = accountObj; - Send.CurrentDoorLock = doorLock; - if (accountObj == null) - { - ///闃叉鎶涘紓甯� - Send.UserMemberInfoRes = new UserCenter.MemberInfoRes(); - } - if (doorLock == null) - { - ///闃叉鎶涘紓甯� - Send.CurrentDoorLock = new DoorLock(); - } - ///杩涙潵鍒锋柊涓�娆¤澶囧垪琛紱 - Common.Logic.LogicDviceList.Clear(); - if (Common.Logic.LogicDviceList.Count == 0) - { - Common.Logic.LogicDviceList.AddRange(LocalDevice.Current.listAllDevice.ToArray()); - } - var doorLockLogicList = new DoorLockLogic.LockLogicList(); - UserView.HomePage.Instance.AddChidren(doorLockLogicList); - UserView.HomePage.Instance.PageIndex += 1; - doorLockLogicList.Show(); - } break; - case 2: { + Send.UserMemberInfoRes = accountObj; + Send.CurrentDoorLock = doorLock; + if (accountObj == null) + { + ///闃叉鎶涘紓甯� + Send.UserMemberInfoRes = new UserCenter.MemberInfoRes(); + } + if (doorLock == null) + { + ///闃叉鎶涘紓甯� + Send.CurrentDoorLock = new DoorLock(); + } + ///杩涙潵鍒锋柊涓�娆¤澶囧垪琛紱 Common.Logic.LogicDviceList.Clear(); if (Common.Logic.LogicDviceList.Count == 0) { Common.Logic.LogicDviceList.AddRange(LocalDevice.Current.listAllDevice.ToArray()); } - //璇诲彇绯荤粺褰撳墠鏃堕棿锛氭椂-鍒� - int h =int.Parse(DateTime.Now.ToString("hh")); - int m = int.Parse(DateTime.Now.ToString("mm")); - //榛樿涓�涓椂闂存(寮�濮嬫椂闂翠负:绯荤粺褰撳墠锛岀粨鏉熸椂闂翠负:寮�濮嬫椂闂�+1涓椂闂�) - Dictionary<string, string> timeDictionary = new Dictionary<string, string>(); - timeDictionary.Add("Type", "5"); - timeDictionary.Add("IsValid", "1"); - timeDictionary.Add("StartHour", h.ToString()); - timeDictionary.Add("StartMin", m.ToString()); - if (h + 1 == 24) - { - //缁撴潫鏃堕棿瓒呭嚭24灏忔椂澶勭悊鏂规硶; - timeDictionary.Add("StopHour", h.ToString()); - timeDictionary.Add("StopMin", "59"); - } - else - { - timeDictionary.Add("StopHour", (h + 1).ToString()); - timeDictionary.Add("StopMin", m.ToString()); - } - Dictionary<string, object> actionsInfo = new Dictionary<string, object>(); - actionsInfo.Add("LinkType", 8); - actionsInfo.Add("DeviceAddr", doorLock.DeviceAddr); - actionsInfo.Add("Epoint", doorLock.DeviceEpoint); - actionsInfo.Add("PassData", "055704010112");//榛樿闂ㄩ攣甯稿紑 - - //new涓�涓柊閫昏緫瀵硅薄锛� - //鏂板闂ㄩ攣甯稿紑妯″紡鑷姩鍖栧叆鍙o紱 - Common.Logic.CurrentLogic = new Common.Logic(); - Common.Logic.CurrentLogic.IsEnable = 1;//榛樿涓哄紑 - Common.Logic.CurrentLogic.LogicType = 2;//鏍囪閫昏緫绫诲瀷 - Common.Logic.CurrentLogic.LogicName = Language.StringByID(MyInternationalizationString.openmode); - Common.Logic.CurrentLogic.Conditions.Add(timeDictionary);//娣诲姞鏉′欢 - Common.Logic.CurrentLogic.Actions.Add(actionsInfo);//娣诲姞鐩爣 - var oneLogic = new OneLogic(); - UserView.HomePage.Instance.AddChidren(oneLogic); + var doorLockLogicList = new DoorLockLogic.LockLogicList(); + UserView.HomePage.Instance.AddChidren(doorLockLogicList); UserView.HomePage.Instance.PageIndex += 1; - oneLogic.Show(false); - } break; + doorLockLogicList.Show(); + } + break; + } } - - #region 鈼� 鑷姩鍖朹_________________________ - + public static bool If_once = true;//杩涙潵鍙涓�娆℃爣璇�; /// <summary> /// 鑷姩鍖栧姛鑳戒唬鐮佸叆鍙� /// </summary> public static void ShowAutotionView(FrameLayout functionSceneAutoBodyView) { - // functionSceneAutoBodyView.BackgroundColor = ZigbeeColor.Current.LogicMiddleBackgroundColor; + //functionSceneAutoBodyView.BackgroundColor = ZigbeeColor.Current.LogicMiddleBackgroundColor; #region ---鎺ㄨ崘妯℃澘鐨勭粍浠� //鎺ㄨ崘妯℃澘鑳屾櫙鎺т欢 + + + var bjFrameLayout1 = new FrameLayout + { + Width = Application.GetRealWidth(1080 - 58), + Height = Application.GetRealHeight(50), + BackgroundColor = ZigbeeColor.Current.LogicBackgroundColor, + X = Application.GetRealWidth(58), + //Radius = (uint)Application.GetRealHeight(50), + Y = Application.GetRealHeight(30), + + }; + functionSceneAutoBodyView.AddChidren(bjFrameLayout1); var bjFrameLayout = new FrameLayout { Width = Application.GetRealWidth(1080 - 58), @@ -123,15 +95,15 @@ X = Application.GetRealWidth(58), //Radius = (uint)Application.GetRealHeight(50), Y = Application.GetRealHeight(30), - }; functionSceneAutoBodyView.AddChidren(bjFrameLayout); - bjFrameLayout.SetCornerWithSameRadius(Application.GetRealHeight(58), HDLUtils.RectCornerBottomLeft); + bjFrameLayout1.SetCornerWithSameRadius(Application.GetRealHeight(17), HDLUtils.RectCornerTopLeft); + bjFrameLayout.SetCornerWithSameRadius(Application.GetRealHeight(58), HDLUtils.RectCornerTopLeft|HDLUtils.RectCornerBottomLeft); //鍥炬爣鎺т欢 var sigBtn = new Button { - Width = Application.GetMinRealAverage(84), - Height = Application.GetMinRealAverage(84), + Width = Application.GetRealWidth(84), + Height = Application.GetRealWidth(84), UnSelectedImagePath = "ZigeeLogic/sign.png", X = Application.GetRealWidth(58), Gravity = Gravity.CenterVertical, @@ -140,8 +112,8 @@ //鎺ㄨ崘妯℃澘鏂囨湰鎺т欢 var recommendtextBtn = new Button { - Width = Application.GetMinRealAverage(300), - Height = Application.GetMinRealAverage(84), + Width = Application.GetRealWidth(300), + Height = Application.GetRealHeight(84), X = sigBtn.Right + Application.GetRealWidth(35), TextAlignment = TextAlignment.CenterLeft, //Text = "鎺ㄨ崘妯℃澘", @@ -155,7 +127,7 @@ var recommendswitchBtn = new Button { Width = Application.GetRealWidth(104), - Height = Application.GetRealHeight(63), + Height = Application.GetRealWidth(63), UnSelectedImagePath = "ZigeeLogic/logicclose.png", SelectedImagePath = "ZigeeLogic/logicopen.png", X = bjFrameLayout.Width - Application.GetRealWidth(104 + 58), @@ -181,7 +153,7 @@ Y = scenehorizontalScrol.Bottom, }; functionSceneAutoBodyView.AddChidren(logicScrolView); - + logicScrolView.SetCornerWithSameRadius(Application.GetRealHeight(58), HDLUtils.RectCornerTopLeft); bool no = false; //鏄剧ず榛樿妯℃澘鐨勭晫闈簨浠� @@ -200,14 +172,14 @@ var frameLayout = new FrameLayout { - Width = Application.GetMinRealAverage(369 + 46), - Height = Application.GetMinRealAverage(246), + Width = Application.GetRealWidth(369 + 46), + Height = Application.GetRealHeight(246), }; scenehorizontalScrol.AddChidren(frameLayout); var logiciocnBtn = new Button { - Width = Application.GetMinRealAverage(369), - Height = Application.GetMinRealAverage(246), + Width = Application.GetRealWidth(369), + Height = Application.GetRealWidth(246), UnSelectedImagePath = "ZigeeLogic/" + i + ".png", Tag = i, }; @@ -215,8 +187,8 @@ var logicnameBtn = new Button { - Width = Application.GetMinRealAverage(250), - Height = Application.GetMinRealAverage(80), + Width = Application.GetRealWidth(250), + Height = Application.GetRealHeight(80), X = Application.GetRealWidth(23), Y = Application.GetRealHeight(246 - 23 - 80), TextAlignment = TextAlignment.CenterLeft, @@ -281,15 +253,19 @@ //涓嬫媺鍒锋柊鑷姩鍖栧垪琛ㄧ殑浜嬩欢 logicScrolView.BeginHeaderRefreshingAction += () => { - //閲嶆柊鍒锋柊logic鍒楄〃 - Common.Logic.LogicList.Clear(); - Read(logicScrolView, no); + if (!Config.Instance.Home.IsVirtually) + {//铏氭嫙鐨勪笉鑾峰彇缃戝叧閫昏緫鍒楄〃 + //閲嶆柊鍒锋柊logic鍒楄〃 + If_once = true; + Common.Logic.LogicList.Clear(); + Read(logicScrolView, no); + } //鍏抽棴鍒锋柊View锛� logicScrolView.EndHeaderRefreshing(); }; - //鑷姩鍖� - Read(logicScrolView, no); + //鑷姩鍖� + Read(logicScrolView, no); } /// <summary> @@ -298,48 +274,74 @@ /// <param name="logicScrolView"></param> private static async void Read(VerticalRefreshLayout logicScrolView, bool no) { + //if (Config.Instance.HomeId != UserCenter.UserCenterResourse.AccountOption.OldHomeStringId) + //{ + // //鍒囨崲浣忓畢娓呴櫎涔嬪墠缂撳瓨鏁版嵁; + // Common.Logic.LogicList.Clear(); + // Common.Logic.LockLogicList.Clear(); + // Common.Logic.SoneLogicList.Clear(); + //} + CommonPage.Loading.Start(); - if (Common.Logic.LogicList.Count == 0) + try { - var Idlist1 = await Send.GetLogicId(0);// - var Idlist2 = await Send.GetLogicId(2);//闂ㄩ攣甯稿紑妯″紡 - if (Idlist1.Count != 0) + if (!Config.Instance.Home.IsVirtually)//铏氭嫙鐨勪笉鑾峰彇缃戝叧閫昏緫鍒楄〃 { - var listlogic1 = await Send.ReadList(Idlist1.Count, 0); - for (int j = 0; j < listlogic1.Count; j++) + if (If_once) { - var logic = listlogic1[j]; - if (logic.LogicType != 0) + if (Common.Logic.LogicList.Count == 0) { - continue; + If_once = false; + var Idlist1 = await Send.GetLogicId(0);// + var Idlist2 = await Send.GetLogicId(2);//闂ㄩ攣甯稿紑妯″紡 + if (Idlist1.Count != 0) + { + var listlogic1 = await Send.ReadList(Idlist1.Count, 0); + for (int j = 0; j < listlogic1.Count; j++) + { + var logic = listlogic1[j]; + if (logic.LogicType != 0) + { + continue; + } + Common.Logic.LogicList.Add(logic); + } + } + if (Idlist2.Count != 0) + { + var listlogic2 = await Send.ReadList(Idlist2.Count, 2); + for (int j = 0; j < listlogic2.Count; j++) + { + var logic = listlogic2[j]; + if (logic.LogicType != 2) + { + continue; + } + Common.Logic.LogicList.Add(logic); + } + } + } - Common.Logic.LogicList.Add(logic); } } - if (Idlist2.Count != 0) - { - var listlogic2 = await Send.ReadList(Idlist2.Count, 2); - for (int j = 0; j < listlogic2.Count; j++) - { - var logic = listlogic2[j]; - if (logic.LogicType != 2) - { - continue; - } - Common.Logic.LogicList.Add(logic); - } - } + } + catch (Exception e) + { + var dd = e.Message; } //鑷姩鍖� Automationview(logicScrolView, no); CommonPage.Loading.Hide(); } + static RowLayout selectedRow = new RowLayout() { Tag = "0" };//璁板綍宸︽粦鐘舵�� + /// <summary> /// 鍔犺浇鑷姩鍖栧垪琛ㄧ晫闈� /// </summary> /// <param name="refresview">Refresview.</param> private static async void Automationview(VerticalRefreshLayout refresview, bool no) { + refresview.RemoveAll(); if (Common.Logic.LogicList.Count == 0 && no == false) { @@ -347,7 +349,7 @@ refresview.BackgroundColor = 0x00000000; var noFrameLayout = new FrameLayout { - Height = Application.GetRealHeight(434 + 200 + 32 + 294-55), + Height = Application.GetRealHeight(434 + 200 + 32 + 294 - 55), //BackgroundColor = ZigbeeColor.Current.LogicMiddleBackgroundColor, }; refresview.AddChidren(noFrameLayout); @@ -355,9 +357,9 @@ var noIconBtn = new Button { - Y = Application.GetRealHeight(294-55), - Width = Application.GetMinRealAverage(756), - Height = Application.GetMinRealAverage(434), + Y = Application.GetRealHeight(294 - 55), + Width = Application.GetRealWidth(757), + Height = Application.GetRealWidth(435), UnSelectedImagePath = "Item/NoFunction.png", X = Application.GetRealWidth(104), }; @@ -394,7 +396,7 @@ int i = 1;//灞�閮ㄥ彉閲忥紝榛樿鏄涓�鏉¢�昏緫; foreach (var logic in Common.Logic.LogicList) { - + var fLayout = new FrameLayout { Height = Application.GetRealHeight(190 + 30), @@ -402,7 +404,7 @@ BackgroundColor = ZigbeeColor.Current.LogicBackgroundColor, }; refresview.AddChidren(fLayout); - + var logicRowlayout = new RowLayout { Height = Application.GetRealHeight(190 + 30), @@ -410,17 +412,27 @@ LineColor = ZigbeeColor.Current.LogicBackgroundColor, BackgroundColor = ZigbeeColor.Current.LogicBackgroundColor, SubViewWidth = Application.GetRealWidth(184),//鏀瑰彉缂栬緫鎺т欢瀹藉害澶氬皯锛� + Tag = i.ToString(), }; fLayout.AddChidren(logicRowlayout); + //宸︽粦鑿滃崟浜嬩欢 + logicRowlayout.OpenMenuAction += () => + { + if (selectedRow.Tag.ToString() != logicRowlayout.Tag.ToString()) + { //淇濈暀宸︽粦鍙湁涓�涓�; + selectedRow.HideMenu();// + } + selectedRow = logicRowlayout; + }; if (i == 1) { //瀹炵幇android鏄剧ず閫昏緫鍒楄〃鐨勫渾瑙�; fLayout.SetCornerWithSameRadius(Application.GetRealHeight(58), HDLUtils.RectCornerTopLeft); logicRowlayout.SetCornerWithSameRadius(Application.GetRealHeight(58), HDLUtils.RectCornerTopLeft); - i = 2; + } - + i++; var logicnameBtn = new Button { Height = Application.GetRealHeight(58), @@ -436,8 +448,8 @@ var logicswitchBtn = new Button { - Width = Application.GetMinRealAverage(104), - Height = Application.GetMinRealAverage(63), + Width = Application.GetRealWidth(104), + Height = Application.GetRealWidth(63), UnSelectedImagePath = "ZigeeLogic/logicclose.png", SelectedImagePath = "ZigeeLogic/logicopen.png", X = logicRowlayout.Width - Application.GetRealWidth(104 + 58), @@ -461,7 +473,10 @@ logic.IsEnable = 0; StatusColor(logic, logicRowlayout, 0); } - Send.LogicControlSwitch(logic); + if (!Config.Instance.Home.IsVirtually) + { + Send.LogicControlSwitch(logic); + } //Logic.Send.AddModifyLogic(logic); }; if (logic.IsEnable == 1) @@ -482,6 +497,10 @@ TextColor = ZigbeeColor.Current.LogicBtnSaveTextColor, }; logicRowlayout.AddRightView(edit); + if (logic.LogicType == 2) + { + edit.TextID = MyInternationalizationString.look; + } edit.MouseUpEventHandler += (sender, e) => { Common.Logic.CurrentLogic = logic; @@ -511,15 +530,18 @@ logicRowlayout.AddRightView(del); del.MouseUpEventHandler += (sender, e) => { - var alert = new UserCenter.ShowMsgControl(UserCenter.ShowMsgType.Confirm, + var alert = new UserCenter.ShowMsgControl(ShowMsgType.Confirm, Language.StringByID(MyInternationalizationString.doyouwanttodelete), - Language.StringByID(MyInternationalizationString.confrim)); - alert.Show(); - alert.ConfirmClickEvent += () => + Language.StringByID(MyInternationalizationString.confrim)); + alert.Show(); + alert.ConfirmClickEvent += () => { Common.Logic.LogicList.Remove(logic); Automationview(refresview, no); - Send.DelLogic(logic.LogicId); + if (!Config.Instance.Home.IsVirtually) + { + Send.DelLogic(logic.LogicId); + } }; }; @@ -532,6 +554,8 @@ BackgroundColor = ZigbeeColor.Current.LogicRowLayoutLineColor, }; fLayout.AddChidren(line); + + } } @@ -570,8 +594,8 @@ indexlist.Add(linkType); } } - //鎺掑垪鍥炬爣椤哄簭; - if (indexlist.Contains("0")|| indexlist.Contains("8")) + //鎺掑垪鍥炬爣椤哄簭; + if (indexlist.Contains("0") || indexlist.Contains("8")) { iconIndexlist.Add("0"); } @@ -603,8 +627,8 @@ var typeIconBtn = new Button { - Width = Application.GetMinRealAverage(58), - Height = Application.GetMinRealAverage(58), + Width = Application.GetRealWidth(58), + Height = Application.GetRealWidth(58), Gravity = Gravity.Center, }; @@ -615,7 +639,7 @@ Y = typebjBtn.Y + Application.GetRealHeight(35), X = Application.GetRealWidth(58) + Application.GetRealWidth((12 + 82 + 12) + (12 + 45 + 82 + 12) * i), Width = Application.GetRealWidth(48), - Height = Application.GetRealHeight(15), + Height = Application.GetRealWidth(15), UnSelectedImagePath = "ZigeeLogic/connect.png", }; logicRowlayout.AddChidren(connectIconBtn); @@ -690,19 +714,18 @@ } } } - #endregion /// <summary> - /// 闂ㄩ攣鍙栨秷璁剧疆鐢ㄧ殑鏂规硶(鐩稿綋涓�涓叧闂父寮�妯″紡鎸夐挳,鍒嗙被-鑷姩鍖�-涓嶉渶瑕佹樉绀鸿鑷姩鍖�) + /// 闂ㄩ攣澶辨晥璁剧疆鐢ㄧ殑鏂规硶(鐩稿綋涓�涓叧闂父寮�妯″紡鎸夐挳,鍒嗙被-鑷姩鍖�-涓嶉渶瑕佹樉绀鸿鑷姩鍖�) /// </summary> /// <param name="timeVlaue">鏃堕棿鍊�</param> /// <param name="common">璁惧</param> /// <returns></returns> - public static void LockAddModifyLogic(int timeVlaue, CommonDevice common) + public static async System.Threading.Tasks.Task<int> LockAddModifyLogic(int timeVlaue, CommonDevice common) { //璇诲彇绯荤粺褰撳墠鏃堕棿锛氭椂-鍒� - var h = DateTime.Now.ToString("hh"); + var h = DateTime.Now.ToString("HH"); var m = DateTime.Now.ToString("mm"); Dictionary<string, string> timeConditionsInfo = new Dictionary<string, string>(); timeConditionsInfo.Add("Type", "0"); @@ -713,12 +736,25 @@ timeConditionsInfo.Add("DelayTime", "0"); timeConditionsInfo.Add("StartHour", h); timeConditionsInfo.Add("StartMin", m); - timeConditionsInfo.Add("DoorLockOpenDelayTime", timeVlaue.ToString()); + if (UserCenter.UserCenterResourse.HideOption.DoorLockNomallyOpenTimeMode == 1) + { + //寮哄埗鍙樻洿鏃堕棿妯″紡涓哄垎閽� + timeConditionsInfo.Add("DoorLockOpenDelayTime", (timeVlaue * 60).ToString()); + } + else + { + timeConditionsInfo.Add("DoorLockOpenDelayTime", (timeVlaue * 3600).ToString()); + } Dictionary<string, object> actionsInfo = new Dictionary<string, object>(); actionsInfo.Add("LinkType", 8); actionsInfo.Add("DeviceAddr", common.DeviceAddr); - actionsInfo.Add("Epoint", common.DeviceEpoint); + actionsInfo.Add("Epoint", "200"); actionsInfo.Add("PassData", "055704010113");//榛樿闂ㄩ攣甯稿叧 + + Dictionary<string, string> accounts = new Dictionary<string, string>(); + accounts.Add("Type", "8"); + accounts.Add("Option4", common.DeviceAddr.ToString());//鐢ㄤ簬鍒ゆ柇璇嗗埆鏄摢涓棬閿�; + accounts.Add("Option2", common.DeviceEpoint.ToString()); Common.Logic currentLogic = new Common.Logic(); currentLogic.IsEnable = 1;//榛樿涓哄紑 @@ -727,79 +763,129 @@ currentLogic.LogicName = Language.StringByID(R.MyInternationalizationString.openmode); currentLogic.Conditions.Add(timeConditionsInfo); currentLogic.Actions.Add(actionsInfo); - Exist(3);//鏌ユ壘鏄惁瀛樺湪璁剧疆杩囧け鏁堟椂闂�(鏈夌殑璇濆垹闄わ紝鍐嶆坊鍔�) - Send.AddModifyLogic(currentLogic); + currentLogic.Accounts.Add(accounts); + var logicIfon = await Send.AddModifyLogic(currentLogic); + if (logicIfon != null && logicIfon.LogicId != 0) + { + //娣诲姞闂ㄩ攣澶辨晥鏃堕棿鐨勫巻鍙茶褰� + UserCenter.HdlDeviceDoorLockLogic.Current.AddDoorHistoryLog((DoorLock)common, 9003, timeVlaue.ToString()); + return logicIfon.LogicId;//琛ㄧず娣诲姞鎴愬姛; + } + return 0;//琛ㄧず娣诲姞澶辫触; } ///<summary> - /// 鏄惁瀛樺湪S-one閫昏緫鏂规硶(true涓哄瓨鍦�) + /// s-one闂ㄩ攣鏄惁瀛樺湪鑷姩鍖栫殑鏂规硶; + /// 娉ㄦ剰(鍙傛暟:2-甯稿紑鑷姩鍖�;3-澶辨晥鏃堕棿鑷姩鍖�); + /// 杩斿洖鍊硷細0涓嶅瓨鍦�;鍏跺畠鍊奸兘瀛樺湪; /// </summary> - public static async System.Threading.Tasks.Task<bool> Exist(int valueInt=2) + public static async System.Threading.Tasks.Task<int> Exist(int valueInt, ZigBee.Device.DoorLock doorLock) { - bool exist = false; - var Idlist = await Send.GetLogicId(valueInt); - if (Idlist.Count != 0) + + int exist = 0; + var IdList = await Send.GetLogicId(valueInt); + if (IdList.Count != 0) { - if (valueInt==3) { - for (int i = 0; i < Idlist.Count; i++) + for (int i = 0; i < IdList.Count; i++) + { + var id = IdList[i]; + var logic = await Send.GetLogic(id, valueInt); + if (logic != null) { - //valueInt=3涓�鏉$壒娈婄殑鑷姩鍖�(鐢ㄦ潵璁剧疆澶辨晥鏃堕棿) - Send.DelLogic(Idlist[i]); + if (ExistLogic(logic, doorLock)) + { + exist = id; + ///鎵惧埌閫�鍑� + break; + } } + } - exist = true; } return exist; } ///<summary> - /// s-one闂ㄩ攣纭鍙栨秷鍙戦�佺殑鏂规硶 + ///鑾峰彇闂ㄩ攣鏃舵晥鎬ч�昏緫淇℃伅 + /// 杩斿洖鍊硷細null涓嶅瓨鍦�;鍏跺畠鍊奸兘瀛樺湪; /// </summary> - public static async void LockCloseLogic(CommonDevice common) + public static async System.Threading.Tasks.Task<Common.Logic> GetLogicIfon(ZigBee.Device.DoorLock doorLock) { - //璇诲彇绯荤粺褰撳墠鏃堕棿锛氭椂-鍒� - int h =int.Parse(DateTime.Now.ToString("hh")); - int m= int.Parse(DateTime.Now.ToString("mm")); - //杞寲涓哄灏戝垎閽�; - int s = h * 60 + m; - List<Common.Logic> logicList = new List<Common.Logic>(); - logicList.Clear(); - var Idlist = await Send.GetLogicId(2); + Common.Logic logic = null; + var Idlist = await Send.GetLogicId(3); if (Idlist.Count != 0) - { //鍏堝幓璇诲彇缃戝叧鐪嬫槸鍚﹀瓨鍦ㄦ暟鎹�; - var list = await Send.ReadList(Idlist.Count, 2); - for (int j = 0; j < list.Count; j++) + { + //榛樿鍙栫涓�涓�昏緫ID(鏃舵晥鎬у彧鏈変竴鏉¢�昏緫) + int exist = Idlist[0]; + logic = await Send.GetLogic(exist, 3); + if (!ExistLogic(logic, doorLock)) { - var logic = list[j]; - foreach (var conditions in logic.Conditions) - { - var linkType = conditions["Type"]; - if (linkType == "5") - { - int startMin = int.Parse(conditions["StartMin"]); - int startHour = int.Parse(conditions["StartHour"]); - int stopMin = int.Parse(conditions["StopMin"]); - int stopHour = int.Parse(conditions["StopHour"]); - int s1 = startMin + startHour * 60;//寮�濮嬫椂闂村�� - int s2 = stopMin + stopHour * 60;//缁撴潫鏃堕棿鍊� - if (s >= s1&&s<=s2) - { - //鏌ユ壘绯荤粺鏃堕棿鍊兼槸鍚﹀睘浜庤繖涓寖鍥达紱 - logicList.Add(logic); - } - } - } - + logic = null; } } - foreach (var logic in logicList) - { - logic.IsEnable = 3;//鏀瑰彉閫昏緫浣胯兘鐘舵��; - //鐢╢oreach鍙戦�佸懡浠わ紱 - Send.AddModifyLogic(logic); - } + return logic; } + + ///<summary> + ///鍒犻櫎璇ラ棬閿佹墍鏈夋椂鏁堟�ц嚜鍔ㄥ寲 + /// 杩斿洖鍊硷細true鎴愬姛;false澶辫触; + /// </summary> + public static async System.Threading.Tasks.Task<bool> DelAllLogic(ZigBee.Device.DoorLock doorLock) + { + bool _if = false; + var Idlist = await Send.GetLogicId(3); + if (Idlist.Count != 0) + { + for (int i = 0; i < Idlist.Count; i++) + { + int id = Idlist[i]; + var logic = await Send.GetLogic(id, 3); + if (logic != null) + { + if (ExistLogic(logic, doorLock)) + { + //鏈潵鍙湁涓�鏉℃椂鏁堟�ц嚜鍔ㄥ寲锛� + //闃叉鐗规畩鎯呭喌,鎵惧埌灏卞垹闄ゆ帀; + //var valueInt = await Send.DelLogic(id); + //if (valueInt == 0) + //{ + // _if = true; + //} + //(鑰冭檻鎬ц兘榛樿鍒犻櫎鎴愬姛锛岀洿鎺ヨ繑鍥炴垚鍔熺粨鏋渢rue) + _if = true; + Send.DelLogic(id); + + + } + } + } + } + return _if; + } + + /// <summary> + /// 鏌ユ壘杩欎竴鏉¤嚜鍔ㄥ寲鏄惁灞炰簬璇ラ棬閿� + /// </summary> + /// <returns></returns> + public static bool ExistLogic(Common.Logic logic, ZigBee.Device.DoorLock doorLock) + { + for (int j = 0; j < logic.Accounts.Count; j++) + { + //Option4鏄澶噈ac锛� + if (logic.Accounts[j]["Option4"].ToString() == doorLock.DeviceAddr) + { + //鏌ユ壘鏄惁鏄偅涓棬閿侊紱 + //濡傛灉涓嶆槸璇ラ棬閿佽仈鍔ㄤ簨浠朵笉鏄剧ず鍑烘潵; + return true; + } + + } + return false; + } + + + } } -- Gitblit v1.8.0