From b253e7c13fab85912af2ee8494a19b42b607fd7a Mon Sep 17 00:00:00 2001
From: JLChen <551775569@qq.com>
Date: 星期一, 21 十二月 2020 09:26:20 +0800
Subject: [PATCH] 2020-12-21 1.修改密码错误锁定提示,增加时间提示。

---
 HDL-ON_Android/Application.cs |  171 +++++++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 135 insertions(+), 36 deletions(-)

diff --git a/HDL-ON_Android/Application.cs b/HDL-ON_Android/Application.cs
index fd6bb1c..44e4c01 100644
--- a/HDL-ON_Android/Application.cs
+++ b/HDL-ON_Android/Application.cs
@@ -5,6 +5,7 @@
 using Android.Content;
 using Android.Net;
 using Android.OS;
+using CN.Jpush.Android.Api;
 using HDL_ON;
 using Java.Util;
 using Shared;
@@ -48,7 +49,9 @@
 
             string[] permissions = new string[] { Manifest.Permission.WriteExternalStorage, Manifest.Permission.RecordAudio,
             Manifest.Permission.Camera, Manifest.Permission.ProcessOutgoingCalls, Manifest.Permission.GetAccounts};
-
+            //绂佹灞忓箷闀夸寒
+            BaseActivity.KeepScreenON = false;
+            //闅愯棌杩嫓铏氭嫙鎸夐敭
             BaseActivity.IsHideVirualButtons = true;
             init();
             BaseActivity.OnCreateActoin += (activity, application) =>
@@ -60,26 +63,33 @@
                 {
                     Language.CurrentLanguage = "Chinese";
                 }
+        
+                //鑾峰彇鏋佸厜鎺ㄩ�両D
+                GetJPushRegistrationID(activity);
 
-                BaseActivity.NetworkStateChanged += (int obj) =>
+                BaseActivity.NetworkStateChanged += (int internetStatus) =>
                 {
+                    //if (!IsEnterBackground)
+                    //{
+                    //    ////BusSocket.Stop();
+                    //    //new System.Threading.Thread(() =>
+                    //    //{
+                    //    //    System.Threading.Thread.Sleep(1000);
+                    //    //    //BusSocket.Start();
+                    //    //})
+                    //    //{ IsBackground = true }.Start();
 
-                    if (!IsEnterBackground)
-                    {
-                        BusSocket.Stop();
-                        new System.Threading.Thread(() =>
-                        {
-                            System.Threading.Thread.Sleep(1000);
-                            BusSocket.Start(6000);
-                        })
-                        { IsBackground = true }.Start();
-                    }
-                    else
-                    {
-                        Console.WriteLine("HHH 缃戠粶鍙樺寲浣嗗浜庡悗鍙�");
-                    }
+                    //}
+                    //else
+                    //{
+                    //    Console.WriteLine("HHH 缃戠粶鍙樺寲浣嗗浜庡悗鍙�");
+                    //}
 
+                    //缃戠粶鍙樺寲澶勭悊
+                    HDLCommon.Current.UpdateInternetStatus((int)internetStatus, MainPage.IsEnterBackground);
                 };
+                //寮�鍚畾浣嶆湇鍔�
+                Shared.Application.StartGPSLocationService();
             };
             BaseActivity.RefreshUIAction += (activity) =>
             {
@@ -89,36 +99,97 @@
             BaseActivity.OnResumeAction += (activity) =>
             {
                 checkSomeInfo();
-                new HDL_ON.UI.AppUnlockPage().LoadPage();
+                
             };
             BaseActivity.OnDestroyAction += (activity) =>
             {
                 Console.WriteLine("OnDestroyAction");
-                BusSocket.Stop();
-                OnAppConfig.Instance.unlockTime = DateTime.Now;
+                //BusSocket.Stop();
+                //UserInfo.Current.unlockTime = DateTime.Now;
             };
 
+       
 
             HDLUtils.SetAuthoritiesName("com.hdl.onpro.fileProvider");
 
             //Shared.Application.IsGpsEnable = true;
-
-            Shared.Application.LocationAction = (arg1, arg2) =>
+            //鑾峰彇缁忕含搴� 
+            Shared.Application.LocationAction = (lon, lat) =>
             {
-                Shared.Application.LocationAction = null;
-
-                new HDL_ON.DAL.Server.HttpServerRequest().GetCityInfo(arg1.ToString(), arg2.ToString());
-
-                MainPage.Log($"缁忕含搴�:::{arg1}:{arg2}");
-
+                try
+                {
+                    Shared.Application.LocationAction = null;
+                    new HDL_ON.DAL.Server.HttpServerRequest().GetCityInfo(lon.ToString(), lat.ToString());
+                    //鍏抽棴瀹氫綅鏈嶅姟
+                    Shared.Application.StopGPSLocationService();
+                }
+                  catch(Exception ex)
+                {
+                    Utlis.WriteLine("GetCityInfo catch"+ ex.Message);
+                }
+                MainPage.Log($"缁忕含搴�:::{lon}:{lat}");
             };
 
-
+           
         }
