From 3ec7de773bff5582411c6f1f659d35cf8fb1734a Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期二, 16 七月 2024 15:13:51 +0800
Subject: [PATCH] Merge branch 'feature/v1.4.1'

---
 app/src/main/java/com/hdl/photovoltaic/ui/CPowerStationActivity.java |  144 ++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 109 insertions(+), 35 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 f4448d2..37f37a8 100644
--- a/app/src/main/java/com/hdl/photovoltaic/ui/CPowerStationActivity.java
+++ b/app/src/main/java/com/hdl/photovoltaic/ui/CPowerStationActivity.java
@@ -5,6 +5,7 @@
 import android.os.Process;
 import android.os.SystemClock;
 import android.text.TextUtils;
+import android.util.Log;
 
 
 import com.google.gson.Gson;
@@ -18,8 +19,10 @@
 import com.hdl.photovoltaic.config.ConstantManage;
 import com.hdl.photovoltaic.config.UserConfigManage;
 import com.hdl.photovoltaic.databinding.ActivityCpowerStationBinding;
+import com.hdl.photovoltaic.enums.LowerTagType;
 import com.hdl.photovoltaic.enums.NetworkType;
 import com.hdl.photovoltaic.listener.CloudCallBeak;
+import com.hdl.photovoltaic.other.HdlCommonLogic;
 import com.hdl.photovoltaic.other.HdlDeviceLogic;
 import com.hdl.photovoltaic.other.HdlLogLogic;
 import com.hdl.photovoltaic.other.HdlMqttLogic;
@@ -42,10 +45,14 @@
 import com.hdl.sdk.link.core.config.HDLLinkConfig;
 import com.hdl.sdk.link.core.utils.mqtt.MqttRecvClient;
 
+import org.greenrobot.eventbus.EventBus;
 import org.greenrobot.eventbus.Subscribe;
 import org.greenrobot.eventbus.ThreadMode;
 
 import java.lang.reflect.Type;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Collections;
 import java.util.List;
 
 import cn.jpush.android.api.JPushInterface;
@@ -68,6 +75,8 @@
 
     @Override
     public void onBindView(Bundle savedInstanceState) {
+        setNotificationBarBackgroundColor(CustomColor.white);
+        setStatusBarTextColor();
         //C绔惎鍔ˋpp鑷姩鎵撳紑灏忕▼搴忕數绔欒鎯呯晫闈�
         startAppAutomaticallyOpenUni();
         //娉ㄥ唽鐩戝惉
@@ -76,6 +85,34 @@
         this.initMqttClient();
         //涓婁紶鏋佸厜娉ㄥ唽ID鍒颁簯绔�
         this.pushTokens();
+    }
+
+    @Override
+    protected void onResume() {
+        super.onResume();
+        //鍚姩椤典笌mainActivity鏍峰紡涓�鏍凤紝杩欐牱鍚姩椤靛拰mainActivity鐪嬩笂鍘绘槸涓�涓晫闈紝鐩殑鏄负浜唌ainActivity閬綇涓嬩竴椤碉紱
+//        AppManagerUtils.getAppManager().finishActivity(StartActivity.class);
+//        this.portConflictDialog();
+    }
+
+    public void startAppAutomaticallyOpenUni() {
+        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)
@@ -87,7 +124,7 @@
         if (TextUtils.isEmpty(event.getTopic())) {
             return;
         }
-        //缃戝叧鏇存柊mqtt绉橀挜鏇存柊閫氱煡
+        //缃戝叧mqtt绉橀挜鏇存柊閫氱煡
         if (event.getTopic().contains("/custom/mqtt/secret/change")) {
             String[] topics = event.getTopic().split("/");
             //涓婚涓嶇鍚堣鍒欎笉澶勭悊
@@ -143,6 +180,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) {
@@ -157,44 +197,39 @@
                     }
                 });
             }
