From 43e38e768360ac8ced4f31fb4a423f2badda5587 Mon Sep 17 00:00:00 2001
From: JLChen <551775569@qq.com>
Date: 星期一, 13 十二月 2021 15:49:05 +0800
Subject: [PATCH] 2021-12-13 1.优化udp发送

---
 HDLSDK/app/src/main/java/com/hdl/hdlsdk/MainActivity.java |  121 +++++++++++++++++++++++++++++----------
 1 files changed, 89 insertions(+), 32 deletions(-)

diff --git a/HDLSDK/app/src/main/java/com/hdl/hdlsdk/MainActivity.java b/HDLSDK/app/src/main/java/com/hdl/hdlsdk/MainActivity.java
index a175c06..2033551 100644
--- a/HDLSDK/app/src/main/java/com/hdl/hdlsdk/MainActivity.java
+++ b/HDLSDK/app/src/main/java/com/hdl/hdlsdk/MainActivity.java
@@ -106,6 +106,8 @@
         beans.add(new DemoBean("璁惧鍔熻兘鍒楄〃"));
         beans.add(new DemoBean("UDP鍙戦��"));
         beans.add(new DemoBean("TCP鍙戦��"));
+        beans.add(new DemoBean("UDP鍙戦�侊紝鐩戝惉涓婚鍥炲锛屽甫閲嶅彂甯﹀洖璋�"));
+        beans.add(new DemoBean("TCP鍙戦�侊紝鐩戝惉涓婚鍥炲锛屽甫閲嶅彂甯﹀洖璋�"));
         demoAdapter = new DemoAdapter(beans);
         rv.setAdapter(demoAdapter);
 
@@ -129,12 +131,12 @@
                         searchGatewayBroadcast();
                         break;
                     case 2:
-                       //鑾峰彇鍔熻兘鍒楄〃
+                        //鑾峰彇鍔熻兘鍒楄〃
                         getFunctionList();
                         break;
                     case 3:
                         //鍔熻兘灞炴�ц鍙�
-                       getFunctionAttribute();
+                        getFunctionAttribute();
                         break;
                     case 4:
                         //璁惧鎺у埗
@@ -164,11 +166,18 @@
                         //TCP鍙戦��
                         tcpSend();
                         break;
+                    case 11:
+                        //UDP鍙戦�侊紝鐩戝惉涓婚鍥炲锛屽甫閲嶅彂甯﹀洖璋�
+                        udpSendWithCallback();
+                        break;
+                    case 12:
+                        //TCP鍙戦�侊紝鐩戝惉涓婚鍥炲锛屽甫閲嶅彂甯﹀洖璋�
+                        tcpSendWithCallback();
+                        break;
                 }
             }
         });
     }
