From 63b0ee228bf52e8e9c4d7fc51a1117543c9a67af Mon Sep 17 00:00:00 2001 From: 刘卫锦 <lwj@hdlchina.com.cn> Date: 星期一, 03 七月 2023 19:02:40 +0800 Subject: [PATCH] Merge branch 'master' of http://172.16.1.23:6688/r/~wjc/HDLPhotovoltaicDebugAPP --- app/src/main/java/com/hdl/photovoltaic/ui/MyPowerStationActivity.java | 94 +++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 94 insertions(+), 0 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 77d9ac2..5e51376 100644 --- a/app/src/main/java/com/hdl/photovoltaic/ui/MyPowerStationActivity.java +++ b/app/src/main/java/com/hdl/photovoltaic/ui/MyPowerStationActivity.java @@ -1,19 +1,32 @@ package com.hdl.photovoltaic.ui; +import androidx.annotation.NonNull; import androidx.appcompat.content.res.AppCompatResources; +import android.Manifest; +import android.content.pm.PackageManager; import android.os.Bundle; import android.view.View; +import com.google.gson.Gson; import com.hdl.photovoltaic.R; import com.hdl.photovoltaic.base.CustomBaseActivity; import com.hdl.photovoltaic.databinding.ActivityMyPowerStationBinding; +import com.hdl.photovoltaic.other.HdlLogLogic; +import com.hdl.photovoltaic.other.HdlUniLogic; +import com.hdl.photovoltaic.uni.HDLUniMP; +import com.hdl.photovoltaic.utils.PermissionUtils; +import com.hdl.sdk.link.HDLLinkLocalSdk; +import com.hdl.sdk.link.common.event.EventListener; +import com.hdl.sdk.link.core.bean.LinkResponse; public class MyPowerStationActivity extends CustomBaseActivity { + private ActivityMyPowerStationBinding viewBinding; private int currentFragmentIndex = 0; + private EventListener allTopicsListener; @Override @@ -24,10 +37,13 @@ @Override public void onBindView(Bundle savedInstanceState) { + getWindow().setStatusBarColor(getColor(R.color.text_245EC3)); //鍒濆鍖� initView(); //鍒濆鍖栫晫闈㈢洃鍚櫒 initEvent(); + //娉ㄥ唽鐩戝惉 + registerAllTopicsListener(); } private void initEvent() { @@ -48,6 +64,14 @@ } + @Override + protected void onDestroy() { + super.onDestroy(); + HdlUniLogic.getInstance().checkRemoveOtherUniMPEventCallBack(); + //绉婚櫎鐩戝惉 + HDLLinkLocalSdk.getInstance().removeAllTopicsListener(allTopicsListener); + + } private void initView() { viewBinding.myPowerStationBottomIl1.titleTv.setText(R.string.my_power_station_鐢电珯); @@ -76,4 +100,74 @@ } } + public void requestPermissions() { + String[] ary = PermissionUtils.checkPermission(_mActivity, new String[]{Manifest.permission.ACCESS_FINE_LOCATION}); + if (ary.length > 0) { + requestPermissions(ary, PermissionUtils.STATUS_SUCCESS); + } else { + if (mPermissionsResultCallback != null) { + mPermissionsResultCallback.succeed(); + } + } + } + + @Override + public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { + super.onRequestPermissionsResult(requestCode, permissions, grantResults); + if (requestCode == PermissionUtils.STATUS_SUCCESS) { + for (int i = 0; i < permissions.length; i++) { + if (grantResults[i] == PackageManager.PERMISSION_GRANTED) { + if (mPermissionsResultCallback != null) { + mPermissionsResultCallback.succeed(); + } + } + + } + } + + } + + + private PermissionsResultCallback mPermissionsResultCallback; + + public void setPermissionsResultCallback(PermissionsResultCallback permissionsResultCallback) { + mPermissionsResultCallback = permissionsResultCallback; + } + + public interface PermissionsResultCallback { + + void succeed(); + + void failing(); + + } + + + /** + * 娉ㄥ唽鎵�鏈変富棰樻暟鎹殑鐩戝惉 + */ + private void registerAllTopicsListener() { + allTopicsListener = new EventListener() { + @Override + public void onMessage(Object msg) { + if (msg instanceof LinkResponse) { + LinkResponse response = (LinkResponse) msg; + if (response.getTopic() == null) { + return; + } + HdlLogLogic.print("鐩戝惉鍒扮殑鏁版嵁===========" + new Gson().toJson(response)); +// if (response.getTopic().endsWith("custom/native/inverter/up")) { + HDLUniMP.UniCallBackBaseBean uniCallBackBaseBean = new HDLUniMP.UniCallBackBaseBean(); + uniCallBackBaseBean.setType(response.getTopic()); + uniCallBackBaseBean.setData(response.getData()); + HdlUniLogic.getInstance().sendUni(HDLUniMP.UNI_EVENT_NOTIFICATION_DEVICE_MODEL, uniCallBackBaseBean); +// } + + } + } + }; + HDLLinkLocalSdk.getInstance().registerAllTopicsListener(allTopicsListener); + } + + } \ No newline at end of file -- Gitblit v1.8.0