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