-
 
 
     public void showToast(String text) {
@@ -178,9 +187,9 @@
     /**
      * 妫�娴嬫槸鍚﹁璇佽繃
      */
-    void checkIfCertified(){
+    void checkIfCertified() {
         boolean isCertified = HDLLink.getInstance().checkIfCertified();
-        String mes = isCertified?"宸茬粡璁よ瘉杩�":"鏈璇�";
+        String mes = isCertified ? "宸茬粡璁よ瘉杩�" : "鏈璇�";
         showToast(mes);
         tv.setText(mes);
     }
@@ -188,11 +197,11 @@
     /**
      * 娉ㄥ唽鎵�鏈変富棰樻暟鎹殑鐩戝惉
      */
-    void registerAllTopicsListener(){
+    void registerAllTopicsListener() {
         allTopicsListener = new EventListener() {
             @Override
             public void onMessage(Object msg) {
-                LinkResponse response = (LinkResponse)msg;
+                LinkResponse response = (LinkResponse) msg;
             }
         };
         HDLLink.getInstance().registerAllTopicsListener(allTopicsListener);
@@ -200,20 +209,21 @@
 
     /**
      * 澶勭悊鏀跺埌鐨勪富棰�
+     *
      * @param response
      */
-    private void handleLinkResponse(LinkResponse response){
+    private void handleLinkResponse(LinkResponse response) {
         //缃戝叧鎼滅储鍥炲
-        if(response.getTopic().contains("/user/all/custom/gateway/search_reply")){
+        if (response.getTopic().contains("/user/all/custom/gateway/search_reply")) {
             String data = response.getData();
             if (!TextUtils.isEmpty(data)) {
-                Log.i("handleLinkResponse", "data:"+data);
+                Log.i("handleLinkResponse", "data:" + data);
                 final BaseLocalResponse<GatewaySearchBean> bean = GsonConvert.getGson().fromJson(data, new TypeToken<BaseLocalResponse<GatewaySearchBean>>() {
                 }.getType());
                 GatewaySearchBean searchBean = bean.getObjects();
-                Log.i("handleLinkResponse", "GatewaySearchBean: "+searchBean.getGatewayId());
+                Log.i("handleLinkResponse", "GatewaySearchBean: " + searchBean.getGatewayId());
             }
-        }else{
+        } else {
             //鍏跺畠涓婚
 
         }
@@ -236,14 +246,14 @@
     /**
      * 绉婚櫎鎵�鏈変富棰樻暟鎹殑鐩戝惉
      */
-    void removeAllTopicsListener(){
+    void removeAllTopicsListener() {
         HDLLink.getInstance().removeAllTopicsListener(allTopicsListener);
     }
 
     /**
      * 鍏ョ綉璁よ瘉
      */
-    void sendAuthenticateRequest(){
+    void sendAuthenticateRequest() {
         tv.setText("寮�濮嬪叆缃戣璇�...");
         //璁よ瘉鎻愪氦鍙傛暟鍑嗗
 
@@ -330,7 +340,7 @@
      * 濡傛灉宸茬粡璁よ瘉鍚庯紝鎼滅储鎸囧畾缃戝叧鏄惁鍦ㄧ嚎
      * 骞挎挱鎼滅储璁よ瘉杩囩殑缃戝叧鏄惁鍦ㄧ嚎
      */
-    void searchGatewayBroadcast(){
+    void searchGatewayBroadcast() {
         tv.setText("鎼滅储缃戝叧涓�...");
         HDLLink.getInstance().searchGatewayBroadcast(new HDLAuthSocket.SearchGatewayCallBack() {
             @Override
@@ -338,10 +348,11 @@
                 tv.setText("缃戝叧涓嶅湪绾�");
                 responseTv.setText(e.getMsg());
             }
+
             @Override
             public void onSuccess(GatewaySearchBean gatewaySearchBean) {
                 tv.setText("缃戝叧鍦ㄧ嚎");
-                responseTv.setText("鎼滅储鎴愬姛 缃戝叧id锛�"+gatewaySearchBean.getGatewayId());
+                responseTv.setText("鎼滅储鎴愬姛 缃戝叧id锛�" + gatewaySearchBean.getGatewayId());
 //                                LogUtils.i("TAG", "onSuccess: 鎼滅储鎴愬姛锛�"+gatewaySearchBean.getGatewayId());
             }
         });
@@ -350,7 +361,7 @@
     /**
      * 鑾峰彇鍔熻兘鍒楄〃
      */
-    void getFunctionList(){
+    void getFunctionList() {
         tv.setText("鑾峰彇鍔熻兘鍒楄〃涓�...");
         responseTv.setText("");
         HDLLink.getInstance().getFunctionList(new HDLLinkCallBack() {
@@ -371,7 +382,7 @@
      * 鍔熻兘灞炴�ц鍙�
      * 鏀寔鎵归噺璇诲彇
      */
-    void getFunctionAttribute(){
+    void getFunctionAttribute() {
         tv.setText("鍔熻兘灞炴�ц鍙�");
         List<String> sids = new ArrayList<>();
         sids.add(testLightSid);
@@ -392,7 +403,7 @@
      * 璇诲彇璁惧鐘舵��
      * 鏀寔鎵归噺璇诲彇
      */
-    void propertyRead(){
+    void propertyRead() {
         tv.setText("璇诲彇鐘舵�佷腑...");
         List<String> list = new ArrayList<>();
         list.add(testLightSid);//瑕佽鍙栬澶囩殑sid
@@ -402,6 +413,7 @@
                 tv.setText("璇诲彇鎴愬姛");
                 responseTv.setText(data);
             }
+
             @Override
             public void onError(HDLLinkException e) {
                 tv.setText("璇诲彇澶辫触");
@@ -414,14 +426,14 @@
      * 鎺у埗澶辫触
      * 鍥炲鍝嶅簲code涓�200 浠h〃鎵ц鎴愬姛
      */
-    void controlDecide(){
+    void controlDecide() {
         tv.setText("鎺у埗璁惧");
         isOn = !isOn;
         List<DeviceControlRequest> requestList = new ArrayList<>();
         DeviceControlRequest request = new DeviceControlRequest();
         request.setSid(testLightSid);
-        List<DeviceControlRequest.StatusBean>  statusBeanList= new ArrayList<>();
-        DeviceControlRequest.StatusBean bean =  new DeviceControlRequest.StatusBean();
+        List<DeviceControlRequest.StatusBean> statusBeanList = new ArrayList<>();
+        DeviceControlRequest.StatusBean bean = new DeviceControlRequest.StatusBean();
         bean.setKey("on_off");
         bean.setValue(isOn ? "on" : "off");
         statusBeanList.add(bean);
@@ -443,7 +455,7 @@
     /**
      * 鑾峰彇鍦烘櫙鍒楄〃
      */
-    void getSceneList(){
+    void getSceneList() {
         tv.setText("璇诲彇鍦烘櫙鍒楄〃");
         HDLLink.getInstance().getSceneList(new HDLLinkCallBack() {
             @Override
@@ -460,21 +472,22 @@
 
     //鍦烘櫙鍒楄〃
     // {"id":"8a5eaa143ce943b987b577df5a66759b","time_stamp":"1637040217235","objects":[{"sid":"04010560D2C7170A0A0100000000","name":"鍥炲妯″紡","status":"off","group":"255","delay":"0","modify_time":"1634871490"},{"sid":"04010560D2C76E0A0A0100010000","name":"绂诲妯″紡","status":"off","group":"255","delay":"0","modify_time":"1634785823"}]}
+
     /**
      * 鎺у埗鍦烘櫙
      * 鎵ц鎴愬姛鐨勮瘽 鍝嶅簲code涓�200
      */
-    void controlScene(){
+    void controlScene() {
         tv.setText("鍦烘櫙鎺у埗");
         //鎺у埗鍦烘櫙sid鍒楄〃锛屾敮鎸佹壒閲忔帶鍒�
         List<String> sids = new ArrayList<>();
         isOn = !isOn;
-        if(isOn){
+        if (isOn) {
             sids.add("04010560D2C7170A0A0100000000");
-        }else{
+        } else {
             sids.add("04010560D2C76E0A0A0100010000");
         }
-        HDLLink.getInstance().controlScene(sids,new HDLLinkCallBack() {
+        HDLLink.getInstance().controlScene(sids, new HDLLinkCallBack() {
             @Override
             public void onSuccess(String msg) {
                 responseTv.setText(msg);
@@ -488,7 +501,7 @@
     }
 
 
-    void startDevicesListActivity(){
+    void startDevicesListActivity() {
         Intent intent = new Intent(this, DevicesListActivity.class);
         startActivity(intent);
     }
@@ -497,27 +510,29 @@
      * TCP鍙戦�� 鍙彂涓�娆★紝涓嶇洃鍚洖澶嶏紝涓嶉噸鍙�
      */
     private void tcpSend() {
+        tv.setText("TCP鍙戦�� 鍙彂涓�娆★紝涓嶇洃鍚洖澶嶏紝涓嶉噸鍙�");
         String propertyDownTopic = String.format(TopicConstant.PROPERTY_DOWN, HDLLinkConfig.getInstance().getGatewayId());
         String bodyStr = getPropertyDownBodyStr();
         HDLLink.getInstance().tcpSendMsg(propertyDownTopic, bodyStr);
     }
 
     /**
-     * 鍙彂涓�娆★紝涓嶇洃鍚洖澶嶏紝涓嶉噸鍙�
+     * UDP鍙彂涓�娆★紝涓嶇洃鍚洖澶嶏紝涓嶉噸鍙�
      */
     private void udpSend() {
+        tv.setText("UDP鍙戦�� 鍙彂涓�娆★紝涓嶇洃鍚洖澶嶏紝涓嶉噸鍙�");
         String propertyDownTopic = String.format(TopicConstant.PROPERTY_DOWN, HDLLinkConfig.getInstance().getGatewayId());
         String bodyStr = getPropertyDownBodyStr();
         HDLLink.getInstance().udpSendMsg(propertyDownTopic, bodyStr);
     }
 
-    private String getPropertyDownBodyStr(){
+    private String getPropertyDownBodyStr() {
         isOn = !isOn;
         List<DeviceControlRequest> requestList = new ArrayList<>();
         DeviceControlRequest request = new DeviceControlRequest();
         request.setSid(testLightSid);
-        List<DeviceControlRequest.StatusBean>  statusBeanList= new ArrayList<>();
-        DeviceControlRequest.StatusBean bean =  new DeviceControlRequest.StatusBean();
+        List<DeviceControlRequest.StatusBean> statusBeanList = new ArrayList<>();
+        DeviceControlRequest.StatusBean bean = new DeviceControlRequest.StatusBean();
         bean.setKey("on_off");
         bean.setValue(isOn ? "on" : "off");
         statusBeanList.add(bean);
@@ -532,4 +547,46 @@
 
         return GsonConvert.getGson().toJson(data);
     }
+
+    /**
+     * UDP鍙戦�侊紝鐩戝惉涓婚鍥炲锛屽甫閲嶅彂甯﹀洖璋�
+     */
+    private void udpSendWithCallback() {
+        tv.setText("UDP鍙戦�侊紝鐩戝惉涓婚鍥炲锛屽甫閲嶅彂甯﹀洖璋�");
+        String propertyDownTopic = String.format(TopicConstant.PROPERTY_DOWN, HDLLinkConfig.getInstance().getGatewayId());
+        String bodyStr = getPropertyDownBodyStr();
+        HDLLink.getInstance().udpSendMsg(propertyDownTopic, bodyStr, new HDLLinkResponseCallBack() {
+            @Override
+            public void onSuccess(LinkResponse msg) {
+                Log.i("udpSendWithCallback", "udpSendWithCallback");
+                responseTv.setText(GsonConvert.getGson().toJson(msg));
+            }
+
+            @Override
+            public void onError(HDLLinkException e) {
+                responseTv.setText(e.getMsg());
+            }
+        });
+    }
+
+    /**
+     * TCP鍙戦�侊紝鐩戝惉涓婚鍥炲锛屽甫閲嶅彂甯﹀洖璋�
+     */
+    private void tcpSendWithCallback() {
+        tv.setText("TCP鍙戦�侊紝鐩戝惉涓婚鍥炲锛屽甫閲嶅彂甯﹀洖璋�");
+        String propertyDownTopic = String.format(TopicConstant.PROPERTY_DOWN, HDLLinkConfig.getInstance().getGatewayId());
+        String bodyStr = getPropertyDownBodyStr();
+        HDLLink.getInstance().tcpSendMsg(propertyDownTopic, bodyStr, new HDLLinkCallBack() {
+            @Override
+            public void onSuccess(String msg) {
+                Log.i("tcpSendWithCallback", "tcpSendWithCallback");
+                responseTv.setText(msg);
+            }
+
+            @Override
+            public void onError(HDLLinkException e) {
+                responseTv.setText(e.getMsg());
+            }
+        });
+    }
 }
\ No newline at end of file

--
Gitblit v1.8.0