From 6002cb9371055af6d37c8581d207cf6e3d0f9a4a Mon Sep 17 00:00:00 2001 From: wjc <1243177876@qq.com> Date: 星期四, 29 六月 2023 10:33:28 +0800 Subject: [PATCH] 2023年06月29日10:33:22 --- app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java | 99 +++++++++++++++++++++++-------------------------- 1 files changed, 46 insertions(+), 53 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 f8bcb24..3179558 100644 --- a/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java +++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java @@ -3,26 +3,27 @@ import android.text.TextUtils; +import com.alibaba.fastjson.JSON; import com.google.gson.Gson; import com.hdl.photovoltaic.HDLApp; +import com.hdl.photovoltaic.bean.BaseEventBus; +import com.hdl.photovoltaic.config.ConstantManage; import com.hdl.photovoltaic.config.UserConfigManage; import com.hdl.photovoltaic.listener.CloudCallBeak; 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.HDLLinkLocalSdk; 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.callback.HDLLinkCallBack; -import com.hdl.sdk.link.core.config.HDLLinkConfig; -import com.hdl.sdk.link.gateway.HDLLinkLocalGateway; +import com.hdl.sdk.link.core.connect.HDLModBusConnect; +import org.greenrobot.eventbus.EventBus; import org.json.JSONObject; -import java.util.ArrayList; import java.util.List; import io.dcloud.feature.unimp.DCUniMPJSCallback; @@ -64,33 +65,16 @@ if (!HDLUniMP.UNI_APP_ID.equals(appId)) { return; } - org.json.JSONObject jsonObject = getJSONObject(data); - String type_value = ""; - String oid=""; - if (jsonObject.has("type")) { - type_value = jsonObject.getString("type"); - } - if (jsonObject.has("oid")) { - oid = jsonObject.getString("oid"); - } - + String type = getKeyValue("type", data); if (HDLUniMP.UNI_EVENT_REPLY_HOME_MODEL.equals(event)) { //浣忓畢妯″潡 - switch (type_value) { + switch (type) { case HDLUniMP.UNI_EVENT_REPLY_HOME_CREATION: { //鍒涘缓 - HdlResidenceLogic.getInstance().getResidenceIdList("", "", new CloudCallBeak<List<HouseIdBean>>() { - @Override - public void onSuccess(List<HouseIdBean> list) { - HdlResidenceLogic.getInstance().setHouseIdList(list); - } - - @Override - public void onFailure(Exception exception) { - - } - }); - + //EventBus浜嬩欢鍒嗗彂 + BaseEventBus baseEventBus = new BaseEventBus(); + baseEventBus.setType(ConstantManage.EVENTBUS_POST_HOME_CREATED); + EventBus.getDefault().post(baseEventBus); } break; case HDLUniMP.UNI_EVENT_REPLY_HOME_DETAILS: { @@ -104,7 +88,7 @@ } } else if (HDLUniMP.UNI_EVENT_REPLY_DEVICE_MODEL.equals(event)) { //璁惧妯″潡 - switch (type_value) { + switch (type) { case HDLUniMP.UNI_EVENT_REPLY_DEVICE_ADD: { //娣诲姞 } @@ -115,10 +99,9 @@ @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); + sendUni(HDLUniMP.UNI_EVENT_NOTIFICATION_DEVICE_MODEL, callBackBaseBean); } @@ -129,16 +112,16 @@ }); } break; - case HDLUniMP.UNI_EVENT_REPLY_DEVICE_MODBUS_SEND:{ + 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 (type) { case HDLUniMP.UNI_EVENT_REPLY_WIFI_LIST: { //鑾峰彇wifi鍒楄〃 if (callback != null) { @@ -183,10 +166,13 @@ /** * 鍘熺敓銆愪富鍔ㄣ�戝悜灏忕▼搴忓彂閫侀�氱煡浜嬩欢 * 娉ㄦ剰锛氶渶瑕佹彁鍓嶅皬绋嬪簭鍦ㄨ繍琛屾墠鍙垚鍔� + * + * @param topic 涓婚澶х被(濡�:UNI_EVENT_REPLY_HOME_MODEL) + * @param callBackBaseBean 鈥斺�� */ - public void sendUni(HDLUniMP.UniCallBackBaseBean callBackBaseBean) { + public void sendUni(String topic, HDLUniMP.UniCallBackBaseBean callBackBaseBean) { try { - HDLUniMPSDKManager.getInstance().sendUniMPEvent(HDLUniMP.UNI_APP_ID, HDLUniMP.UNI_APP_ID, getJSONObject(callBackBaseBean)); + HDLUniMPSDKManager.getInstance().sendUniMPEvent(HDLUniMP.UNI_APP_ID, topic, getJSONObject(callBackBaseBean)); } catch (Exception e) { HdlLogLogic.print("uni===鍘熺敓涓诲姩鍚戝皬绋嬪簭鍙戦�侀�氱煡浜嬩欢", e.getMessage()); } @@ -250,22 +236,6 @@ } - - /** - * 鑾峰彇uni鍙戦�佸璞� - * - * @param obj 闄勫姞鏁版嵁 - * @param code 鐘舵�佺爜 - * @param msg 缁撴灉鎻忚堪鐨勪俊鎭� - */ - private HDLUniMP.UniCallBackBaseBean getUniCallBackBaseBean(Object obj, String code, String msg) { - HDLUniMP.UniCallBackBaseBean uniCallBackBaseBean = new HDLUniMP.UniCallBackBaseBean(); - uniCallBackBaseBean.setCode(code); - uniCallBackBaseBean.setMes(msg); - uniCallBackBaseBean.setData(obj); - return uniCallBackBaseBean; - } - /** * 褰撳墠瀵硅薄杞� JSONObject * @@ -279,12 +249,35 @@ if (TextUtils.isEmpty(obj.toString())) { return new JSONObject(); } + if (obj instanceof JSONObject) { + return (JSONObject) obj; + } String json = new Gson().toJson(obj); - return new JSONObject(json); } catch (Exception e) { return new JSONObject(); } } + + + /** + * 鑾峰彇 KeyValue + * + * @param key - + * @param obj - + * @return value + */ + private String getKeyValue(String key, Object obj) { + try { + JSONObject jsonObject = this.getJSONObject(obj); + if (jsonObject.has(key)) { + return jsonObject.getString(key); + } + return ""; + } catch (Exception e) { + return ""; + } + } + } -- Gitblit v1.8.0