From b8209d15d915f72d9abe3a68b76e1f4cfd21eac3 Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期六, 23 九月 2023 14:37:00 +0800
Subject: [PATCH] 2023年09月23日14:36:51

---
 app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java |   65 ++++++++++++++++++++++----------
 1 files changed, 44 insertions(+), 21 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 67b6bcd..5837237 100644
--- a/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java
+++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java
@@ -1,26 +1,23 @@
 package com.hdl.photovoltaic.other;
 
 
-import android.content.Intent;
 import android.text.TextUtils;
 
-import com.alibaba.fastjson.JSON;
 import com.google.gson.Gson;
+import com.hdl.linkpm.sdk.core.exception.HDLException;
 import com.hdl.photovoltaic.HDLApp;
 import com.hdl.photovoltaic.bean.BaseEventBus;
 import com.hdl.photovoltaic.bean.ModBusBean;
 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.listener.LinkCallBack;
 import com.hdl.photovoltaic.ui.bean.OidBean;
 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.HDLLinkCode;
 import com.hdl.sdk.link.common.exception.HDLLinkException;
-import com.hdl.sdk.link.common.utils.LogUtils;
 import com.hdl.sdk.link.core.bean.gateway.GatewayBean;
 import com.hdl.sdk.link.core.callback.GatewayCallBack;
 import com.hdl.sdk.link.core.callback.ModbusCallBack;
@@ -101,11 +98,10 @@
                     case HDLUniMP.UNI_EVENT_REPLY_DEVICE_ADD: {
                         //娣诲姞璁惧鍒颁簯绔�
                         String mac = getKeyValue("mac", getKeyValue("data", data));
-
-                        HdlDeviceLogic.getInstance().steGatewayParam(mac, new CloudCallBeak<Boolean>() {
+                        HdlDeviceLogic.getInstance().steGatewayParam(mac, new LinkCallBack<Boolean>() {
                             @Override
                             public void onSuccess(Boolean obj) {
-                                HdlDeviceLogic.getInstance().editGatewayParam(mac, new CloudCallBeak<Boolean>() {
+                                HdlDeviceLogic.getInstance().editGatewayParam(mac, new LinkCallBack<Boolean>() {
                                     @Override
                                     public void onSuccess(Boolean obj) {
                                         GatewayBean gatewayBean = HDLLinkLocalGateway.getInstance().getLocalGateway(mac);
@@ -125,29 +121,29 @@
                                                     }
 
                                                     @Override
-                                                    public void onFailure(Exception exception) {
-                                                        uniCallbackData(null, -100, exception.getMessage(), callback);
+                                                    public void onFailure(HDLException e) {
+                                                        uniCallbackData(null, -100, e.getMessage(), callback);
                                                     }
                                                 });
                                     }
 
                                     @Override
-                                    public void onFailure(Exception exception) {
-                                        uniCallbackData(null, -100, exception.getMessage(), callback);
+                                    public void onError(HDLLinkException e) {
+                                        uniCallbackData(null, -100, e.getMessage(), callback);
                                     }
                                 });
                             }
 
                             @Override
-                            public void onFailure(Exception exception) {
-                                uniCallbackData(null, -100, exception.getMessage(), callback);
+                            public void onError(HDLLinkException e) {
+                                uniCallbackData(null, -100, e.getMessage(), callback);
                             }
                         });
 
 
                     }
                     break;
-                    case HDLUniMP.UNI_EVENT_REPLY_DEVICE_LIST: {
+                    case HDLUniMP.UNI_EVENT_REPLY_DEVICE_NET_LIST: {
                         //缃戝叧鎼滅储
                         HdlDeviceLogic.getInstance().searchGateway(new GatewayCallBack() {
                             @Override
@@ -163,14 +159,34 @@
                         });
                     }
                     break;
+                    case HDLUniMP.UNI_EVENT_REPLY_DEVICE_LIST: {
+                        //鑾峰彇缃戝叧璁惧鍒楄〃
+                        HdlDeviceLogic.getInstance().getLocalGatewayList(new CloudCallBeak<Boolean>() {
+                            @Override
+                            public void onSuccess(Boolean obj) {
+                                if (callback != null) {
+                                    uniCallbackData(HDLLinkLocalGateway.getInstance().getGatewayList(), callback);
+                                }
+                            }
+
+                            @Override
+                            public void onFailure(HDLException e) {
+                                if (callback != null) {
+                                    uniCallbackData(null, -2, e.getMessage(), callback);
+                                }
+                            }
+                        });
+                    }
+                    break;
                     case HDLUniMP.UNI_EVENT_REPLY_DEVICE_MODBUS_SEND: {
                         sendModBus(data, callback);
+
                     }
                     case HDLUniMP.UNI_EVENT_REPLY_DEVICE_OID: {
                         //娣诲姞璁惧鍒颁簯绔�
                         String mac = getKeyValue("mac", getKeyValue("data", data));
                         //鑾峰彇oid鍒楄〃
-                        HdlDeviceLogic.getInstance().getGatewayOidList(mac, new CloudCallBeak<List<OidBean>>() {
+                        HdlDeviceLogic.getInstance().getGatewayOidList(mac, new LinkCallBack<List<OidBean>>() {
                             @Override
                             public void onSuccess(List<OidBean> list) {
                                 if (callback != null) {
@@ -179,7 +195,7 @@
                             }
 
                             @Override
-                            public void onFailure(Exception e) {
+                            public void onError(HDLLinkException e) {
                                 uniCallbackData(null, -2, e.getMessage(), callback);
                             }
                         });
@@ -226,16 +242,23 @@
      */
     void sendModBus(Object data, DCUniMPJSCallback callback) {
         String tempData = getKeyValue("data", data);
-        if (tempData == null) {
-            LogUtils.i("data鍐呭涓虹┖");
+        if (TextUtils.isEmpty(tempData)) {
+            HdlLogLogic.print("data鍐呭涓虹┖");
             return;
         }
-        ModBusBean modBusBean = com.alibaba.fastjson.JSONObject.parseObject(JSON.toJSONString(tempData), ModBusBean.class);
+        ModBusBean modBusBean = new Gson().fromJson(tempData, ModBusBean.class);
+//        ModBusBean modBusBean = new ModBusBean();
+//        modBusBean.setOid("0101050219D44A00");
+//        modBusBean.setData(new byte[]{00,01,00,00,00,0x09,00,00,00,01,03,00,00,00,01});
+        if (TextUtils.isEmpty(modBusBean.getOid())) {
+            modBusBean.setOid("010105021775E400");
+        }
         if (modBusBean.getOid() == null || modBusBean.getData() == null) {
-            LogUtils.i("鍐呭涓虹┖,oid=" + modBusBean.getOid() + " data=" + modBusBean.getData());
+            HdlLogLogic.print("鍐呭涓虹┖,oid=" + modBusBean.getOid() + " data=" + modBusBean.getData());
             return;
         }
 
+
         //鍙戦�乵odbus鍗忚
         HDLModBusConnect.getInstance().Send(modBusBean.getOid(), modBusBean.getData(), new ModbusCallBack() {
             @Override

--
Gitblit v1.8.0