From d8545fbd1b36a6766c57c987e5d89862b470fed9 Mon Sep 17 00:00:00 2001
From: JLChen <551775569@qq.com>
Date: 星期四, 03 九月 2020 09:46:29 +0800
Subject: [PATCH] 2020-09-03 1.修改风扇默认为关状态。2.Alexa添加设备时,去掉空调和通用开关选择添加支持。 3.场景增加通用开关添加和发送控制支持,Alexa 的场景同样增加通用开关的支持。

---
 Crabtree/SmartHome/UI/SimpleControl/EquipmentPublicClass.cs |  110 ++++++++++++++++++++++++++++++++++++-------------------
 1 files changed, 72 insertions(+), 38 deletions(-)

diff --git a/Crabtree/SmartHome/UI/SimpleControl/EquipmentPublicClass.cs b/Crabtree/SmartHome/UI/SimpleControl/EquipmentPublicClass.cs
index 0013c38..c48d449 100644
--- a/Crabtree/SmartHome/UI/SimpleControl/EquipmentPublicClass.cs
+++ b/Crabtree/SmartHome/UI/SimpleControl/EquipmentPublicClass.cs
@@ -1,8 +1,5 @@
 using System;
 using Shared.SimpleControl.Phone;
-using System.Collections.Generic;
-using System.Text;
-using System.Net.NetworkInformation;
 
 namespace Shared.SimpleControl
 {
@@ -17,26 +14,41 @@
         }
 
         static bool isConnectiong = false;
-
+        static DateTime mFlagDateTime;
         /// <summary>
         /// 妫�娴�/杩炴帴杩滅▼
         /// </summary>
