From dbff6d6f9200417ea60e2fe507b79cbe2eb7ea32 Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期四, 11 一月 2024 18:19:48 +0800
Subject: [PATCH] 2024年01月11日18:19:42

---
 app/src/main/java/com/hdl/photovoltaic/ui/MyPowerStationActivity.java |  287 ++++++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 224 insertions(+), 63 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 46cba3f..b1b4e18 100644
--- a/app/src/main/java/com/hdl/photovoltaic/ui/MyPowerStationActivity.java
+++ b/app/src/main/java/com/hdl/photovoltaic/ui/MyPowerStationActivity.java
@@ -4,36 +4,44 @@
 import androidx.appcompat.content.res.AppCompatResources;
 
 import android.Manifest;
-import android.content.IntentFilter;
+import android.content.Context;
+import android.content.Intent;
 import android.content.pm.PackageManager;
+import android.location.LocationManager;
 import android.os.Bundle;
 import android.os.Process;
+import android.os.SystemClock;
+import android.provider.Settings;
 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.HDLApp;
 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;
@@ -47,7 +55,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;
 
 
 /**
@@ -59,11 +70,7 @@
     private ActivityMyPowerStationBinding viewBinding;
     private int currentFragmentIndex = 1;
     private EventListener allTopicsListener;
-
     private int backPressTimes;
-
-    private NetworkChangeReceiver networkChangeReceiver;
-
 
     @Override
     public Object getContentView() {
@@ -82,32 +89,101 @@
         this.registerAllTopicsListener();
         //鍒濆鍖杕qtt瀹㈡埛绔�
         this.initMqttClient();
-        //鐩戝惉缃戠粶鐘舵�佸彉鍖�
-        this.networkMonitoring();
+        //涓婁紶鏋佸厜娉ㄥ唽ID鍒颁簯绔�
+        this.pushTokens();
+        //鐐瑰嚮鏋佸厜閫氱煡鏍忔秷鎭繘鏉�
+        this.clickJpushNotificationMessage();
+        //閫氱煡闄愭潈
+        this.notificationSet();
+        //鍒濆鍖栨潈闄�
+        this.requestPermissions();
 
-//        HdlOtaLogic.getInstance().startLocalService(new ServiceConnection() {
-//            @Override
-//            public void onServiceConnected(ComponentName name, IBinder service) {
-//
-//            }
-//
-//            @Override
-//            public void onServiceDisconnected(ComponentName name) {
-//
-//            }
-//        });
+    }
 
+
+    /**
+     * 涓婁紶鏋佸厜娉ㄥ唽ID鍒颁簯绔�
+     */
+    private void pushTokens() {
+        String is_registrationID = HDLApp.getInstance().getKey("registrationID");
+        if (is_registrationID.equals("true")) {
+            //涓婅繃灏辨病鏈夊繀瑕佸湪涓婁紶鍟�
+            return;
+        }
+
+        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();
+                            }
+                            HDLApp.getInstance().setInfoMap("registrationID", "true");//璁板綍涓�涓嬬姸鎬�,鍚庡彴鏉�姝籥pp浼氭竻绌�;
+                            HdlLogLogic.print("娣诲姞鏋佸厜ID鍒颁簯绔�--->registrationID:" + finalRegistrationID, true);
+
+                        }
+
+                        @Override
+                        public void onFailure(HDLException e) {
+                            HdlLogLogic.print("娣诲姞鏋佸厜ID鍒颁簯绔け璐�--->registrationID:" + finalRegistrationID, true);
+                        }
+                    });
+
+                }
+
+
+            }
+        });
     }
 
     /**
-     * 鐩戝惉缃戠粶鐘舵�佸彉鍖�
+     * 寮�鍚�氱煡鏉冮檺
      */
