From e4d7da0fc500395f70f13d6c46bd7227c8644ec4 Mon Sep 17 00:00:00 2001
From: liusuyi <13324259@qq.com>
Date: 星期三, 29 十一月 2023 21:18:59 +0800
Subject: [PATCH] 增加雷达引导相机跟踪

---
 ard-work/src/main/java/com/ruoyi/alarm/radar/service/impl/ArdRadarServiceImpl.java |   62 +++++++++++++++----------------
 1 files changed, 30 insertions(+), 32 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/alarm/radar/service/impl/ArdRadarServiceImpl.java b/ard-work/src/main/java/com/ruoyi/alarm/radar/service/impl/ArdRadarServiceImpl.java
index 8d1cdf3..e97ed12 100644
--- a/ard-work/src/main/java/com/ruoyi/alarm/radar/service/impl/ArdRadarServiceImpl.java
+++ b/ard-work/src/main/java/com/ruoyi/alarm/radar/service/impl/ArdRadarServiceImpl.java
@@ -1,6 +1,8 @@
 package com.ruoyi.alarm.radar.service.impl;
 
 import com.alibaba.fastjson2.JSONObject;
+import com.ruoyi.alarm.radar.domain.ArdAlarmRadar;
+import com.ruoyi.alarm.radar.domain.RadarAlarmData;
 import com.ruoyi.alarm.radar.service.ArdRadarService;
 import com.ruoyi.common.utils.StringUtils;
 import com.ruoyi.device.camera.domain.ArdCameras;
@@ -16,6 +18,7 @@
 
 import javax.annotation.Resource;
 import java.util.HashMap;
+import java.util.List;
 import java.util.Map;
 
 /**
@@ -89,43 +92,38 @@
     @Async
     public void followGuide(String msg) {
         try {
-            Map<String, Object> msgMap = JSONObject.parseObject(msg, Map.class);
-            if (msgMap != null) {
-                Double p = Double.parseDouble(msgMap.get("p").toString());
-                Double t = Double.parseDouble(msgMap.get("t").toString());
-                Long distance = Long.parseLong(msgMap.get("distance").toString());
-                String radarId = msgMap.get("radarId").toString();
-                //鑾峰彇闆疯揪鎵�鍦ㄥ涓婄殑澶у厜鐢�
-                ArdCameras camera = ardEquipRadarMapper.getCameraByRadar(radarId);
-                if (StringUtils.isNotNull(camera)) {
-                    log.debug("鑾峰彇鍒伴浄杈惧涓婄殑鍏夌數:" + camera.getId());
-                    //璁$畻鐩爣鐐瑰潗鏍�
-                    GlobalCoordinates cameraCoordinates = new GlobalCoordinates(camera.getLatitude(), camera.getLongitude());
-                    GlobalCoordinates targetCoordinates = GisUtil.getGlobalCoordinates(cameraCoordinates, p, distance);
-                    //鑾峰彇ptz
-                    double[] cameraPoint = new double[]{ camera.getLongitude(), camera.getLatitude(),camera.getAltitude()};
-                    double[] targetPoint = new double[]{targetCoordinates.getLongitude(), targetCoordinates.getLatitude()};
-                    double[] cameraPTZ = GisUtil.getCameraPTZ(cameraPoint, targetPoint, 20, 150);
-                    //濡傛灉闆疯揪濉斾笂鏈夊厜鐢�
-                    CameraCmd cmd = new CameraCmd(camera.getId(), 1);
-                    cmd.setOperator("sys_radar_follow");
-                    Map<String, Double> ptzMap = new HashMap<>();
-                    ptzMap.put("p", p);
-                    ptzMap.put("t", t);
-                    ptzMap.put("z", cameraPTZ[2]);
-                    cmd.setPtzMap(ptzMap);
-                    boolean res = iCameraSdkService.setPtz(cmd);
-                    if (res) {
-                        log.debug("闆疯揪杩借釜寮曞鎴愬姛");
+            RadarAlarmData radarFollowData = JSONObject.parseObject(msg, RadarAlarmData.class);
+            if (radarFollowData != null) {
+                ArdAlarmRadar ardFollowRadar = radarFollowData.getArdFollowRadars();
+                if (ardFollowRadar != null) {
+                    //褰撴瘡娆′笂鎶ュ彧涓婃姤涓�涓拷韪俊鎭紝璁や负涓嶅お鍙兘闆疯揪鎵弿涓�娆′細璺熻釜澶氫釜鐩爣
+                    String radarId = radarFollowData.getRadarId();//闆疯揪id
+                    //杩欓噷杩借釜鐨勫潗鏍囦负闆疯揪缁忚繃璁$畻涓婁紶鐨勭粡绾害
+                    Double longitude = ardFollowRadar.getLongitude();
+                    Double latitude = ardFollowRadar.getLatitude();
+                    //鑾峰彇闆疯揪鎵�鍦ㄥ涓婄殑澶у厜鐢�
+                    ArdCameras camera = ardEquipRadarMapper.getCameraByRadar(radarId);
+                    if (StringUtils.isNotNull(camera)) {
+                        log.debug("鑾峰彇鍒伴浄杈惧涓婄殑澶у厜鐢�:" + camera.getId());
+                        //濡傛灉闆疯揪濉斾笂鏈夊厜鐢�,寮曞鍏夌數鐨�1閫氶亾鍒拌拷韪殑鍧愭爣
+                        CameraCmd cmd = new CameraCmd(camera.getId(), 1);
+                        cmd.setOperator("sys_radar_follow");
+                        cmd.setCameraId(camera.getId());
+                        cmd.setChanNo(1);
+                        cmd.setTargetPosition(new double[]{longitude,latitude});
+                        boolean res = iCameraSdkService.guideTargetPosition(cmd);
+                        if (res) {
+                            log.debug("闆疯揪杩借釜寮曞鎴愬姛");
+                        } else {
+                            log.debug("闆疯揪杩借釜寮曞澶辫触");
+                        }
                     } else {
-                        log.debug("闆疯揪杩借釜寮曞澶辫触");
+                        log.debug("鏈幏鍙栧埌闆疯揪濉斾笂鐨勫ぇ鍏夌數");
                     }
-                } else {
-                    log.debug("鏈幏鍙栧埌闆疯揪濉斾笂鐨勫厜鐢�");
                 }
             }
         } catch (Exception ex) {
-            log.error("杈捐拷韪紩瀵煎紓甯�:" + ex.getMessage());
+            log.error("闆疯揪杩借釜寮曞寮傚父:" + ex.getMessage());
         }
     }
 }
\ No newline at end of file

--
Gitblit v1.9.3