+        /// <param name="status">褰撳墠缃戠粶鐘舵��</param>
+        /// <param name="IsReconnectRemote">鏄惁闇�瑕侀噸鏂拌繛鎺ヨ繙绋�</param>
         public static void CheckLinkRemote (int status, bool IsReconnectRemote = true)
         {
-            //if (isConnectiong) {
-            //    return;
-            //}
-            //isConnectiong = true;
+
+            //20S鍚庡己鍒堕噸缃甶sConnectiong鐘舵�侊紝闃叉isConnectiong涓�鐩翠负true鐘舵��
+            if (mFlagDateTime.AddSeconds (20).Ticks <= System.DateTime.Now.Ticks) {
+                mFlagDateTime = DateTime.Now;
+                if (isConnectiong) {
+                    Utlis.WriteLine ("20s銆媔sConnectiong true ");
+                    isConnectiong = false;
+                }
+            }
+
+            if (isConnectiong) {
+                return;
+            }
+            isConnectiong = true;
             UserConfig.Instance.internetStatus = status;
 #if wallon
-                return;
+                            return;
 #endif
-            if (MainPage.LoginUser == null || !MainPage.LoginUser.IsLogin || isConnectiong) {
+            if (MainPage.LoginUser == null || !MainPage.LoginUser.IsLogin) {
+                isConnectiong = false;
                 return;
             }
 
-            isConnectiong = true;
             new System.Threading.Thread (async () => {
+
+                bool IsRemoteLoadingShow = false;
+
                 try {
                     if (status == 0) {
                         Application.RunOnMainThread (() => {
@@ -65,13 +77,16 @@
                                 obj.Split ('_') [1].ToString () == DeviceType.OnePortMqttFR.ToString ());
                         });
                         bool canRemote = false;
-                       
+                      
+
+
+                        //1.濡傛灉鏈湴娌$綉鍏虫暟鎹紝鎻愮ずWiFiOffline锛屽苟涓斿垽鏂槸鍚﹂渶瑕佹柇寮�杩滅▼
                         if (gateWayList == null || gateWayList.Count == 0) {
                             Utlis.ShowAppLinkStatus (AppLinkStatus.WiFiOffline);
                             await DisConnectRemoteAsync ();
                         }
 
-
+                        //2.杩滅▼杩炴帴鎯呭喌涓嬶紝鏄惁闇�瑕佹柇寮�杩炴帴閲嶈繛
                         if (IsReconnectRemote) {
                             if (CommonPage.IsRemote) {
                                 CommonPage.IsRemote = false;
@@ -80,12 +95,13 @@
                             }
                         }
 
+                        //3.鍙戦�佷竴娆� CheckGateway鏁版嵁
                         if (CommonPage.IsRemote) {
                             //await SmartHome.MqttCommon.StartCloudMqtt ();
                             SmartHome.MqttCommon.MqttRemoteSend (new byte [] { }, 3);
                         }
 
-                        //鏈湴鏄惁瀛樺湪涓庡綋鍓嶄綇瀹呯粦瀹氱綉鍏崇殑鏁版嵁
+                        //4.鏈湴鏄惁瀛樺湪涓庡綋鍓嶄綇瀹呯粦瀹氱綉鍏崇殑鏁版嵁
                         bool HomeGatewaysExistsLocally = false;
                         foreach (var gatewayFileName in gateWayList) {
                             var tempStrings = gatewayFileName.Split ('_');
@@ -93,11 +109,15 @@
                             var common = Newtonsoft.Json.JsonConvert.DeserializeObject<GatewayBase> (gateWayString);
                             if (common != null) {
                                 if (common.MAC.Replace (".", "") == UserConfig.Instance.GatewayMAC.Replace (".", "")) {
+                                    //4.1 鏈湴瀛樺湪涓庡綋鍓嶄綇瀹呯粦瀹氱綉鍏崇殑鏁版嵁锛屽鏋滄槸WiFi杩炴帴锛屽氨灞�鍩熺綉鎼滅储缃戝叧鏄惁鍦ㄥ悓涓�灞�鍩熺綉
                                     HomeGatewaysExistsLocally = true;
                                     canRemote = true;
                                     if (status == 2) {
                                         //var result = Control.ControlBytesSendHasReturn (Command.ReadGateway, common.SubnetID, common.DeviceID, new byte [] { (byte)new Random ().Next (255), (byte)new Random ().Next (255) });
                                         #region
+                                        //寮�濮嬫湰鍦版悳绱㈢綉鍏�...
+                                        MainPage.LoadingStart ("Searching local gateway...");
+
                                         var control = new Control ();
                                         control.Send (new Target () {
                                             IPEndPoint = new System.Net.IPEndPoint (System.Net.IPAddress.Parse (new Net.NetWiFi ().BroadcastIpAddress.ToString ()), 6000),
@@ -113,16 +133,26 @@
                                             canRemote = false;
                                             var mac0 = CommonPage.byteToHex16 (result [5]) + "." + CommonPage.byteToHex16 (result [6]) + "." + CommonPage.byteToHex16 (result [7]) + "." + CommonPage.byteToHex16 (result [8]) + "." + CommonPage.byteToHex16 (result [9]) + "." + CommonPage.byteToHex16 (result [10]) + "." + CommonPage.byteToHex16 (result [11]) + "." + CommonPage.byteToHex16 (result [12]);
                                             if (common.MAC == mac0) {
+                                                //4.2 缃戝叧鍦ㄥ悓涓�灞�鍩熺綉锛屾樉绀篧iFi鐘舵�侊紝鍙栨秷杩滅▼鏂紑杩滅▼杩炴帴
                                                 CommonPage.IsRemote = false;
                                                 Application.RunOnMainThread (() => {
                                                     MainPage.WiFiStatus = "CrabtreeAdd/WiFi.png";
                                                     UserMiddle.btnLinkStatus.UnSelectedImagePath = MainPage.WiFiStatus;
                                                     MainPage.Loading.Hide ();
                                                 });
+                                                //鎼滅储鎴愬姛锛屽惎鐢ㄦ湰鍦拌繛鎺�
+                                                MainPage.AddTip ("Gateway searched successfully, enable local connection.");
+
                                                 Shared.SimpleControl.Phone.UserMiddle.ReadAllDeviceStatus ();
                                                 await SmartHome.MqttCommon.DisConnectRemoteMqttClient ();
                                                 return;
+                                            } else {
+
                                             }
+                                        } else {
+                                            //鎼滅储澶辫触锛屽惎鐢ㄨ繙绋嬭繛鎺�
+                                            MainPage.AddTip ("Gateway cannot be searched locally.");
+                                            
                                         }
                                     } else {
                                         break;
@@ -133,53 +163,53 @@
 
 
 
-                        //鑳借繙绋�
+                        //5.鑳借繙绋�
                         if (canRemote) {
                             if (!CommonPage.IsRemote) {
                                 if (UserConfig.Instance.CheckHomeGateways ()) {
                                     if (!string.IsNullOrEmpty (UserConfig.Instance.CurrentRegion.HomeGateways [0].GatewayUniqueId)) {
-                                        Utlis.ShowAppLinkStatus (AppLinkStatus.CloudUnlink);
+                                        // 5.1鑳借繙绋�,鏄剧ずCloudUnlink鐘舵�侊紝IsRemote璁句负true寮�濮嬭繙绋�
+                                        //MainPage.AddTip ("Please wait, starting remote connection...");
+                                        //MainPage.LoadingStart ("Please wait, starting remote connection...");
+
+                                        MainPage.LoadingTipShow ("Please wait, starting remote connection...");
+
                                         CommonPage.IsRemote = true;
-                                        SmartHome.MqttCommon.IsGatewayOnline = false;
-                                        //await SmartHome.MqttCommon.StartCloudMqtt ();
+                                        IsRemoteLoadingShow = true;
+                                        //閲嶇疆鍙傛暟鐘舵��
+                                        SmartHome.MqttCommon.InitState ();
+                                        Utlis.ShowAppLinkStatus (AppLinkStatus.CloudUnlink);
+
                                     }
                                 }
                             }
 
                         } else {
 
-                            //涓嶈兘杩滅▼锛屽鏋滀箣鍓嶈繙绋嬫ā寮忓垯鏂紑MQTT杩炴帴,鏄剧ず涓烘湭杩炴帴
+                            //6.涓嶈兘杩滅▼锛屽鏋滀箣鍓嶈繙绋嬫ā寮忓垯鏂紑MQTT杩炴帴,鏄剧ず涓烘湭杩炴帴
                             if (CommonPage.IsRemote) {
                                 Utlis.ShowAppLinkStatus (AppLinkStatus.WiFiOffline);
                                 CommonPage.IsRemote = false;
                                 await SmartHome.MqttCommon.DisConnectRemoteMqttClient ();
 
                             }
-
+                            //鏈湴涓嶅瓨鍦ㄤ笌褰撳墠浣忓畢缁戝畾缃戝叧鐨勬暟鎹�
                             if (!HomeGatewaysExistsLocally) {
                                 Utlis.ShowAppLinkStatus (AppLinkStatus.WiFiOffline);
                             }
 
                         }
-
-
-                        //if (canRemote && !CommonPage.IsRemote) {
-                        //    if (UserConfig.Instance.CheckHomeGateways ()) {
-                        //        if (!string.IsNullOrEmpty (UserConfig.Instance.CurrentRegion.HomeGateways [0].GatewayUniqueId)) {
-                        //            Utlis.ShowAppLinkStatus (AppLinkStatus.CloudUnlink);
-                        //            Shared.SimpleControl.CommonPage.IsRemote = true;
-                        //            //await SmartHome.MqttCommon.StartCloudMqtt ();
-                        //        }
-                        //    }
-                        //}
-
-
-
                     }
                 } catch (Exception ex) {
-                    Console.WriteLine ("CheckLinkRemote : " + ex.ToString ());
+                    Utlis.WriteLine ("CheckLinkRemote : " + ex.ToString ());
                 } finally {
                     isConnectiong = false;
+                    //if (!IsRemoteLoadingShow) {
+                    //    Application.RunOnMainThread (() => {
+                    //        MainPage.Loading.Hide ();
+                    //    });
+                    //}
+
                     Application.RunOnMainThread (() => {
                         MainPage.Loading.Hide ();
                     });
@@ -187,13 +217,14 @@
             }) { IsBackground = true }.Start ();
         }
 
+        //static bool IsRemoteLoadingShow = false;
 
-
         /// <summary>
         /// 鍏抽棴杩滅▼杩炴帴妯″紡锛屽苟鏂紑MQTT
         /// </summary>
-        /// <returns></returns>
-        static async System.Threading.Tasks.Task DisConnectRemoteAsync (){
+        /// <returns></returns>
+        static async System.Threading.Tasks.Task DisConnectRemoteAsync ()
+        {
 
             if (CommonPage.IsRemote) {
                 CommonPage.IsRemote = false;
@@ -205,3 +236,6 @@
 
 
 
+
+
+

--
Gitblit v1.8.0