package com.hdl.photovoltaic.ui; import android.os.Bundle; import android.os.Process; import android.os.SystemClock; import android.text.TextUtils; 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.linkpm.sdk.user.HDLLinkPMUser; 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.config.ConstantManage; import com.hdl.photovoltaic.config.UserConfigManage; import com.hdl.photovoltaic.databinding.ActivityCpowerStationBinding; import com.hdl.photovoltaic.enums.NetworkType; import com.hdl.photovoltaic.listener.CloudCallBeak; import com.hdl.photovoltaic.other.HdlDeviceLogic; import com.hdl.photovoltaic.other.HdlESLocalJsonLogic; 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.HouseIdBean; import com.hdl.photovoltaic.ui.bean.OidBean; import com.hdl.photovoltaic.uni.HDLUniMP; import com.hdl.photovoltaic.uni.HDLUniMPSDKManager; import com.hdl.photovoltaic.utils.AppManagerUtils; import com.hdl.sdk.link.HDLLinkLocalSdk; import com.hdl.sdk.link.common.event.EventListener; import com.hdl.sdk.link.core.bean.LinkResponse; import com.hdl.sdk.link.core.bean.ModbusResponse; 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.utils.mqtt.MqttRecvClient; import com.umeng.analytics.MobclickAgent; 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; /** * C端-电站界面 */ public class CPowerStationActivity extends CustomBaseActivity { private ActivityCpowerStationBinding viewBinding; private EventListener allTopicsListener; private int backPressTimes; @Override public Object getContentView() { viewBinding = ActivityCpowerStationBinding.inflate(getLayoutInflater()); return viewBinding.getRoot(); } @Override public void onBindView(Bundle savedInstanceState) { setStatusBarTranslucent(); getWindow().setNavigationBarColor(getColor(R.color.text_FF000000)); //C端启动App自动打开小程序电站详情界面 startAppAutomaticallyOpenUni(); //注册监听 this.registerAllTopicsListener(); //初始化mqtt客户端 this.initMqttClient(); //上传极光注册ID到云端 this.pushTokens(); //获取云端脚本 HdlESLocalJsonLogic.getInstance().getAllHdlESLocalJson(); } @Override protected void onResume() { super.onResume(); //启动页与mainActivity样式一样,这样启动页和mainActivity看上去是一个界面,目的是为了mainActivity遮住下一页; // 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() { startAppAutomaticallyOpenUni(false); // //低于安卓14版本 // if (android.os.Build.VERSION.SDK_INT < 34) { // startAppAutomaticallyOpenUni(false); // } else { // startAppAutomaticallyOpenUni(false); // } } }); } }).start(); } @Subscribe(threadMode = ThreadMode.MAIN) public void onEventMessage(BaseEventBus event) { if (event == null) { return; } if (TextUtils.isEmpty(event.getTopic())) { return; } //网关mqtt秘钥更新通知 if (event.getTopic().contains("/custom/mqtt/secret/change")) { String[] topics = event.getTopic().split("/"); //主题不符合规则不处理 if (topics.length < 3) { return; } int index = -1; List list = HdlDeviceLogic.getInstance().getCurrentHomeGatewayList(UserConfigManage.getInstance().getHomeId(), null); for (int i = 0; i < list.size(); i++) { GatewayBean gatewayBean = list.get(i); if (gatewayBean.getGatewayId().equals(topics[2])) { index = i; break; } } if (index > -1) { GatewayBean gatewayBean = list.get(index); HdlDeviceLogic.getInstance().getDeviceRemoteInfo(UserConfigManage.getInstance().getHomeId(), gatewayBean.getSpk(), gatewayBean.getDevice_mac(), new CloudCallBeak() { @Override public void onSuccess(DeviceRemoteInfo deviceRemoteInfo) { if (deviceRemoteInfo != null) { //更新mqtt通讯的新秘钥 gatewayBean.setAesKey(deviceRemoteInfo.getSecret()); gatewayBean.setGatewayId(deviceRemoteInfo.getGatewayId()); //用之前的库,底层mqtt订阅,加解密会用到该参数; HDLLinkConfig.getInstance().setAesKey(deviceRemoteInfo.getSecret());//设置mqtt通讯秘钥库 HDLLinkConfig.getInstance().setGatewayId(deviceRemoteInfo.getGatewayId());//设置GatewayId } } @Override public void onFailure(HDLException e) { } }); } } else if (event.getTopic().contains(HdlOtaLogic.localDownloadProgress)) { //下载云端驱动或者固件文件到本地,自己计算进度条上报到uni那边 HDLUniMP.UniCallBackBaseBean uniCallBackBaseBean = new HDLUniMP.UniCallBackBaseBean(); 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); } else if (event.getTopic().contains(ConstantManage.network_change_post)) { // String wifi_ssid = WifiUtils.getInstance().getCurrentConnectWifiSsid();//获取WiFi的ssid需要位置权限的 HdlLogLogic.print("监听网络状态---" + event.getData().toString() + "(" + event.getType() + ")", true); //第一次启动App,以及切换网络的时候更新 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() { //防止app启动的时候没有网络(app也登录不了),导致获取不了mqtt远程连接信息; initMqttClient(); HdlDeviceLogic.getInstance().getCurrentHomeLocalAndCloudGatewayList(UserConfigManage.getInstance().getHomeId(), new CloudCallBeak>() { @Override public void onSuccess(List obj) { // AppManagerUtils.getAppManager().hideLoading(); } @Override public void onFailure(HDLException e) { // AppManagerUtils.getAppManager().hideLoading(); } }); } }); } } else if (event.getTopic().contains(HDLUniMP.UNI_EVENT_REPLY_OTHER_MODEL) && event.getType().contains(HDLUniMP.UNI_EVENT_REPLY_OTHER_BACK)) { //物理按键返回事件(包括左滑移除事件) 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, null).size(); i++) { String gatewayId = HdlDeviceLogic.getInstance().getCurrentHomeGatewayList(homeId, null).get(i).getGatewayId(); //字符串是自己按规则拼接的,里面注册主题时会解析字符串,只拿getGatewayId()值; String topic = "/user/" + gatewayId + "/#"; //进去住宅详情开始订阅主题 MqttRecvClient.getInstance().checkAndsubscribeAllTopics(topic);//订阅【逆变器】消息 } String topicHome = "/user/" + homeId + "/#"; MqttRecvClient.getInstance().checkAndsubscribeAllTopics(topicHome);//订阅【电站】消息 } } /** * C端启动App自动打开小程序电站详情界面 */ private void startAppAutomaticallyOpenUni(boolean delay) { // if (delay) { // SystemClock.sleep(2000); // } if (TextUtils.isEmpty(HDLLinkPMUser.getInstance().getAccessToken())) { //其实刷新token失败已通知退出登录,数据已经清空,因为等2s uni加载慢导致请求链接的时候出现token为空 HdlLogLogic.print("返回去"); return; } UserConfigManage.getInstance().setUniBottomSafeDistanceBackgroundColor(0); List HouseIdList = HdlResidenceLogic.getInstance().getHouseIdList(); if (HouseIdList.isEmpty()) { if (TextUtils.isEmpty(UserConfigManage.getInstance().getHomeId())) { String path = HDLUniMP.UNI_EVENT_OPEN_HOME_Null_C; HdlUniLogic.getInstance().openUniMP(path, null); } else { //解决问题手机没有网自动登录进来,默认传上一次的住宅id String path = HDLUniMP.UNI_EVENT_OPEN_HOME_DETAILS_C + "?homeId=" + UserConfigManage.getInstance().getHomeId() + "&homeName=" + UserConfigManage.getInstance().getHomeName(); HdlUniLogic.getInstance().openUniMP(path, null); } } else { int select_home = 0; for (int i = 0; i < HouseIdList.size(); i++) { if (HouseIdList.get(i).getHomeId().equals(UserConfigManage.getInstance().getHomeId())) { select_home = i; break; } } HouseIdBean houseIdBean = HouseIdList.get(select_home); HdlResidenceLogic.getInstance().switchHouse(houseIdBean, false); 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(); //如果开发者调用kill或者exit之类的方法杀死进程,或者双击back键会杀死进程,请务必在此之前调用MobclickAgent.onKillProcess方法,用来保存统计数据。 MobclickAgent.onKillProcess(_mActivity); Process.killProcess(Process.myPid()); } } } @Override protected void onDestroy() { super.onDestroy(); HdlUniLogic.getInstance().checkRemoveOtherUniMPEventCallBack(); //移除监听 HDLLinkLocalSdk.getInstance().removeAllTopicsListener(allTopicsListener); } /** * 上传极光注册ID到云端 */ private void pushTokens() { String registrationId_tag = "registrationID_" + UserConfigManage.getInstance().getUserId(); String is_registrationID = HDLApp.getInstance().getKey(registrationId_tag); 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() { @Override public void onSuccess(String pushId) { if (!TextUtils.isEmpty(pushId)) { UserConfigManage.getInstance().setPushId(pushId); UserConfigManage.getInstance().Save(); } HDLApp.getInstance().setInfoMap(registrationId_tag, "true");//记录一下状态,后台杀死app会清空; HdlLogLogic.print("C端---添加极光ID到云端---registrationID:" + UserConfigManage.getInstance().getUserName() + "--->" + finalRegistrationID, true); } @Override public void onFailure(HDLException e) { HDLApp.getInstance().setInfoMap(registrationId_tag, "false");//记录一下状态,后台杀死app会清空; HdlLogLogic.print("C端---添加极光ID到云端失败---registrationID:" + UserConfigManage.getInstance().getUserName() + "--->" + finalRegistrationID, true); } }); } } }); } /** * 初始化mqtt客户端 */ public void initMqttClient() { //检查断开状态 if (!MqttRecvClient.getInstance().isConnected()) { MqttRecvClient.getInstance().reConnect(); } if (!MqttRecvClient.getInstance().isInit()) { HdlMqttLogic.getInstance().getMqttRemoteInfo(HomeType.A, new CloudCallBeak() { @Override public void onSuccess(MqttInfo info) { if (info != null) { MqttRecvClient.getInstance().setConnectParam(info.getUrl(), info.getClientId(), info.getUserName(), info.getPassWord()); MqttRecvClient.getInstance().connect(); HdlLogLogic.print("mqtt链接成功---ClientId---" + info.getClientId(), true); } } @Override public void onFailure(HDLException e) { HdlLogLogic.print("读取mqtt远程信息失败---" + e.getMessage(), e.getCode(), true); } }); } } /** * 注册所有主题数据的监听 */ private void registerAllTopicsListener() { allTopicsListener = new EventListener() { @Override public void onMessage(Object msg) { if (msg == null) { return; } if (msg instanceof ModbusResponse) { ModbusResponse response = (ModbusResponse) msg; if (response.getTopic() == null) { return; } HdlLogLogic.print("C端---监听到Modbus数据---" + new Gson().toJson(response), false); // if (response.getTopic().endsWith("custom/native/inverter/up")) { HDLUniMP.UniCallBackBaseBean uniCallBackBaseBean = new HDLUniMP.UniCallBackBaseBean(); uniCallBackBaseBean.setType(response.getTopic()); uniCallBackBaseBean.setData(response.getData()); // if (com.hdl.photovoltaic.ui.test.UniAppMqtt.getInstance().getUni()) { // try { // String t = String.format("AndroidToPC/%s/%s", System.currentTimeMillis(), HDLUniMP.UNI_EVENT_NOTIFICATION_DEVICE_MODEL); // com.hdl.photovoltaic.ui.test.UniAppMqtt.getInstance().publish(t, JSONObject.toJSON(uniCallBackBaseBean).toString()); // } catch (Exception ignored) { // } // } else { HdlUniLogic.getInstance().sendUni(HDLUniMP.UNI_EVENT_NOTIFICATION_DEVICE_MODEL, uniCallBackBaseBean); // } // } } else if (msg instanceof LinkResponse) { LinkResponse linkResponse = (LinkResponse) msg; if (linkResponse.getTopic() == null) { return; } if (linkResponse.getTopic().endsWith("/ota/device/progress/up")) { HDLUniMP.UniCallBackBaseBean uniCallBackBaseBean = new HDLUniMP.UniCallBackBaseBean(); 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); } else if (linkResponse.getTopic().endsWith("/custom/device/list/upload")) { //逆变器有新oid通知主题 if (linkResponse.getData() == null) { HdlLogLogic.print("逆变器有新oid通知--->数据为空", false); return; } try { Gson gson = new Gson(); Type typeOfT = new TypeToken>() { }.getType(); String json = gson.toJson(linkResponse.getData()); List oidList = gson.fromJson(json, typeOfT); //增量增加add HdlDeviceLogic.getInstance().updateOidAdd(UserConfigManage.getInstance().getHomeId(), oidList, null); } catch (Exception ignored) { } } else if (linkResponse.getTopic().endsWith("/app/thing/property/send")) { //设备状态变更topic:/user/${homeId}/app/thing/property/send if (linkResponse.getData() == null) { HdlLogLogic.print("设备状态变更--->数据为空", false); return; } HDLUniMP.UniCallBackBaseBean uniCallBackBaseBean = new HDLUniMP.UniCallBackBaseBean(); uniCallBackBaseBean.setType(linkResponse.getTopic()); uniCallBackBaseBean.setData(linkResponse.getData()); HdlUniLogic.getInstance().sendUni(HDLUniMP.UNI_EVENT_NOTIFICATION_DEVICE_MODEL, uniCallBackBaseBean); } } } }; HDLLinkLocalSdk.getInstance().registerAllTopicsListener(allTopicsListener); } }