From ef270bd1855b5ce3f398c5df024840a498e33a8f Mon Sep 17 00:00:00 2001
From: MercuryZ <zdmisif@126.com>
Date: 星期四, 31 三月 2022 14:09:17 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/manager/iot/frame/inner/report/A5C3HeartbeatReportInnerFrame.java |   85 +++++++++++++++++++++++++++++++++---------
 1 files changed, 66 insertions(+), 19 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/manager/iot/frame/inner/report/A5C3HeartbeatReportInnerFrame.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/manager/iot/frame/inner/report/A5C3HeartbeatReportInnerFrame.java
index 8c07181..a25bc62 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/manager/iot/frame/inner/report/A5C3HeartbeatReportInnerFrame.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/manager/iot/frame/inner/report/A5C3HeartbeatReportInnerFrame.java
@@ -1,5 +1,6 @@
 package com.sandu.ximon.admin.manager.iot.frame.inner.report;
 
+import cn.hutool.core.util.HexUtil;
 import cn.hutool.core.util.StrUtil;
 import com.sandu.ximon.admin.manager.iot.frame.inner.BaseResponseInnerFrame;
 import com.sandu.ximon.admin.manager.iot.frame.inner.IResponseInnerFrame;
@@ -98,25 +99,26 @@
                 return null;
             }
             this.c3Mac = hex.substring(0, 8);
-            this.year = hex.substring(8, 10);
-            this.month = hex.substring(10, 12);
-            this.day = hex.substring(12, 14);
-            this.hour = hex.substring(14, 16);
-            this.min = hex.substring(16, 18);
-            this.sec = hex.substring(18, 20);
-            this.chargingPort = hex.substring(20, 24);
-            this.statusBit = hex.substring(24, 26);
-            this.deviceTemperature = (parseVal(hex, 26, 28) + "." + parseVal(hex, 28, 30));
-            this.gridVoltage = hex.substring(30, 34);
-            this.gridCurrent = hex.substring(34, 38);
-            this.frequency = hex.substring(38, 42);
-            this.powerFactor = hex.substring(42, 46);
-            this.activePower = hex.substring(46, 50);
-            this.reactivePower = hex.substring(50, 54);
-            this.chargedCapacity = hex.substring(54, 58);
-            this.reservedCapacity = hex.substring(58, 62);
-            this.remainingAmount = hex.substring(62, 66);
-            this.alreadyChargingTime = hex.substring(66, 72);
+            this.year = parseVal(hex.substring(8, 10));
+            this.month = parseVal(hex.substring(10, 12));
+            this.day = parseVal(hex.substring(12, 14));
+            this.hour = parseVal(hex.substring(14, 16));
+            this.min = parseVal(hex.substring(16, 18));
+            this.sec = parseVal(hex.substring(18, 20));
+            this.chargingPort = parseVal(hex.substring(20, 24));
+            this.statusBit = parseVal(hex.substring(24, 26));
+            this.deviceTemperature = temperatureTransition(hex.substring(26, 30)) + "";
+            this.gridVoltage = (parseVal(hex, 30, 34) * 0.01) + "";
+            this.gridCurrent = (parseVal(hex, 34, 38) * 0.01 + "");
+            this.frequency = (parseVal(hex, 38, 42) * 0.01 + "");
+            this.powerFactor = (parseVal(hex, 42, 46) * 0.01 + "");
+            this.activePower = (parseVal(hex, 46, 50) * 0.01 + "");
+            this.reactivePower = (parseVal(hex, 50, 54) * 0.01 + "");
+            this.chargedCapacity = (parseVal(hex, 54, 58) * 0.01 + "");
+            this.reservedCapacity = (parseVal(hex, 58, 62) * 0.01 + "");
+            this.remainingAmount = (parseVal(hex, 62, 66) * 0.01 + "");
+            this.alreadyChargingTime = parseVal(hex.substring(66, 72));
+            //72-80淇濈暀锛屾殏鏈娇鐢�
 
             return this;
         }
@@ -124,5 +126,50 @@
         private Integer parseVal(String frame, int start, int end) {
             return Integer.parseInt(frame.substring(start, end), 16);
         }
+
+        private String parseVal(String hex) {
+            return Integer.parseInt(hex, 16) + "";
+        }
+
+        /**
+         * 灏�16杩涘埗杞垚2杩涘埗锛岃繘琛岃ˉ鐮侊紙鍙嶇爜鍩虹涓�+1锛夛紝寰楀埌姝g‘鏁板��
+         * 浼犲叆16杩涘埗鐨勬俯搴︼紝绫诲瀷涓篠tring
+         * 濡侳500
+         */
+        public 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 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