-    private void networkMonitoring() {
-        IntentFilter intentFilter = new IntentFilter();
-        intentFilter.addAction("android.net.conn.CONNECTIVITY_CHANGE");
-        networkChangeReceiver = new NetworkChangeReceiver();
-        registerReceiver(networkChangeReceiver, intentFilter);
+    private void notificationSet() {
+        boolean isBoolean = PermissionUtils.isNotificationEnabled(_mActivity);
+        if (!isBoolean) {
+            ConfirmationCancelDialog confirmationCancelDialog = new ConfirmationCancelDialog(_mActivity);
+            confirmationCancelDialog.setTitle(getString(R.string.loading_title_tip));
+            confirmationCancelDialog.setContent(getString(R.string.no_permissions_unable_to_receive_push));
+            confirmationCancelDialog.setConfirmation(getString(R.string.go_to_settings));
+            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 initEvent() {
         viewBinding.myPowerStationBottomIl1.clickTv.setOnClickListener(new View.OnClickListener() {
@@ -115,7 +191,7 @@
             public void onClick(View v) {
                 currentFragmentIndex = 1;
                 bottomViewChangeOfStyle();
-                postEventBus(HdlCommonLogic.HomepageTitleTabSwitch.powerstation);
+                postEventBus(HomepageTitleTabSwitch.powerstation);
             }
         });
         viewBinding.myMessageBottomIl2.clickTv.setOnClickListener(new View.OnClickListener() {
@@ -123,7 +199,7 @@
             public void onClick(View v) {
                 currentFragmentIndex = 2;
                 bottomViewChangeOfStyle();
-                postEventBus(HdlCommonLogic.HomepageTitleTabSwitch.message);
+                postEventBus(HomepageTitleTabSwitch.message);
             }
         });
         viewBinding.myMeBottomIl3.clickTv.setOnClickListener(new View.OnClickListener() {
@@ -131,12 +207,13 @@
             public void onClick(View v) {
                 currentFragmentIndex = 3;
                 bottomViewChangeOfStyle();
-                postEventBus(HdlCommonLogic.HomepageTitleTabSwitch.me);
+                postEventBus(HomepageTitleTabSwitch.me);
             }
         });
 
 
     }
+
 
     @Override
     protected void onDestroy() {
@@ -144,13 +221,10 @@
         HdlUniLogic.getInstance().checkRemoveOtherUniMPEventCallBack();
         //绉婚櫎鐩戝惉
         HDLLinkLocalSdk.getInstance().removeAllTopicsListener(allTopicsListener);
-        //绉婚櫎鐩戝惉缃戠粶鐘舵�佸彉鍖�
-        unregisterReceiver(networkChangeReceiver);
-
     }
 
     private void initView() {
-        viewBinding.myPowerStationBottomIl1.titleTv.setText("棣栭〉");//
+        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();
@@ -196,21 +270,22 @@
      *
      * @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() {
-        String[] ary = PermissionUtils.checkPermission(_mActivity, new String[]{Manifest.permission.ACCESS_FINE_LOCATION});
+        //Manifest.permission.ACCESS_COARSE_LOCATION
+        //ACCESS_FINE_LOCATION	鍏佽浣跨敤GPS瀹氫綅
+        //ACCESS_COARSE_LOCATION	鍏佽浣跨敤WIFI鐑偣鎴栧熀绔欐潵鑾峰彇绮楃暐鐨勫畾浣�
+        String[] ary = PermissionUtils.checkPermission(_mActivity, new String[]{Manifest.permission.ACCESS_FINE_LOCATION, Manifest.permission.ACCESS_COARSE_LOCATION});
         if (ary.length > 0) {
-            requestPermissions(ary, PermissionUtils.STATUS_SUCCESS);
+            this.requestPermissions(ary, PermissionUtils.STATUS_SUCCESS);
         } else {
-            if (mPermissionsResultCallback != null) {
-                mPermissionsResultCallback.succeed();
-            }
+            locationUpdates();
         }
     }
 
@@ -220,28 +295,17 @@
         if (requestCode == PermissionUtils.STATUS_SUCCESS) {
             for (int i = 0; i < permissions.length; i++) {
                 if (grantResults[i] == PackageManager.PERMISSION_GRANTED) {
-                    if (mPermissionsResultCallback != null) {
-                        mPermissionsResultCallback.succeed();
+                    switch (permissions[i]) {
+                        case Manifest.permission.ACCESS_FINE_LOCATION: {
+                            locationUpdates();
+                        }
+                        break;
                     }
+
                 }
 
             }
         }
-
-    }
-
-
-    private PermissionsResultCallback mPermissionsResultCallback;
-
-    public void setPermissionsResultCallback(PermissionsResultCallback permissionsResultCallback) {
-        mPermissionsResultCallback = permissionsResultCallback;
-    }
-
-    public interface PermissionsResultCallback {
-
-        void succeed();
-
-        void failing();
 
     }
 
@@ -262,7 +326,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());
@@ -281,6 +345,24 @@
                         uniCallBackBaseBean.setData(linkResponse.getData());
                         HdlUniLogic.getInstance().sendUni(HDLUniMP.UNI_EVENT_REPLY_OTA_MODEL, uniCallBackBaseBean);
                         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) {
+                        }
+
+
                     }
                 }
             }
