From 606d7388589829e6a7108a48898d4e4126312d73 Mon Sep 17 00:00:00 2001
From: ‘liusuyi’ <1951119284@qq.com>
Date: 星期三, 01 十一月 2023 16:38:11 +0800
Subject: [PATCH] 增加雷达角度引导信息反馈

---
 src/main/java/com/ard/utils/tcp/ClientHandler.java |   78 +++++++++++++++++++++++++-------------
 1 files changed, 51 insertions(+), 27 deletions(-)

diff --git a/src/main/java/com/ard/utils/tcp/ClientHandler.java b/src/main/java/com/ard/utils/tcp/ClientHandler.java
index 74f4d99..2693e76 100644
--- a/src/main/java/com/ard/utils/tcp/ClientHandler.java
+++ b/src/main/java/com/ard/utils/tcp/ClientHandler.java
@@ -1,11 +1,12 @@
 package com.ard.utils.tcp;
+
 import com.alibaba.fastjson2.JSON;
 import com.ard.alarm.radar.domain.ArdAlarmRadar;
 import com.ard.alarm.radar.domain.ArdEquipRadar;
 import com.ard.alarm.radar.domain.RadarAlarmData;
 import com.ard.utils.other.ByteUtils;
 import com.ard.utils.other.GisUtils;
-import com.ard.utils.mqtt.MqttConsumer;
+import com.ard.utils.mqtt.MqttProducer;
 import io.netty.buffer.ByteBuf;
 import io.netty.channel.ChannelHandlerContext;
 import io.netty.channel.ChannelId;
@@ -21,6 +22,7 @@
 import java.util.List;
 import java.util.concurrent.ScheduledFuture;
 import java.util.concurrent.TimeUnit;
+
 /**
  * @Description: 瀹㈡埛绔鐞嗗櫒
  * @ClassName: ClientHandler
@@ -41,7 +43,7 @@
      * @throws Exception
      */
     @Override
