From d859bb3fd4e10c93fbf5796957cf1a0a4a4fc281 Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期四, 04 一月 2024 15:19:30 +0800
Subject: [PATCH] 2024年01月04日15:19:24

---
 app/src/main/java/com/hdl/photovoltaic/ui/MyPowerStationActivity.java |  214 ++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 194 insertions(+), 20 deletions(-)

diff --git a/app/src/main/java/com/hdl/photovoltaic/ui/MyPowerStationActivity.java b/app/src/main/java/com/hdl/photovoltaic/ui/MyPowerStationActivity.java
index 634d792..d1f5e46 100644
--- a/app/src/main/java/com/hdl/photovoltaic/ui/MyPowerStationActivity.java
+++ b/app/src/main/java/com/hdl/photovoltaic/ui/MyPowerStationActivity.java
@@ -4,33 +4,42 @@
 import androidx.appcompat.content.res.AppCompatResources;
 
 import android.Manifest;
+import android.content.Intent;
+import android.content.IntentFilter;
 import android.content.pm.PackageManager;
 import android.os.Bundle;
 import android.os.Process;
+import android.os.SystemClock;
 import android.text.TextUtils;
 import android.view.View;
 
 import com.google.gson.Gson;
+import com.google.gson.reflect.TypeToken;
 import com.hdl.linkpm.sdk.core.exception.HDLException;
 import com.hdl.linkpm.sdk.home.type.HomeType;
 import com.hdl.photovoltaic.R;
 import com.hdl.photovoltaic.base.CustomBaseActivity;
 import com.hdl.photovoltaic.bean.MqttInfo;
+import com.hdl.photovoltaic.broadcast.NetworkChangeReceiver;
 import com.hdl.photovoltaic.config.ConstantManage;
 import com.hdl.photovoltaic.config.UserConfigManage;
 import com.hdl.photovoltaic.databinding.ActivityMyPowerStationBinding;
+import com.hdl.photovoltaic.enums.HomepageTitleTabSwitch;
+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;
 import com.hdl.photovoltaic.other.HdlOtaLogic;
+import com.hdl.photovoltaic.other.HdlResidenceLogic;
 import com.hdl.photovoltaic.other.HdlThreadLogic;
 import com.hdl.photovoltaic.other.HdlUniLogic;
 import com.hdl.photovoltaic.ui.bean.DeviceRemoteInfo;
+import com.hdl.photovoltaic.ui.bean.OidBean;
 import com.hdl.photovoltaic.uni.HDLUniMP;
 import com.hdl.photovoltaic.utils.AppManagerUtils;
 import com.hdl.photovoltaic.utils.PermissionUtils;
+import com.hdl.photovoltaic.widget.ConfirmationCancelDialog;
 import com.hdl.sdk.link.HDLLinkLocalSdk;
 import com.hdl.sdk.link.common.event.EventListener;
 import com.hdl.sdk.link.core.bean.LinkResponse;
@@ -44,8 +53,10 @@
 import org.greenrobot.eventbus.Subscribe;
 import org.greenrobot.eventbus.ThreadMode;
 
+import java.lang.reflect.Type;
 import java.util.List;
 