+
+        /// <summary>
+        /// 
+        /// </summary>
+        /// <param name="activity"></param>
+        void GetJPushRegistrationID(BaseActivity activity)
+        {
+            try
+            {
+                //淇濆瓨鑾峰彇鐨勬瀬鍏夋湇鍔″櫒涓婄殑娉ㄥ唽ID鍒版湰鍦版枃浠�
+                var tokenID = JPushInterface.GetRegistrationID(activity);
+                Console.WriteLine("RegistrationID:  " + tokenID);
+                if (!string.IsNullOrEmpty(tokenID) && OnAppConfig.Instance.PushDeviceToken != tokenID)
+                {
+                    OnAppConfig.Instance.PushDeviceToken = tokenID;
+                    OnAppConfig.Instance.PhoneName = Android.OS.Build.Manufacturer;
+                    OnAppConfig.Instance.SaveConfig();
+                }
+                int loadTokenCount = 0;
+                System.Threading.Tasks.Task.Run(() =>
+                {
+                    while (string.IsNullOrEmpty(tokenID))
+                    {
+                        System.Threading.Thread.Sleep(1000);
+                        tokenID = JPushInterface.GetRegistrationID(activity);
+                        Console.WriteLine("Sleep.tokenID + " + JPushInterface.GetRegistrationID(activity));
+                        loadTokenCount++;
+                        if (loadTokenCount > 30)
+                        {
+                            break;
+                        }
+                    }
+                    Console.WriteLine("RegistrationID:  " + tokenID);
+                    if (!string.IsNullOrEmpty(tokenID) && OnAppConfig.Instance.PushDeviceToken != tokenID)
+                    {
+                        OnAppConfig.Instance.PushDeviceToken = tokenID;
+                        OnAppConfig.Instance.PhoneName = Android.OS.Build.Manufacturer;
+                        OnAppConfig.Instance.SaveConfig();
+                    }
+                });
+
+            }
+            catch
+            {
+
+            }
+        }
+
         public static bool IsShowTip = true;
         void init()
         {
             //鎵嬫満鍚嶇О Android.OS.Build.Manufacturer;
+            //OnAppConfig.Instance.PhoneName = Android.OS.Build.Manufacturer;
+#if DEBUG
+            CN.Jpush.Android.Api.JPushInterface.SetDebugMode(true);
+#endif
+            CN.Jpush.Android.Api.JPushInterface.Init(this);
+
         }
         void checkSomeInfo()
         {
@@ -210,6 +281,8 @@
             {
                 Console.WriteLine("HHH OnActivityStarted锛歠oreground");
                 BusSocketStart();
+                //鍚庡彴鍥炲埌鍓嶅彴
+                new HDL_ON.UI.AppUnlockPage().LoadPage();
             }
         }
 
@@ -221,6 +294,9 @@
             {
                 Console.WriteLine("HHH OnActivityStopped锛� background");
                 BusSocketStop();
+                //杩涘叆鍚庡彴
+                UserInfo.Current.unlockTime = DateTime.Now;
+
             }
         }
 
@@ -233,30 +309,53 @@
 
         int mCount;
 
+        ///// <summary>
+        ///// 鏄惁杩涘叆鍚庡彴
+        ///// </summary>
+        //public bool IsEnterBackground = false;
+
         /// <summary>
-        /// 鏄惁杩涘叆鍚庡彴
+        /// 杩涘叆鍚庡彴鐨勬椂闂�
         /// </summary>
-        public bool IsEnterBackground = false;
+        DateTime CloseTime = DateTime.Now;
 
         /// <summary>
         /// BusSocketStop
         /// </summary>
         void BusSocketStop()
         {
-            IsEnterBackground = true;
-            BusSocket.Stop();
-            OnAppConfig.Instance.unlockTime = DateTime.Now;
+            //IsEnterBackground = true;
+            CloseTime = DateTime.Now;
+            MainPage.IsEnterBackground = true;
+            //杩涘叆鍚庡彴mqtt姝e湪杩炴帴閲嶇疆鐘舵��
+            HDL_ON.DAL.Mqtt.MqttClient.RemoteMqttIsConnecting = false;
+            HDL_ON.DriverLayer.UdpSocket._BusSocket.Stop();
+           
         }
-
 
         /// <summary>
         /// BusSocketStart
         /// </summary>
         void BusSocketStart()
         {
-            IsEnterBackground = false;
+            //IsEnterBackground = false;
 
-            BusSocket.Start(6000);
+            if (CloseTime.AddSeconds(10) < DateTime.Now)
+            {
+                //鍚庡彴瓒呰繃10s灏辨柇寮�MQTT閲嶈繛
+                if (HDL_ON.DriverLayer.Control.Ins.IsRemote)
+                {
+                    HDL_ON.DAL.Mqtt.MqttClient.DisConnectRemote("closeTime", false);
+                }
+            }
+
+            MainPage.IsEnterBackground = false;
+            HDL_ON.DriverLayer.UdpSocket._BusSocket.Start();
+            HDL_ON.DriverLayer.Control.Ins.SearchLoaclGateway();
         }
+
+      
+
     }
+
 }
\ No newline at end of file

--
Gitblit v1.8.0