From fde174d256d4dced8bef6c439ec87cd888ad140b Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期三, 12 六月 2024 17:27:43 +0800
Subject: [PATCH] 2024年06月12日17:27:36

---
 app/src/main/java/com/hdl/photovoltaic/ui/CPowerStationActivity.java |   81 +++++++++++++++++++---------------------
 1 files changed, 39 insertions(+), 42 deletions(-)

diff --git a/app/src/main/java/com/hdl/photovoltaic/ui/CPowerStationActivity.java b/app/src/main/java/com/hdl/photovoltaic/ui/CPowerStationActivity.java
index 2c34460..d86dc78 100644
--- a/app/src/main/java/com/hdl/photovoltaic/ui/CPowerStationActivity.java
+++ b/app/src/main/java/com/hdl/photovoltaic/ui/CPowerStationActivity.java
@@ -5,10 +5,7 @@
 import android.os.Process;
 import android.os.SystemClock;
 import android.text.TextUtils;
-import android.util.Log;
 
-
-import androidx.annotation.Nullable;
 
 import com.google.gson.Gson;
 import com.google.gson.reflect.TypeToken;
@@ -36,8 +33,6 @@
 import com.hdl.photovoltaic.uni.HDLUniMP;
 import com.hdl.photovoltaic.uni.HDLUniMPSDKManager;
 import com.hdl.photovoltaic.utils.AppManagerUtils;
-import com.hdl.photovoltaic.widget.ConfirmationCancelDialog;
-import com.hdl.photovoltaic.widget.ConfirmationTipDialog;
 import com.hdl.sdk.link.HDLLinkLocalSdk;
 import com.hdl.sdk.link.common.event.EventListener;
 import com.hdl.sdk.link.core.bean.LinkResponse;
@@ -45,7 +40,6 @@
 import com.hdl.sdk.link.core.bean.eventbus.BaseEventBus;
 import com.hdl.sdk.link.core.bean.gateway.GatewayBean;
 import com.hdl.sdk.link.core.config.HDLLinkConfig;
-import com.hdl.sdk.link.core.connect.HDLUdpConnect;
 import com.hdl.sdk.link.core.utils.mqtt.MqttRecvClient;
 
 import org.greenrobot.eventbus.Subscribe;
@@ -87,25 +81,31 @@
     }
 
     @Override
-    protected void onCreate(@Nullable Bundle savedInstanceState) {
-        super.onCreate(savedInstanceState);
-//        setTheme(R.style.NoAnimationTheme);
-    }
-
-    @Override
     protected void onResume() {
         super.onResume();
         //鍚姩椤典笌mainActivity鏍峰紡涓�鏍凤紝杩欐牱鍚姩椤靛拰mainActivity鐪嬩笂鍘绘槸涓�涓晫闈紝鐩殑鏄负浜唌ainActivity閬綇涓嬩竴椤碉紱
 //        AppManagerUtils.getAppManager().finishActivity(StartActivity.class);
-        this.portConflictDialog();
+//        this.portConflictDialog();
     }
+
     public void startAppAutomaticallyOpenUni() {
-        //浣庝簬瀹夊崜14鐗堟湰
-        if (android.os.Build.VERSION.SDK_INT < 34) {
-            startAppAutomaticallyOpenUni(false);
-        } else {
-            startAppAutomaticallyOpenUni(true);
-        }
+        new Thread(new Runnable() {
+            @Override
+            public void run() {
+                SystemClock.sleep(10);
+                runOnUiThread(new Runnable() {
+                    @Override
+                    public void run() {
+                        //浣庝簬瀹夊崜14鐗堟湰
+                        if (android.os.Build.VERSION.SDK_INT < 34) {
+                            startAppAutomaticallyOpenUni(false);
+                        } else {
+                            startAppAutomaticallyOpenUni(true);
+                        }
+                    }
+                });
+            }
+        }).start();
     }
 
     @Subscribe(threadMode = ThreadMode.MAIN)