-        } else if (event.getTopic().contains(HDLUniMP.UNI_EVENT_REPLY_OTHER_MODEL)
-                && event.getType().contains(HDLUniMP.UNI_EVENT_REPLY_OTHER_BACK)) {
+        } else if (event.getTopic().contains(HDLUniMP.UNI_EVENT_REPLY_OTHER_MODEL) && event.getType().contains(HDLUniMP.UNI_EVENT_REPLY_OTHER_BACK)) {
             //鐗╃悊鎸夐敭杩斿洖浜嬩欢(鍖呮嫭宸︽粦绉婚櫎浜嬩欢)
-            if (AppManagerUtils.getAppManager().getActivitySize() <= 1) {
-                if (backPressTimes == 0) {
-                    HdlThreadLogic.toast(_mActivity, R.string.kill_app);
-                    backPressTimes = 1;
-                    new Thread() {
-                        @Override
-                        public void run() {
-                            try {
-                                Thread.sleep(2000);
-                            } catch (InterruptedException e) {
-                                e.printStackTrace();
-                            } finally {
-                                backPressTimes = 0;
-                            }
-                        }
-                    }.start();
-                    return;
-                } else {
-                    //鍏抽棴灏忕▼搴�
-                    if (null != HDLUniMPSDKManager.getInstance().getUniMP()) {
-                        HDLUniMPSDKManager.getInstance().getUniMP().closeUniMP();
-                    }
-                    AppManagerUtils.getAppManager().finishAllActivity();
-                    HDLUniMPSDKManager.getInstance().initDCUniMPSDK(HDLApp.getInstance());
-                    Process.killProcess(Process.myPid());
-                }
+            killProcessApp();
+        } else if (HDLUniMP.UNI_EVENT_REPLY_DEVICE_LIST.equals(event.getType())) {
+            if (MqttRecvClient.getInstance() != null) {
+                MqttRecvClient.getInstance().removeAllTopic();
             }
+            String homeId = event.getData().toString();
+            //杩涘幓浣忓畢璇︽儏uni璇诲彇閫嗗彉鍣ㄥ垪琛ㄦ垚鍔熷悗閫氱煡
+            for (int i = 0; i < HdlDeviceLogic.getInstance().getCurrentHomeGatewayList(homeId).size(); i++) {
+                String gatewayId = HdlDeviceLogic.getInstance().getCurrentHomeGatewayList(homeId).get(i).getGatewayId();
+                //瀛楃涓叉槸鑷繁鎸夎鍒欐嫾鎺ョ殑,閲岄潰娉ㄥ唽涓婚鏃朵細瑙f瀽瀛楃涓�,鍙嬁getGatewayId()鍊�;
+                String topic = "/user/" + gatewayId + "/#";
+                //杩涘幓浣忓畢璇︽儏寮�濮嬭闃呬富棰�
+                MqttRecvClient.getInstance().checkAndsubscribeAllTopics(topic);//璁㈤槄銆愰�嗗彉鍣ㄣ�戞秷鎭�
+
+            }
+            String topicHome = "/user/" + homeId + "/#";
+            MqttRecvClient.getInstance().checkAndsubscribeAllTopics(topicHome);//璁㈤槄銆愮數绔欍�戞秷鎭�
+
+
         }
     }
+
 
     /**
      * C绔惎鍔ˋpp鑷姩鎵撳紑灏忕▼搴忕數绔欒鎯呯晫闈�
      */
-    private void startAppAutomaticallyOpenUni() {
+    private void startAppAutomaticallyOpenUni(boolean 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;
@@ -209,13 +244,48 @@
             }
             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();
+            String path = HDLUniMP.UNI_EVENT_OPEN_HOME_DETAILS_C + "?homeId=" + houseIdBean.getHomeId() + "&homeName=" + houseIdBean.getHomeName() + "&powerStationStatus=" + houseIdBean.getPowerStationStatus();
             HdlUniLogic.getInstance().openUniMP(path, null);
         }
+    }
 
+//    /**
+//     * 鐗╃悊鎸夐敭杩斿洖浜嬩欢(鍖呮嫭宸︽粦绉婚櫎浜嬩欢)
+//     */
+//    @Override
+//    public void onBackPressed() {
+//        killProcessApp();
+//        super.onBackPressed();
+//    }
+
+    private void killProcessApp() {
+        //鐗╃悊鎸夐敭杩斿洖浜嬩欢(鍖呮嫭宸︽粦绉婚櫎浜嬩欢)
+        if (AppManagerUtils.getAppManager().getActivitySize() <= 1) {
+            if (backPressTimes == 0) {
+                HdlThreadLogic.toast(_mActivity, R.string.kill_app);
+                backPressTimes = 1;
+                new Thread() {
+                    @Override
+                    public void run() {
+                        try {
+                            Thread.sleep(2000);
+                        } catch (InterruptedException e) {
+                            e.printStackTrace();
+                        } finally {
+                            backPressTimes = 0;
+                        }
+                    }
+                }.start();
+                return;
+            } else {
+                //鍏抽棴灏忕▼搴�
+                if (null != HDLUniMPSDKManager.getInstance().getUniMP()) {
+                    HDLUniMPSDKManager.getInstance().getUniMP().closeUniMP();
+                }
+                AppManagerUtils.getAppManager().finishAllActivity();
+                Process.killProcess(Process.myPid());
+            }
+        }
     }
 
 
@@ -287,6 +357,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
@@ -374,4 +448,4 @@
     }
 
 
-}
\ No newline at end of file
+}

--
Gitblit v1.8.0