From 9a4b76398009cf76c508d61f7e48fb6f5cb7ac2d Mon Sep 17 00:00:00 2001 From: xm <1271024303@qq.com> Date: 星期二, 21 七月 2020 09:46:53 +0800 Subject: [PATCH] 请合并最新多功能面板代码 --- ZigbeeApp/Shared/Phone/UserCenter/Gateway/Add/WiredGatewaySearchForm.cs | 90 ++++++++++++++++++++++++++------------------- 1 files changed, 52 insertions(+), 38 deletions(-) diff --git a/ZigbeeApp/Shared/Phone/UserCenter/Gateway/Add/WiredGatewaySearchForm.cs b/ZigbeeApp/Shared/Phone/UserCenter/Gateway/Add/WiredGatewaySearchForm.cs index c6d8d0a..448ff57 100755 --- a/ZigbeeApp/Shared/Phone/UserCenter/Gateway/Add/WiredGatewaySearchForm.cs +++ b/ZigbeeApp/Shared/Phone/UserCenter/Gateway/Add/WiredGatewaySearchForm.cs @@ -30,9 +30,9 @@ /// </summary> private bool newGatewayGetting = false; /// <summary> - /// 缃戝叧妫�娴嬩腑 + /// 缃戝叧鎼滅储涓� /// </summary> - private string isGatewayChecking = "0"; + private bool isGatewaySearching = true; #endregion @@ -77,6 +77,8 @@ //鍒濆鍖栬繛鎺ョ殑鍋囨兂鍔ㄧ敾鏁堟灉 this.InitConcetionAnimete(picGwImage, btnMsg); + //寮�鍚綉鍏虫娴嬬殑绾跨▼ + this.StartCheckGatewayThread(); } /// <summary> @@ -167,7 +169,7 @@ btnReDo.Gravity = Gravity.CenterHorizontal; btnReDo.TextAlignment = TextAlignment.Center; btnReDo.TextID = R.MyInternationalizationString.uReDoAgain; - frameback.AddChidren(btnReDo, ChidrenBindMode.BindEventOnly); + frameback.AddChidren(btnReDo, ChidrenBindMode.BindEvent); frameback.ButtonClickEvent += (sender, e) => { //鍒濆鍖栧垵濮嬩腑閮ㄦ帶浠� @@ -226,10 +228,6 @@ string strMsg = btnMsg.Text; HdlThreadLogic.Current.RunThread(() => { - //娓呯┖鍏ㄩ儴鍒楄〃 - HdlGatewayLogic.Current.ClearAllRealGateway(); - ZigBee.Common.Application.IsSearchingGateway = true; - int index = 1; int maxCount = 120 * 2; int timeCount = 120; @@ -237,36 +235,13 @@ { System.Threading.Thread.Sleep(500); maxCount--; - if (maxCount % 4 == 0) - { - lock(isGatewayChecking) - { - if (isGatewayChecking != "1") - { - isGatewayChecking = "1"; - HdlThreadLogic.Current.RunThread(async () => - { - //姣�2绉掓娴嬫悳绱㈠埌鐨勭綉鍏� - await this.CheckZbGatewayAndSetRow(); - lock (isGatewayChecking) - { - isGatewayChecking = "0"; - } - }); - } - } - } - if (this.newGatewayGetting == true) - { - //鑾峰彇寰楀埌鏂扮綉鍏�,鍒欎腑鏂嚎绋� - break; - } if (maxCount % 2 == 0) { timeCount--; } - if (maxCount <= 0) + if (maxCount <= 0 || this.newGatewayGetting == true) { + //鑾峰彇寰楀埌鏂扮綉鍏�,鍒欎腑鏂嚎绋� break; } Application.RunOnMainThread(() => @@ -281,6 +256,9 @@ btnMsg.Text = strMsg + timeCount + "s"; }); } + //鎼滅储缁撴潫 + this.isGatewaySearching = false; + if (maxCount <= 0) { HdlThreadLogic.Current.RunMain(() => @@ -308,6 +286,42 @@ #region 鈻� 缃戝叧妫�娴媉__________________________ /// <summary> + /// 寮�鍚綉鍏虫娴嬬殑绾跨▼ + /// </summary> + private void StartCheckGatewayThread() + { + this.isGatewaySearching = true; + HdlThreadLogic.Current.RunThread(async () => + { + //娓呯┖鍏ㄩ儴鍒楄〃 + HdlGatewayLogic.Current.ClearAllRealGateway(); + ZigBee.Common.Application.IsSearchingGateway = true; + + int count = 0; + while (this.Parent != null && this.isGatewaySearching == true) + { + //姣�2绉掓娴嬫悳绱㈠埌鐨勭綉鍏� + System.Threading.Thread.Sleep(500); + count++; + if (count < 4) + { + //涓昏涓轰簡蹇竴鐐硅兘澶熶腑鏂繖涓嚎绋� + continue; + } + count = 0; + + await this.CheckZbGatewayAndSetRow(); + + if (this.newGatewayGetting == true) + { + //鑾峰彇寰楀埌鏂扮綉鍏�,鍒欎腑鏂嚎绋� + break; + } + } + }); + } + + /// <summary> /// 妫�娴嬫悳绱㈠埌鐨勭綉鍏筹紝鐒跺悗娣诲姞鍒扮敾闈㈢殑琛岄噷闈� /// </summary> private async Task<bool> CheckZbGatewayAndSetRow() @@ -315,12 +329,12 @@ List<string> listId = new List<string>(); for (int i = 0; i < ZbGateway.GateWayList.Count; i++) { - if (ZbGateway.GateWayList[i].getGatewayBaseInfo.IpAddress == string.Empty) + if (ZbGateway.GateWayList[i].GwIP == string.Empty) { //IP娌℃湁鐨勭綉鍏筹紝鎴戜篃涓嶇煡閬撳畠鏄共鍢涚殑 continue; } - string gwId = HdlGatewayLogic.Current.GetGatewayId(ZbGateway.GateWayList[i]); + string gwId = ZbGateway.GateWayList[i].GwId; //閲嶅娣诲姞妫�娴� if (this.dicIdCheckCount.ContainsKey(gwId) == false) { @@ -342,7 +356,7 @@ } for (int i = 0; i < listId.Count; i++) { - ZbGateway way = ZbGateway.GateWayList.Find((obj) => HdlGatewayLogic.Current.GetGatewayId(obj) == listId[i]); + ZbGateway way = ZbGateway.GateWayList.Find((obj) => obj.GwId == listId[i]); if (way == null) { continue; @@ -352,9 +366,9 @@ GatewayBindMode mode = GatewayBindMode.BindAgain; //濡傛灉鏄涓�娆$粦瀹�,鎴栬�呮槸浠ュ墠宸茬粡缁戝畾杩囦簡鐨� if (HdlGatewayLogic.Current.HomeIdIsEmpty(way) == true - || way.getGatewayBaseInfo.HomeId == Common.Config.Instance.HomeId) + || way.HomeId == Common.Config.Instance.HomeId) { - if (way.getGatewayBaseInfo.HomeId != Common.Config.Instance.HomeId) + if (way.HomeId != Common.Config.Instance.HomeId) { //绗竴娆$粦瀹�,涔熷氨鏄綉鍏充綇瀹匢D涓虹┖ mode = GatewayBindMode.First; @@ -399,7 +413,7 @@ this.newGatewayGetting = true; } - if (mode == GatewayBindMode.First) + if (mode == GatewayBindMode.First || mode == GatewayBindMode.Binded) { //鎴戣寰楄繖閲岄渶瑕佽幏鍙栦竴涓嬫柊缃戝叧鐨勮澶囧垪琛� Common.LocalDevice.Current.SetDeviceToMemmoryByGateway(way); -- Gitblit v1.8.0