@@ -302,7 +384,7 @@
 
             @Override
             public void onFailure(HDLException e) {
-                HdlLogLogic.print("璇诲彇mqtt杩滅▼淇℃伅澶辫触===" + e.getMessage(), e.getCode(), true);
+                HdlLogLogic.print("璇诲彇mqtt杩滅▼淇℃伅澶辫触--->" + e.getMessage(), e.getCode(), true);
             }
         });
     }
@@ -324,7 +406,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])) {
@@ -374,7 +456,6 @@
                             @Override
                             public void onSuccess(List<GatewayBean> obj) {
 //                                AppManagerUtils.getAppManager().hideLoading();
-
                             }
 
                             @Override
@@ -388,9 +469,23 @@
         }
     }
 
+    /**
+     * 鐐瑰嚮鏋佸厜閫氱煡鏍忔秷鎭繘鏉�
+     */
+    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() {
@@ -420,4 +515,70 @@
     }
 
 
+    /**
+     * 鍒濆鍖栥�愬紑鍚畾浣嶃�戝拰銆愪綅缃俊鎭�戞潈闄�
+     */
+    private void locationUpdates() {
+        // 鍒濆鍖朙ocationManager瀵硅薄
+        LocationManager locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE);
+        // 鍒ゆ柇璁惧鏄惁鏀寔瀹氫綅鍔熻兘
+        if (!locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER)) {
+            // 鎻愮ず鐢ㄦ埛鎵撳紑瀹氫綅鍔熻兘鎴栬�呭紩瀵肩敤鎴峰幓绯荤粺璁剧疆椤甸潰鎵撳紑瀹氫綅鍔熻兘
+            ConfirmationCancelDialog confirmationCancelDialog = new ConfirmationCancelDialog(_mActivity);
+            confirmationCancelDialog.setTitle(getString(R.string.loading_title_tip));
+            confirmationCancelDialog.setContent(getString(R.string.system_positioning_switch));
+            confirmationCancelDialog.setConfirmation(getString(R.string.go_to_settings));
+            confirmationCancelDialog.show();
+            confirmationCancelDialog.setYesOnclickListener(new ConfirmationCancelDialog.onYesOnclickListener() {
+                @Override
+                public void Confirm() {
+                    confirmationCancelDialog.dismiss();
+                    Intent intent = new Intent(Settings.ACTION_LOCATION_SOURCE_SETTINGS);
+                    intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
+                    HDLApp.getInstance().startActivity(intent);
+
+                }
+            });
+            confirmationCancelDialog.setNoOnclickListener(new ConfirmationCancelDialog.onNoOnclickListener() {
+                @Override
+                public void Cancel() {
+                    confirmationCancelDialog.dismiss();
+                }
+            });
+
+        } else {
+//            //INTERNET	鍏佽浣跨敤缃戠粶
+//            //ACCESS_FINE_LOCATION	鍏佽浣跨敤GPS瀹氫綅
+//            //ACCESS_COARSE_LOCATION	鍏佽浣跨敤WIFI鐑偣鎴栧熀绔欐潵鑾峰彇绮楃暐鐨勫畾浣�
+//            if (ActivityCompat.checkSelfPermission(_mActivity, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED && ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
+//                // TODO: Consider calling
+//                //    ActivityCompat#requestPermissions
+//                // here to request the missing permissions, and then overriding
+//                //   public void onRequestPermissionsResult(int requestCode, String[] permissions,
+//                //                                          int[] grantResults)
+//                // to handle the case where the user grants the permission. See the documentation
+//                // for ActivityCompat#requestPermissions for more details.
+//                return;
+//            }
+//            HdlLogLogic.print("寮�濮嬬含搴︾粡搴�--->", true);
+//            Location location = locationManager.getLastKnownLocation(LocationManager.GPS_PROVIDER);
+//
+//            //寤鸿杩欎釜 minTime 涓嶅皬浜� 60000锛屽嵆 1 鍒嗛挓锛岃繖鏍蜂細鏇村姞楂樻晥鑰屼笖鐪佺數
+//            locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 0, 0, new LocationListener() {
+//                @Override
+//                public void onLocationChanged(@NonNull Location location) {
+//                    // 褰撲綅缃彂鐢熷彉鍖栨椂璋冪敤姝ゆ柟娉�
+//                    double latitude = location.getLatitude();   // 鑾峰彇绾害
+//                    double longitude = location.getLongitude(); // 鑾峰彇缁忓害
+//
+//                    HdlLogLogic.print("绾害--->" + latitude, true);
+//                    HdlLogLogic.print("缁忓害--->" + longitude, true);
+//                }
+//            });
+        }
+
+
+    }
+
+
 }
\ No newline at end of file

--
Gitblit v1.8.0