-    public void channelActive(ChannelHandlerContext ctx) throws Exception {
+    public void channelActive(ChannelHandlerContext ctx) {
         context = ctx;
         startHeartbeatTask();//寮�濮嬪彂閫佸績璺�
     }
@@ -143,7 +145,7 @@
             byte[] heart = ByteUtils.appendArrays(header, payload, payloadCrc32, footer);
 //            byte[] heart = {0x01, 0x02, 0x01, 0x10, 0x00, 0x00, 0x00, (byte) 0x83, (byte) 0x88, 0x5d, 0x71, 0x01, 0x02, 0x00};
             String hexString = DatatypeConverter.printHexBinary(heart);
-            log.debug("鍙戦�佸績璺�:" + hexString);
+           // log.debug("鍙戦�佸績璺�:" + hexString);
             message.writeBytes(heart);
             context.writeAndFlush(message);
 
@@ -169,12 +171,13 @@
             String radarName = ardEquipRadarbyte.getName();
             Double radarLongitude = ardEquipRadarbyte.getLongitude();
             Double radarLagitude = ardEquipRadarbyte.getLatitude();
+            Double radarAltitude = ardEquipRadarbyte.getAltitude();
             //region crc鏍¢獙-鐩墠浠呯敤浜庢樉绀烘牎楠岀粨鏋�
             Boolean crc32Check = MessageParsing.CRC32Check(data);
             if (!crc32Check) {
-                log.info("CRC32鏍¢獙涓嶉�氳繃");
+                log.debug("CRC32鏍¢獙涓嶉�氳繃");
             } else {
-                log.info("CRC32鏍¢獙閫氳繃");
+                log.debug("CRC32鏍¢獙閫氳繃");
             }
             //endregion
             //log.info("鍘熷鏁版嵁:" + DatatypeConverter.printHexBinary(data));
@@ -191,6 +194,8 @@
             // log.info("鏈夋晥璐熻浇澶у皬(杞暣鍨�):" + payloadSizeToDecimal);
             //endregion
             List<ArdAlarmRadar> radarAlarmInfos = new ArrayList<>();
+            //鎶芥补鏈虹姸鎬侀浄杈炬帹閫侀泦鍚�
+            List<ArdAlarmRadar> well = new ArrayList<>();
             String alarmTime = "";
             Integer targetNum = 0;
             if (Arrays.equals(cmdId, new byte[]{0x01})) {
@@ -208,7 +213,7 @@
                 if (targetNum == 0) {
                     return;
                 }
-                log.info("鐩爣鎬荤偣鏁�(杞暣鍨�):" + targetNum);
+                log.debug("鐩爣鎬荤偣鏁�(杞暣鍨�):" + targetNum);
 
                 //瑙f瀽NET_TARGET_UNIT(64鏄疦ET_TARGET_HEAD鐨勫瓧鑺傛暟)
                 int uintSize = (payloadSizeToDecimal - 64) / targetNum;
@@ -221,13 +226,13 @@
                     // log.info("鐩爣ID:" + DatatypeConverter.printHexBinary(cmdId));
                     dwID = ByteUtils.toLittleEndian(dwID);
                     int id = ByteUtils.bytesToDecimal(dwID);
-
                     // log.info("鐩爣ID鍙凤細" + id);
 
                     byte[] iDistance = Arrays.copyOfRange(data, index + 8, index + 12);
                     iDistance = ByteUtils.toLittleEndian(iDistance);
-                    Double Distance = ByteUtils.bytesToDouble(iDistance);
-                    // log.info("鐩爣褰撳墠璺濈(m):" + Distance);
+                    double Distance = ByteUtils.bytesToDecimal(iDistance);
+                    log.debug("鐩爣褰撳墠鐩寸嚎璺濈(m):" + Distance);
+
                     //region 涓嶉渶瑕佺殑瀛楁
 //                    byte[] dwGSum = Arrays.copyOfRange(data, index + 4, index + 8);
 //                    dwGSum = toLittleEndian(dwGSum);
@@ -298,10 +303,16 @@
                     byte[] afTy = Arrays.copyOfRange(data, index + 112, index + 116);
                     afTy = ByteUtils.toLittleEndian(afTy);
                     float fTy = ByteUtils.bytesToFloat(afTy);
-                    //  log.info("鍨傜洿瑙掑害:" + fTy);
+                    log.debug("鍨傜洿瑙掑害:" + fTy);
+                    // 灏嗚搴﹁浆鎹负寮у害
+                    double thetaRadians = Math.toRadians(fTy+90);
+                    // 浣跨敤姝e鸡鍑芥暟璁$畻瀵硅竟闀垮害
+                    Distance = Math.sin(thetaRadians) * Distance;
+                    log.debug("鐩爣鎶曞奖璺濈(m):" + Distance);
+
                     Double[] radarXY = {radarLongitude, radarLagitude};
                     Double[] alarmXY = GisUtils.CalculateCoordinates(radarXY, Distance, (double) fTx);
-                    //  log.info("鎶ヨ淇℃伅锛�" + "銆恑d銆�" + id + "銆恘ame銆�" + alarmPointName + "銆恆larmType銆�" + alarmType + "銆恆larmTime銆�" + alarmTime + "銆恉istance銆�" + Distance + "銆怭銆�" + fTx + "銆怲銆�" + fTy + "銆怷銆�" + alarmXY[0] + "銆怸銆�" + alarmXY[1]);
+                    log.debug("鎶ヨ淇℃伅锛�" + "銆恑d銆�" + id + "銆恘ame銆�" + alarmPointName + "銆恆larmType銆�" + alarmType + "銆恆larmTime銆�" + alarmTime + "銆恉istance銆�" + Distance + "銆怭銆�" + fTx + "銆怲銆�" + fTy + "銆怷銆�" + alarmXY[0] + "銆怸銆�" + alarmXY[1]);
                     ArdAlarmRadar ardAlarmRadar = new ArdAlarmRadar();
                     ardAlarmRadar.setTargetId(id);
                     ardAlarmRadar.setName(alarmPointName);
@@ -327,7 +338,7 @@
                 byte[] wTargetNum = Arrays.copyOfRange(data, 8, 10);
                 wTargetNum = ByteUtils.toLittleEndian(wTargetNum);
                 targetNum = ByteUtils.bytesToDecimal(wTargetNum);
-                log.info("鐩爣鎬荤偣鏁�(杞暣鍨�):" + targetNum);
+                log.debug("鐩爣鎬荤偣鏁�(杞暣鍨�):" + targetNum);
                 if (targetNum == 0) {
                     return;
                 }
@@ -355,16 +366,16 @@
                     byte[] fTx = Arrays.copyOfRange(data, index + 12, index + 16);
                     fTx = ByteUtils.toLittleEndian(fTx);
                     float fTxAngle = ByteUtils.bytesToFloat(fTx);
-                    //log.info("p瑙掑害:" + fTxAngle);
+                    log.debug("p瑙掑害:" + fTxAngle);
                     byte[] fTy = Arrays.copyOfRange(data, index + 16, index + 20);
                     fTy = ByteUtils.toLittleEndian(fTy);
                     float fTyAngle = ByteUtils.bytesToFloat(fTy);
-                    //log.info("t瑙掑害:" + fTyAngle);
+                    log.debug("t瑙掑害:" + fTyAngle);
 
                     byte[] sAreaNo = Arrays.copyOfRange(data, index + 20, index + 22);
                     sAreaNo = ByteUtils.toLittleEndian(sAreaNo);
                     int AreaNo = ByteUtils.bytesToDecimal(sAreaNo);
-                    //log.info("鐩爣褰掑睘鐨勫憡璀﹀尯鍩熷彿:" + AreaNo);
+                    log.debug("鐩爣褰掑睘鐨勫憡璀﹀尯鍩熷彿:" + AreaNo);
 
                     byte[] cGrp = Arrays.copyOfRange(data, index + 22, index + 23);
                     cGrp = ByteUtils.toLittleEndian(cGrp);
@@ -372,6 +383,8 @@
                     //log.info("鎵�灞炵粍:" + Grp);
                     //endregion
                     String alarmType;
+                    //鎶芥补鏈虹姸鎬佸彉閲�
+                    String wellType;
                     byte[] cStat = Arrays.copyOfRange(data, index + 23, index + 24);
                     cStat = ByteUtils.toLittleEndian(cStat);
                     //String binaryString = String.format("%8s", Integer.toBinaryString(cStat[0] & 0xFF)).replace(' ', '0');
@@ -382,21 +395,29 @@
                     // 鍒ゆ柇鎻愬彇鐨勫��
                     if (isB0) {
                         alarmType = "闆疯揪鎶芥补鏈哄仠鏈�";
+                        byte[] szName = Arrays.copyOfRange(data, index + 32, index + 64);
+                        //log.info("鎵�灞炲憡璀﹀尯鍩熷悕绉�:" + DatatypeConverter.printHexBinary(szName));
+                        String alarmPointName = ByteUtils.bytesToStringZh(szName);
+                        // log.info("鎵�灞炲憡璀﹀尯鍩熷悕绉�:" + alarmPointName);
+                        log.debug("鎶ヨ淇℃伅锛�" + "銆恑d銆�" + id + "銆恘ame銆�" + alarmPointName + "銆恆larmType銆�" + alarmType + "銆恆larmTime銆�" + alarmTime);
+                        ArdAlarmRadar ardAlarmRadar = new ArdAlarmRadar();
+                        ardAlarmRadar.setTargetId(id);
+                        ardAlarmRadar.setName(alarmPointName);
+                        ardAlarmRadar.setAlarmType(alarmType);
+                        radarAlarmInfos.add(ardAlarmRadar);
+                        wellType = "鍋滄満";
                     } else {
-                        continue;
+                        wellType = "杩愯";
                     }
-                    //log.info("鎶ヨ绫诲瀷:" + alarmType);
-
+                    //鎶芥补鏈虹姸鎬侀泦鍚堜腑瑁呭叆鏁版嵁
                     byte[] szName = Arrays.copyOfRange(data, index + 32, index + 64);
-                    //log.info("鎵�灞炲憡璀﹀尯鍩熷悕绉�:" + DatatypeConverter.printHexBinary(szName));
                     String alarmPointName = ByteUtils.bytesToStringZh(szName);
-                    // log.info("鎵�灞炲憡璀﹀尯鍩熷悕绉�:" + alarmPointName);
-                    //log.info("鎶ヨ淇℃伅锛�" + "銆恑d銆�" + id + "銆恘ame銆�" + alarmPointName + "銆恆larmType銆�" + alarmType + "銆恆larmTime銆�" + alarmTime);
-                    ArdAlarmRadar ardAlarmRadar = new ArdAlarmRadar();
-                    ardAlarmRadar.setTargetId(id);
-                    ardAlarmRadar.setName(alarmPointName);
-                    ardAlarmRadar.setAlarmType(alarmType);
-                    radarAlarmInfos.add(ardAlarmRadar);
+                    log.debug("鎶芥补鏈虹姸鎬佹姤璀︿俊鎭細" + "銆恑d銆�" + id + "銆恘ame銆�" + alarmPointName + "銆恆larmType銆�" + wellType + "銆恆larmTime銆�" + alarmTime);
+                    ArdAlarmRadar wellAlarm = new ArdAlarmRadar();
+                    wellAlarm.setTargetId(id);
+                    wellAlarm.setName(alarmPointName);
+                    wellAlarm.setAlarmType(wellType);
+                    well.add(wellAlarm);
                 }
                 //endregion
             }
@@ -411,7 +432,10 @@
             radarAlarmData.setRadarName(radarName);
             radarAlarmData.setAlarmTime(alarmTime);
             radarAlarmData.setArdAlarmRadars(radarAlarmInfos);
-            MqttConsumer.publish(2, false, "radar", JSON.toJSONString(radarAlarmData));
+            MqttProducer.publish(2, false, "radar", JSON.toJSONString(radarAlarmData));
+            //鎶芥补鏈虹姸鎬丮QTT闃熷垪
+            radarAlarmData.setArdAlarmRadars(well);
+            MqttProducer.publish(2, false, "radarWellData", JSON.toJSONString(radarAlarmData));
         } catch (Exception ex) {
             log.error("闆疯揪鎶ユ枃瑙f瀽寮傚父:" + ex.getMessage());
         }

--
Gitblit v1.9.3