From 60f74b306659cba1a8ed7378f9df54a71e48a614 Mon Sep 17 00:00:00 2001 From: hxb <hxb@hdlchina.com.cn> Date: 星期三, 28 六月 2023 18:04:09 +0800 Subject: [PATCH] 临时 --- app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java | 50 +++++++++++++++++++++++++++++++++----------------- 1 files changed, 33 insertions(+), 17 deletions(-) diff --git a/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java b/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java index b41b342..445dc0c 100644 --- a/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java +++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java @@ -3,6 +3,7 @@ import android.text.TextUtils; +import com.alibaba.fastjson.JSON; import com.google.gson.Gson; import com.hdl.photovoltaic.HDLApp; import com.hdl.photovoltaic.config.UserConfigManage; @@ -10,7 +11,12 @@ import com.hdl.photovoltaic.ui.bean.HouseIdBean; import com.hdl.photovoltaic.uni.HDLUniMP; import com.hdl.photovoltaic.uni.HDLUniMPSDKManager; +import com.hdl.photovoltaic.uni.UniToAndroidBean; import com.hdl.photovoltaic.utils.WifiUtils; +import com.hdl.sdk.link.common.exception.HDLLinkException; +import com.hdl.sdk.link.core.bean.gateway.GatewayBean; +import com.hdl.sdk.link.core.callback.GatewayCallBack; +import com.hdl.sdk.link.core.connect.HDLModBusConnect; import org.json.JSONObject; @@ -56,15 +62,11 @@ if (!HDLUniMP.UNI_APP_ID.equals(appId)) { return; } - org.json.JSONObject jsonObject = getJSONObject(data); - String type_value = ""; - if (jsonObject.has("type")) { - type_value = jsonObject.getString("type"); - } + UniToAndroidBean uniToAndroidBean = com.alibaba.fastjson.JSONObject.parseObject(JSON.toJSONString(data), UniToAndroidBean.class); if (HDLUniMP.UNI_EVENT_REPLY_HOME_MODEL.equals(event)) { //浣忓畢妯″潡 - switch (type_value) { + switch (uniToAndroidBean.getType()) { case HDLUniMP.UNI_EVENT_REPLY_HOME_CREATION: { //鍒涘缓 HdlResidenceLogic.getInstance().getResidenceIdList("", "", new CloudCallBeak<List<HouseIdBean>>() { @@ -92,22 +94,41 @@ } } else if (HDLUniMP.UNI_EVENT_REPLY_DEVICE_MODEL.equals(event)) { //璁惧妯″潡 - switch (type_value) { + switch (uniToAndroidBean.getType()) { case HDLUniMP.UNI_EVENT_REPLY_DEVICE_ADD: { //娣诲姞 } break; case HDLUniMP.UNI_EVENT_REPLY_DEVICE_LIST: { - //鑾峰彇璁惧鍒楄〃 + //缃戝叧鎼滅储 + HdlDeviceLogic.getInstance().searchGateway(new GatewayCallBack() { + @Override + public void onSuccess(List<GatewayBean> gatewayBeanList) { + HDLUniMP.UniCallBackBaseBean callBackBaseBean = new HDLUniMP.UniCallBackBaseBean(); + callBackBaseBean.setTopic(HDLUniMP.UNI_EVENT_NOTIFICATION_DEVICE_MODEL); + callBackBaseBean.setType(HDLUniMP.UNI_EVENT_NOTIFICATION_DEVICE_LIST); + callBackBaseBean.setData(gatewayBeanList); + sendUni(callBackBaseBean); + } + + + @Override + public void onError(HDLLinkException e) { + //鍙戦�佸け璐� + } + }); } break; - + case HDLUniMP.UNI_EVENT_REPLY_DEVICE_MODBUS_SEND:{ + //鍙戦�乵odbus鍗忚 + HDLModBusConnect.getInstance().Send(uniToAndroidBean.getGatewayOid(),null,); + } } } else if (HDLUniMP.UNI_EVENT_REPLY_WIFI_MODEL.equals(event)) { WifiUtils wifiUtils = new WifiUtils(HDLApp.getInstance()); //wifi妯″潡 - switch (type_value) { + switch (uniToAndroidBean.getType()) { case HDLUniMP.UNI_EVENT_REPLY_WIFI_LIST: { //鑾峰彇wifi鍒楄〃 if (callback != null) { @@ -152,15 +173,9 @@ /** * 鍘熺敓銆愪富鍔ㄣ�戝悜灏忕▼搴忓彂閫侀�氱煡浜嬩欢 * 娉ㄦ剰锛氶渶瑕佹彁鍓嶅皬绋嬪簭鍦ㄨ繍琛屾墠鍙垚鍔� - * - * @param topic 涓婚 - * @param body 闄勪欢鏁版嵁(娌℃湁鏁版嵁濉玭ull) */ - public void sendUni(String topic, String body) { + public void sendUni(HDLUniMP.UniCallBackBaseBean callBackBaseBean) { try { - HDLUniMP.UniCallBackBaseBean callBackBaseBean = new HDLUniMP.UniCallBackBaseBean(); - callBackBaseBean.setTopic(topic); - callBackBaseBean.setData(body); HDLUniMPSDKManager.getInstance().sendUniMPEvent(HDLUniMP.UNI_APP_ID, HDLUniMP.UNI_APP_ID, getJSONObject(callBackBaseBean)); } catch (Exception e) { HdlLogLogic.print("uni===鍘熺敓涓诲姩鍚戝皬绋嬪簭鍙戦�侀�氱煡浜嬩欢", e.getMessage()); @@ -255,6 +270,7 @@ return new JSONObject(); } String json = new Gson().toJson(obj); + return new JSONObject(json); } catch (Exception e) { return new JSONObject(); -- Gitblit v1.8.0