From 5cfcf41368e52dd0128e8561e3709ba3bea833a4 Mon Sep 17 00:00:00 2001
From: zhanzhiqin <895896009@qq.com>
Date: 星期三, 02 三月 2022 18:13:56 +0800
Subject: [PATCH] 大气数据主动获取保存数据库FIX

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/controller/AirDataController.java                                    |   26 +++---------
 ximon-admin/src/main/java/com/sandu/ximon/admin/manager/iot/amqp/AmqpMessageListener.java                            |    7 ++-
 ximon-admin/src/main/java/com/sandu/ximon/admin/manager/iot/frame/inner/report/A5LightHeartbeatReportInnerFrame.java |   48 +++++++++++++++++++++++
 3 files changed, 59 insertions(+), 22 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/AirDataController.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/AirDataController.java
index aa0497b..b65653d 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/AirDataController.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/AirDataController.java
@@ -1,8 +1,10 @@
 package com.sandu.ximon.admin.controller;
 
+import com.alibaba.fastjson.JSON;
 import com.sandu.common.domain.ResponseVO;
 import com.sandu.common.object.BaseConditionVO;
 import com.sandu.common.util.ResponseUtil;
+import com.sandu.ximon.admin.manager.iot.amqp.processor.AirDataProcessor;
 import com.sandu.ximon.admin.manager.iot.frame.A5Frame;
 import com.sandu.ximon.admin.manager.iot.frame.inner.request.AirDataReqInnerFrame;
 import com.sandu.ximon.admin.manager.iot.rrpc.dto.CommonFrame;