@@ -117,7 +117,7 @@
         if (TextUtils.isEmpty(event.getTopic())) {
             return;
         }
-        //缃戝叧鏇存柊mqtt绉橀挜鏇存柊閫氱煡
+        //缃戝叧mqtt绉橀挜鏇存柊閫氱煡
         if (event.getTopic().contains("/custom/mqtt/secret/change")) {
             String[] topics = event.getTopic().split("/");
             //涓婚涓嶇鍚堣鍒欎笉澶勭悊
@@ -173,6 +173,9 @@
                 HdlThreadLogic.runSubThread(new Runnable() {
                     @Override
                     public void run() {
+                        //闃叉app鍚姩鐨勬椂鍊欐病鏈夌綉缁�(app涔熺櫥褰曚笉浜�),瀵艰嚧鑾峰彇涓嶄簡mqtt杩滅▼杩炴帴淇℃伅;
+                        initMqttClient();
+
                         HdlDeviceLogic.getInstance().getCurrentHomeLocalAndCloudGatewayList(UserConfigManage.getInstance().getHomeId(), new CloudCallBeak<List<GatewayBean>>() {
                             @Override
                             public void onSuccess(List<GatewayBean> obj) {
@@ -199,13 +202,17 @@
      */
     private void startAppAutomaticallyOpenUni(boolean delay) {
 
-        if(delay) {
+        if (delay) {
             SystemClock.sleep(2000);
         }
         List<HouseIdBean> HouseIdList = HdlResidenceLogic.getInstance().getHouseIdList();
         if (HouseIdList.size() == 0) {
             String path = HDLUniMP.UNI_EVENT_OPEN_HOME_Null_C;
-            HdlUniLogic.getInstance().openUniMP(path, null);
+            if(delay){
+                HdlUniLogic.getInstance().openUniMPDelay(path, null);
+            }else {
+                HdlUniLogic.getInstance().openUniMP(path, null);
+            }
         } else {
             int select_home = 0;
             for (int i = 0; i < HouseIdList.size(); i++) {
@@ -217,7 +224,11 @@
             HouseIdBean houseIdBean = HouseIdList.get(select_home);
             HdlResidenceLogic.getInstance().switchHouse(houseIdBean);
             String path = HDLUniMP.UNI_EVENT_OPEN_HOME_DETAILS_C + "?homeId=" + houseIdBean.getHomeId() + "&homeName=" + houseIdBean.getHomeName() + "&powerStationStatus=" + houseIdBean.getPowerStationStatus();
-            HdlUniLogic.getInstance().openUniMP(path, null);
+            if(delay) {
+                HdlUniLogic.getInstance().openUniMPDelay(path, null);
+            }else {
+                HdlUniLogic.getInstance().openUniMP(path, null);
+            }
         }
     }
 
@@ -329,6 +340,10 @@
      * 鍒濆鍖杕qtt瀹㈡埛绔�
      */
     public void initMqttClient() {
+        //妫�鏌ユ柇寮�鐘舵��
+        if (!MqttRecvClient.getInstance().isConnected()) {
+            MqttRecvClient.getInstance().reConnect();
+        }
         if (!MqttRecvClient.getInstance().isInit()) {
             HdlMqttLogic.getInstance().getMqttRemoteInfo(HomeType.A, new CloudCallBeak<MqttInfo>() {
                 @Override
@@ -416,22 +431,4 @@
     }
 
 
-    /**
-     * 绔彛鍐茬獊
-     */
-    private void portConflictDialog() {
-        if (!HDLUdpConnect.getInstance().isBindSuccess()) {
-            ConfirmationTipDialog dialog = new ConfirmationTipDialog(_mActivity);
-            dialog.show();
-            dialog.setTitle(getString(R.string.home_account_registered_successfully));
-            dialog.setYesOnclickListener(new ConfirmationCancelDialog.onYesOnclickListener() {
-                @Override
-                public void Confirm() {
-                    finish();
-                }
-            });
-        }
-    }
-
-
-}
\ No newline at end of file
+}

--
Gitblit v1.8.0