From be95e839f40eb3ddf64706b60cba6dfcf4fad5e5 Mon Sep 17 00:00:00 2001
From: JLChen <551775569@qq.com>
Date: 星期五, 03 四月 2020 14:31:44 +0800
Subject: [PATCH] 2020-04-03 1.去掉登录前ping百度域名的网络监测。
---
Crabtree/SmartHome/UI/SimpleControl/EquipmentPublicClass.cs | 145 ++++++++++++++++++++++++++++++++++--------------
1 files changed, 102 insertions(+), 43 deletions(-)
diff --git a/Crabtree/SmartHome/UI/SimpleControl/EquipmentPublicClass.cs b/Crabtree/SmartHome/UI/SimpleControl/EquipmentPublicClass.cs
index f308fc1..c96c1ab 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,25 +14,37 @@
}
static bool isConnectiong = false;
-
+ static DateTime mFlagDateTime;
/// <summary>
/// 妫�娴�/杩炴帴杩滅▼
/// </summary>
- public static void CheckLinkRemote (int status)
+ /// <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 () => {
try {
if (status == 0) {
@@ -43,9 +52,13 @@
MainPage.AddTip (Language.StringByID (R.MyInternationalizationString.InternetStatusTip));
MainPage.WiFiStatus = "CrabtreeAdd/WiFiUnlink.png";
UserMiddle.btnLinkStatus.UnSelectedImagePath = MainPage.WiFiStatus;
+
});
+
+ await DisConnectRemoteAsync ();
+
} else {
-
+
//Application.RunOnMainThread (() => {
// if (UserMiddle.LinkStatusTip.BackgroundColor == SkinStyle.Current.DelColor) {
// UserMiddle.LinkStatusTip.BackgroundColor = SkinStyle.Current.MainColor;
@@ -58,19 +71,42 @@
obj.Split ('_') [1].ToString () == DeviceType.RCU.ToString () ||
obj.Split ('_') [1].ToString () == DeviceType.SuperWireless.ToString () ||
obj.Split ('_') [1].ToString () == DeviceType.OnePortWirelessFR.ToString () ||
- obj.Split ('_') [1].ToString () == DeviceType.OnePortMqttFR.ToString());
+ 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;
+ Utlis.ShowAppLinkStatus (AppLinkStatus.WiFiOffline);
+ await SmartHome.MqttCommon.DisConnectRemoteMqttClient ();
+ }
+ }
+
+ //3.鍙戦�佷竴娆� CheckGateway鏁版嵁
if (CommonPage.IsRemote) {
- await SmartHome.MqttCommon.StartCloudMqtt ();
+ //await SmartHome.MqttCommon.StartCloudMqtt ();
SmartHome.MqttCommon.MqttRemoteSend (new byte [] { }, 3);
}
+
+ //4.鏈湴鏄惁瀛樺湪涓庡綋鍓嶄綇瀹呯粦瀹氱綉鍏崇殑鏁版嵁
+ bool HomeGatewaysExistsLocally = false;
foreach (var gatewayFileName in gateWayList) {
var tempStrings = gatewayFileName.Split ('_');
var gateWayString = CommonPage.MyEncodingUTF8.GetString (IO.FileUtils.ReadFile (gatewayFileName));
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) });
@@ -82,35 +118,16 @@
SubnetID = common.SubnetID,
DeviceID = common.DeviceID,
AddData = new byte [] { (byte)new Random ().Next (255), (byte)new Random ().Next (255) },
- }, SendCount.Three, true,true);
- var result = control.UsefulBytes;
+ }, SendCount.Three, true, true);
+ var result = control.UsefulBytes;
#endregion
if (result != null) {
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;
- //var gatewayBytes = Control.ControlBytesSendHasReturn (Command.ReadGateWayModelInfo, common.SubnetID, common.DeviceID, new byte [] { });
- //#region
- //control.Send (new Target () {
- // IPEndPoint = new System.Net.IPEndPoint (System.Net.IPAddress.Parse (new Net.NetWiFi ().BroadcastIpAddress.ToString ()), 6000),
- // Command = Command.ReadGateWayModelInfo,
- // SubnetID = common.SubnetID,
- // DeviceID = common.DeviceID,
- // AddData = new byte [] { },
- //}, SendCount.Three, true,true);
- //var gatewayBytes = control.UsefulBytes;
- //#endregion
- //if (gatewayBytes != null) {
- //common.Remote_GroupName = CommonPage.MyEncodingGB2312.GetString (gatewayBytes, 1, 20).Trim ('\0');
- //common.Remote_ProjectName = CommonPage.MyEncodingGB2312.GetString (gatewayBytes, 21, 20).Trim ('\0');
- //common.Remote_UserName = CommonPage.MyEncodingGB2312.GetString (gatewayBytes, 41, 8).Trim ('\0');
- //common.Remote_Password = CommonPage.MyEncodingGB2312.GetString (gatewayBytes, 49, 8).Trim ('\0');
- //var requestJson2 = @"{'Token':'" + MainPage.LoginUser.LoginTokenString + "','MAC':'" + common.MAC + "','Password':'" + common.Remote_Password + "'}";
- //var revertObj2 = MainPage.RequestHttps ("UpdateRemoteSwitchPassword", requestJson2, true, false);
- //return;
- //}
Application.RunOnMainThread (() => {
MainPage.WiFiStatus = "CrabtreeAdd/WiFi.png";
UserMiddle.btnLinkStatus.UnSelectedImagePath = MainPage.WiFiStatus;
@@ -127,17 +144,41 @@
}
}
}
- if (canRemote && !CommonPage.IsRemote) {
- if (UserConfig.Instance.CheckHomeGateways ()) {
- if (!string.IsNullOrEmpty (UserConfig.Instance.CurrentRegion.HomeGateways[0].GatewayUniqueId)) {
- Shared.SimpleControl.CommonPage.IsRemote = true;
- await SmartHome.MqttCommon.StartCloudMqtt ();
+
+
+
+ //5.鑳借繙绋�
+ if (canRemote) {
+ if (!CommonPage.IsRemote) {
+ if (UserConfig.Instance.CheckHomeGateways ()) {
+ if (!string.IsNullOrEmpty (UserConfig.Instance.CurrentRegion.HomeGateways [0].GatewayUniqueId)) {
+ // 5.1鑳借繙绋�,鏄剧ずCloudUnlink鐘舵�侊紝IsRemote璁句负true寮�濮嬭繙绋�
+ Utlis.ShowAppLinkStatus (AppLinkStatus.CloudUnlink);
+ CommonPage.IsRemote = true;
+ SmartHome.MqttCommon.IsGatewayOnline = false;
+ //await SmartHome.MqttCommon.StartCloudMqtt ();
+ }
}
}
+
+ } else {
+
+ //6.涓嶈兘杩滅▼锛屽鏋滀箣鍓嶈繙绋嬫ā寮忓垯鏂紑MQTT杩炴帴,鏄剧ず涓烘湭杩炴帴
+ if (CommonPage.IsRemote) {
+ Utlis.ShowAppLinkStatus (AppLinkStatus.WiFiOffline);
+ CommonPage.IsRemote = false;
+ await SmartHome.MqttCommon.DisConnectRemoteMqttClient ();
+
+ }
+ //鏈湴涓嶅瓨鍦ㄤ笌褰撳墠浣忓畢缁戝畾缃戝叧鐨勬暟鎹�
+ if (!HomeGatewaysExistsLocally) {
+ Utlis.ShowAppLinkStatus (AppLinkStatus.WiFiOffline);
+ }
+
}
}
} catch (Exception ex) {
- Console.WriteLine ("CheckLinkRemote : " + ex.ToString ());
+ Utlis.WriteLine ("CheckLinkRemote : " + ex.ToString ());
} finally {
isConnectiong = false;
Application.RunOnMainThread (() => {
@@ -146,8 +187,26 @@
}
}) { IsBackground = true }.Start ();
}
+
+
+
+ /// <summary>
+ /// 鍏抽棴杩滅▼杩炴帴妯″紡锛屽苟鏂紑MQTT
+ /// </summary>
+ /// <returns></returns>
+ static async System.Threading.Tasks.Task DisConnectRemoteAsync ()
+ {
+
+ if (CommonPage.IsRemote) {
+ CommonPage.IsRemote = false;
+ await SmartHome.MqttCommon.DisConnectRemoteMqttClient ();
+ }
+ }
}
}
+
+
+
--
Gitblit v1.8.0