@@ -54,7 +56,6 @@
     public ResponseVO<Object> updataAirEquipmentInfo(@RequestBody List<String> listMac) {
         AirDataReqInnerFrame airDataReqInnerFrame = new AirDataReqInnerFrame();
         A5Frame a5Frame = new A5Frame(A5OrderEnum.REQUEST_ATMOSPHERE_DATA.getCode(), airDataReqInnerFrame);
-
 //        WrapResponseCommonFrame<A5AtmosphereHeartbeatReportInnerFrame> wrapResponseCommonFrame =
 //                MainBoardInvokeSyncService.getInstance().sendRRPC(listMac.get(0), a5Frame, A5AtmosphereHeartbeatReportInnerFrame.class);
 
@@ -62,9 +63,13 @@
         List<String> failed = new ArrayList<>();
 
         listMac.parallelStream().forEach(macStr -> {
-//            System.out.println(System.currentTimeMillis()+"       -------------");
             try {
                 CommonFrame commonFrame = MainBoardInvokeSyncService.getInstance().sendRRPC(macStr, a5Frame);
+//                //娴嬭瘯鐢ㄧ殑
+//                String s = "{\"connectType\":\"FE\",\"crc32\":\"8685DF1B\",\"functionCode\":\"A5\",\"orderType\":\"84\",\"payload\":\"F0010022FFFF0101016666640000000000000000419D000000360089000000000002019300008CA14C69\",\"payloadLength\":\"002A\",\"validate\":true}";
+//                CommonFrame commonFrame1 = JSON.parseObject(s, CommonFrame.class);
+//                AirDataProcessor.getInstance().process("a1JsfPG4iKW",macStr,commonFrame1);
+                AirDataProcessor.getInstance().process("a1JsfPG4iKW",macStr,commonFrame);
                 if (commonFrame != null) {
                     success.add(macStr);
                 } else {
@@ -73,24 +78,7 @@
             } catch (Exception e) {
                 failed.add(macStr);
             }
-//            System.out.println(System.currentTimeMillis());
         });
-
-
-//        for (String macStr : listMac) {
-//            System.out.println(System.currentTimeMillis()+"       -------------");
-//            try {
-//                CommonFrame commonFrame = MainBoardInvokeSyncService.getInstance().sendRRPC(macStr, a5Frame);
-//                if (commonFrame != null) {
-//                    success.add(macStr);
-//                } else {
-//                    failed.add(macStr);
-//                }
-//            } catch (Exception e) {
-//                failed.add(macStr);
-//            }
-//            System.out.println(System.currentTimeMillis());
-//        }
 
         Map<String, List> resultMap = new HashMap<>();
         resultMap.put("success", success);
diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/manager/iot/amqp/AmqpMessageListener.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/manager/iot/amqp/AmqpMessageListener.java
index 04d8bb1..a6b034d 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/manager/iot/amqp/AmqpMessageListener.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/manager/iot/amqp/AmqpMessageListener.java
@@ -90,8 +90,8 @@
         if (frame == null) {
             return;
         }
-        log.info("澶勭悊璁㈤槄");
-        log.info(frame.toString());
+//        log.info("澶勭悊璁㈤槄");
+//        log.info(frame.toString());
         if (frame.getOrderType().equals(A5OrderEnum.RESPONSE_LIGHT_DATA.getCode())) {
             // 鍗曠伅鏁版嵁涓婃姤澶勭悊
             LightDataProcessor.getInstance().process(productKey, deviceName, frame);
@@ -99,6 +99,9 @@
             // C3鍏呯數妗╀笂鎶ュ鐞�
             c3ChargingReportAnalysis(productKey, deviceName, frame);
         } else if (frame.getOrderType().equals(A5OrderEnum.RESPONSE_ATMOSPHERE_DATA.getCode())) {
+//            //娴嬭瘯鐢ㄧ殑
+//            String s = "{\"connectType\":\"FE\",\"crc32\":\"8685DF1B\",\"functionCode\":\"A5\",\"orderType\":\"84\",\"payload\":\"F0010022FFFF0101010907640000000000000000419D000000360089000000000002019300008CA14C69\",\"payloadLength\":\"002A\",\"validate\":true}";
+//            CommonFrame commonFrame1 = JSON.parseObject(s, CommonFrame.class);
             // 澶ф皵鏁版嵁鎸囦护涓婃姤
             AirDataProcessor.getInstance().process(productKey, deviceName, frame);
 //            atmosphereAnalysis(productKey, deviceName, frame);
diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/manager/iot/frame/inner/report/A5LightHeartbeatReportInnerFrame.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/manager/iot/frame/inner/report/A5LightHeartbeatReportInnerFrame.java
index e25240e..477780a 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/manager/iot/frame/inner/report/A5LightHeartbeatReportInnerFrame.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/manager/iot/frame/inner/report/A5LightHeartbeatReportInnerFrame.java
@@ -108,7 +108,9 @@
             this.min = HexUtil.hexToInt(hex.substring(8, 10));
             this.sec = HexUtil.hexToInt(hex.substring(10, 12));
 
-            this.deviceTemperature = NumberUtil.round(HexUtil.hexToInt(hex.substring(12, 16)) * 0.01, 2).doubleValue();
+//            //闇�瑕佹妸鍗佸叚杩涘埗杞簩杩涘埗
+//            this.deviceTemperature = NumberUtil.round(HexUtil.hexToInt(hex.substring(12, 16)) * 0.01, 2).doubleValue();
+            this.deviceTemperature = NumberUtil.round(temperatureTransition(hex.substring(12, 16)), 2).doubleValue();
             this.lightPercent = HexUtil.hexToInt(hex.substring(16, 18));
             this.voltage = NumberUtil.round(HexUtil.hexToInt(hex.substring(18, 22)) * 0.1, 1).doubleValue();
             this.electricCurrent = NumberUtil.round(HexUtil.hexToInt(hex.substring(22, 26)) * 0.001, 3).doubleValue();
@@ -124,6 +126,50 @@
             this.retain = hex.substring(76, 96);
             return this;
         }
+
+        /**
+         * 灏�16杩涘埗杞垚2杩涘埗锛岃繘琛岃ˉ鐮侊紙鍙嶇爜鍩虹涓�+1锛夛紝寰楀埌姝g‘鏁板��
+         * 浼犲叆16杩涘埗鐨勬俯搴︼紝绫诲瀷涓篠tring
+         * 濡侳500
+         */
+        public static Double temperatureTransition(String temperature) {
+
+            //灏嗕紶杩涙潵鐨�16杩涘埗鐨勮浆涓�2杩涘埗
+            String twoBinStr = hexStr2BinStr(temperature);
+
+            if ("1".equals(twoBinStr.substring(0, 1))) {
+                //鏈�楂樹綅鏄�1锛屼负璐熸暟,灏�16杩涘埗鐨勮繘琛岃ˉ鐮侊紝杩斿洖
+                int max = 0b1111111111111111;
+                double result = (max-HexUtil.hexToInt(temperature))*(-0.01);
+                return result;
+
+            } else if ("0".equals(twoBinStr.substring(0, 1))) {
+                //鏈�楂樹綅鏄�0锛屾鏁帮紝鐩存帴杩斿洖
+                double result = (HexUtil.hexToInt(temperature))*(0.01);
+                return result;
+
+            }
+            //
+            return 0.00;
+        }
+        /**
+         * 16杩涘埗瀛楃涓茶浆涓轰簩杩涘埗
+         * */
+        public static String hexStr2BinStr(String hexStr)
+        {
+            if (hexStr == null || hexStr.length() % 2 != 0)
+            {
+                return null;
+            }
+            String bString = "", tmp;
+            for (int i = 0; i < hexStr.length(); i++)
+            {
+                tmp = "0000" + Integer.toBinaryString(Integer.parseInt(hexStr.substring(i, i + 1), 16));
+                bString += tmp.substring(tmp.length() - 4);
+            }
+            return bString;
+        }
+
     }
 
 }

--
Gitblit v1.9.3