+import cn.jpush.android.api.JPushInterface;
 
 
 /**
@@ -60,6 +71,8 @@
 
     private int backPressTimes;
 
+    private NetworkChangeReceiver networkChangeReceiver;
+
 
     @Override
     public Object getContentView() {
@@ -71,14 +84,110 @@
     public void onBindView(Bundle savedInstanceState) {
         setNotificationBarBackgroundColor(CustomColor.blue);
         //鍒濆鍖�
-        initView();
+        this.initView();
         //鍒濆鍖栫晫闈㈢洃鍚櫒
-        initEvent();
+        this.initEvent();
         //娉ㄥ唽鐩戝惉
-        registerAllTopicsListener();
+        this.registerAllTopicsListener();
         //鍒濆鍖杕qtt瀹㈡埛绔�
-        initMqttClient();
+        this.initMqttClient();
+        //鐩戝惉缃戠粶鐘舵�佸彉鍖�
+        this.networkMonitoring();
+        //涓婁紶鏋佸厜娉ㄥ唽ID
+        this.pushTokens();
+        //鐐瑰嚮鏋佸厜閫氱煡鏍忔秷鎭繘鏉�
+        this.clickJpushNotificationMessage();
+        //閫氱煡闄愭潈
+        this.notificationSet();
 
+
+    }
+
+
+    /**
+     * 涓婁紶鏋佸厜娉ㄥ唽ID
+     */
+    private void pushTokens() {
+        HdlThreadLogic.runSubThread(new Runnable() {
+            @Override
+            public void run() {
+                String registrationID = JPushInterface.getRegistrationID(_mActivity);
+                int addCount = 0;
+                while (TextUtils.isEmpty(registrationID)) {
+                    SystemClock.sleep(1000);//1s浼戠湢
+                    registrationID = JPushInterface.getRegistrationID(_mActivity);
+                    addCount++;
+                    if (addCount > 5) {
+                        //5s瓒呮椂
+                        break;
+                    }
+                }
+                if (!TextUtils.isEmpty(registrationID)) {
+                    UserConfigManage.getInstance().setRegistrationID(registrationID);
+                    UserConfigManage.getInstance().Save();
+                    String finalRegistrationID = registrationID;
+                    HdlResidenceLogic.getInstance().pushAdd(new CloudCallBeak<String>() {
+                        @Override
+                        public void onSuccess(String pushId) {
+
+                            if (!TextUtils.isEmpty(pushId)) {
+                                UserConfigManage.getInstance().setPushId(pushId);
+                                UserConfigManage.getInstance().Save();
+                            }
+                            HdlLogLogic.print("娣诲姞鎺ㄩ�佹瀬鍏塈D--->registrationID===" + finalRegistrationID, true);
+
+                        }
+
+                        @Override
+                        public void onFailure(HDLException e) {
+                            HdlLogLogic.print("娣诲姞鎺ㄩ�佹瀬鍏塈D澶辫触--->registrationID===" + finalRegistrationID, true);
+                        }
+                    });
+
+                }
+
+
+            }
+        });
+    }
+
+    /**
+     * 寮�鍚�氱煡鏉冮檺
+     */
+    private void notificationSet() {
+        boolean isBoolean = PermissionUtils.isNotificationEnabled(_mActivity);
+        if (!isBoolean) {
+            ConfirmationCancelDialog confirmationCancelDialog = new ConfirmationCancelDialog(_mActivity);
+            confirmationCancelDialog.setTitle("鎻愮ず");
+            confirmationCancelDialog.setContent("閫氱煡鏉冮檺娌″紑鍚�,灏嗘棤娉曟敹鍒版帹閫佷俊鎭�.");
+            confirmationCancelDialog.setConfirmation("鍓嶅線璁剧疆");
+            confirmationCancelDialog.show();
+            confirmationCancelDialog.setYesOnclickListener(new ConfirmationCancelDialog.onYesOnclickListener() {
+                @Override
+                public void Confirm() {
+                    confirmationCancelDialog.dismiss();
+                    PermissionUtils.openNotificationSettings(_mActivity);
+
+                }
+            });
+            confirmationCancelDialog.setNoOnclickListener(new ConfirmationCancelDialog.onNoOnclickListener() {
+                @Override
+                public void Cancel() {
+                    confirmationCancelDialog.dismiss();
+                }
+            });
+
+        }
+    }
+
+    /**
+     * 鐩戝惉缃戠粶鐘舵�佸彉鍖�
+     */
+    private void networkMonitoring() {
+        IntentFilter intentFilter = new IntentFilter();
+        intentFilter.addAction("android.net.conn.CONNECTIVITY_CHANGE");
+        networkChangeReceiver = new NetworkChangeReceiver();
+        registerReceiver(networkChangeReceiver, intentFilter);
     }
 
     private void initEvent() {
@@ -87,7 +196,7 @@
             public void onClick(View v) {
                 currentFragmentIndex = 1;
                 bottomViewChangeOfStyle();
-                postEventBus(HdlCommonLogic.HomepageTitleTabSwitch.powerstation);
+                postEventBus(HomepageTitleTabSwitch.powerstation);
             }
         });
         viewBinding.myMessageBottomIl2.clickTv.setOnClickListener(new View.OnClickListener() {
@@ -95,7 +204,7 @@
             public void onClick(View v) {
                 currentFragmentIndex = 2;
                 bottomViewChangeOfStyle();
-                postEventBus(HdlCommonLogic.HomepageTitleTabSwitch.message);
+                postEventBus(HomepageTitleTabSwitch.message);
             }
         });
         viewBinding.myMeBottomIl3.clickTv.setOnClickListener(new View.OnClickListener() {
@@ -103,12 +212,13 @@
             public void onClick(View v) {
                 currentFragmentIndex = 3;
                 bottomViewChangeOfStyle();
-                postEventBus(HdlCommonLogic.HomepageTitleTabSwitch.me);
+                postEventBus(HomepageTitleTabSwitch.me);
             }
         });
 
 
     }
+
 
     @Override
     protected void onDestroy() {
@@ -116,11 +226,13 @@
         HdlUniLogic.getInstance().checkRemoveOtherUniMPEventCallBack();
         //绉婚櫎鐩戝惉
         HDLLinkLocalSdk.getInstance().removeAllTopicsListener(allTopicsListener);
+        //绉婚櫎鐩戝惉缃戠粶鐘舵�佸彉鍖�
+        unregisterReceiver(networkChangeReceiver);
 
     }
 
     private void initView() {
-        viewBinding.myPowerStationBottomIl1.titleTv.setText(R.string.power_station);
+        viewBinding.myPowerStationBottomIl1.titleTv.setText(R.string.power_shome_page);//
         viewBinding.myMessageBottomIl2.titleTv.setText(R.string.message);
         viewBinding.myMeBottomIl3.titleTv.setText(R.string.power_station_me);
         this.bottomViewChangeOfStyle();
@@ -166,11 +278,11 @@
      *
      * @param tabSwitch -
      */
-    private void postEventBus(HdlCommonLogic.HomepageTitleTabSwitch tabSwitch) {
+    private void postEventBus(HomepageTitleTabSwitch tabSwitch) {
         BaseEventBus baseEventBus = new BaseEventBus();
         baseEventBus.setTopic(ConstantManage.homepage_title_tab_switch);
-        baseEventBus.setType(tabSwitch + "");
-        EventBus.getDefault().post(baseEventBus);
+        baseEventBus.setType(tabSwitch.toString());
+        EventBus.getDefault().postSticky(baseEventBus);
     }
 
     public void requestPermissions() {
@@ -232,7 +344,7 @@
                     if (response.getTopic() == null) {
                         return;
                     }
-                    HdlLogLogic.print("鐩戝惉鍒扮殑鏁版嵁===" + new Gson().toJson(response), false);
+                    HdlLogLogic.print("鐩戝惉鍒癕odbus鏁版嵁--->" + new Gson().toJson(response), false);
 //                    if (response.getTopic().endsWith("custom/native/inverter/up")) {
                     HDLUniMP.UniCallBackBaseBean uniCallBackBaseBean = new HDLUniMP.UniCallBackBaseBean();
                     uniCallBackBaseBean.setType(response.getTopic());
@@ -250,12 +362,34 @@
                         uniCallBackBaseBean.setType(linkResponse.getTopic());
                         uniCallBackBaseBean.setData(linkResponse.getData());
                         HdlUniLogic.getInstance().sendUni(HDLUniMP.UNI_EVENT_REPLY_OTA_MODEL, uniCallBackBaseBean);
-                        HdlLogLogic.print( linkResponse.getTopic() +  new Gson().toJson(linkResponse.getData()), true);
+                        HdlLogLogic.print(linkResponse.getTopic() + new Gson().toJson(linkResponse.getData()), true);
+                    } else if (linkResponse.getTopic().endsWith("/custom/device/list/upload")) {
+                        //閫嗗彉鍣ㄦ湁鏂皁id閫氱煡涓婚
+                        if (linkResponse.getData() == null) {
+                            HdlLogLogic.print("閫嗗彉鍣ㄦ湁鏂皁id閫氱煡--->鏁版嵁涓虹┖", false);
+                            return;
+                        }
+                        try {
+                            Gson gson = new Gson();
+                            Type typeOfT = new TypeToken<List<OidBean>>() {
+                            }.getType();
+                            String json = gson.toJson(linkResponse.getData());
+                            List<OidBean> oidList = gson.fromJson(json, typeOfT);
+                            //澧為噺澧炲姞add
+                            HdlDeviceLogic.getInstance().updateOidAdd(UserConfigManage.getInstance().getHomeId(), oidList, null);
+                        } catch (Exception ignored) {
+                        }
+
+
                     }
                 }
             }
-        };
-        HDLLinkLocalSdk.getInstance().registerAllTopicsListener(allTopicsListener);
+        }
+
+        ;
+        HDLLinkLocalSdk.getInstance().
+
+                registerAllTopicsListener(allTopicsListener);
     }
 
     /**
@@ -272,7 +406,7 @@
 
             @Override
             public void onFailure(HDLException e) {
-                HdlLogLogic.print("璇诲彇mqtt杩滅▼淇℃伅澶辫触===" + e.getMessage(), e.getCode(), true);
+                HdlLogLogic.print("璇诲彇mqtt杩滅▼淇℃伅澶辫触--->" + e.getMessage(), e.getCode(), true);
             }
         });
     }
@@ -294,7 +428,7 @@
                 return;
             }
             int index = -1;
-            List<GatewayBean> list = HdlDeviceLogic.getInstance().getCurrentHomeGatewayList();
+            List<GatewayBean> list = HdlDeviceLogic.getInstance().getCurrentHomeGatewayList(UserConfigManage.getInstance().getHomeId());
             for (int i = 0; i < list.size(); i++) {
                 GatewayBean gatewayBean = list.get(i);
                 if (gatewayBean.getGatewayId().equals(topics[2])) {
@@ -327,13 +461,53 @@
             uniCallBackBaseBean.setType(event.getType());
             uniCallBackBaseBean.setData(event.getData());
             HdlUniLogic.getInstance().sendUni(HDLUniMP.UNI_EVENT_REPLY_OTA_MODEL, uniCallBackBaseBean);
-            HdlLogLogic.print(  event.getTopic()  + new Gson().toJson(event.getData()), true);
+            HdlLogLogic.print(event.getTopic() + new Gson().toJson(event.getData()), true);
+        } else if (event.getTopic().contains(ConstantManage.network_change_post)) {
+//            String wifi_ssid = WifiUtils.getInstance().getCurrentConnectWifiSsid();//鑾峰彇WiFi鐨剆sid闇�瑕佷綅缃潈闄愮殑
+            HdlLogLogic.print("鐩戝惉缃戠粶鐘舵��--->" + event.getData().toString() + "(" + event.getType() + ")", true);
+            //绗竴娆″惎鍔ˋpp,浠ュ強鍒囨崲缃戠粶鐨勬椂鍊欐洿鏂�
+            if (TextUtils.isEmpty(UserConfigManage.getInstance().getHomeId())) {
+                return;
+            }
+            if (!event.getType().equals(NetworkType.no_network.toString())) {
+//                AppManagerUtils.getAppManager().showLoading();
+                HdlThreadLogic.runSubThread(new Runnable() {
+                    @Override
+                    public void run() {
+                        HdlDeviceLogic.getInstance().getCurrentHomeLocalAndCloudGatewayList(UserConfigManage.getInstance().getHomeId(), new CloudCallBeak<List<GatewayBean>>() {
+                            @Override
+                            public void onSuccess(List<GatewayBean> obj) {
+//                                AppManagerUtils.getAppManager().hideLoading();
+                            }
+
+                            @Override
+                            public void onFailure(HDLException e) {
+//                                AppManagerUtils.getAppManager().hideLoading();
+                            }
+                        });
+                    }
+                });
+            }
+        }
+    }
+
+    /**
+     * 鐐瑰嚮鏋佸厜閫氱煡鏍忔秷鎭繘鏉�
+     */
+    private void clickJpushNotificationMessage() {
+        Intent intent = getIntent();
+        if (intent != null) {
+            String key = intent.getStringExtra("skip");
+            if (key != null) {
+                //瑙﹀彂娑堟伅鐐瑰嚮浜嬩欢
+                viewBinding.myMessageBottomIl2.clickTv.performClick();
+            }
         }
     }
 
 
     /**
-     * 鐐瑰嚮杩斿洖閿殑浜嬩欢
+     * 鐗╃悊鎸夐敭杩斿洖浜嬩欢
      */
     @Override
     public void onBackPressed() {

--
Gitblit v1.8.0