From 0362c0c8502a81fc974afb8d2aff85d9efd7bbb1 Mon Sep 17 00:00:00 2001
From: ‘liusuyi’ <1951119284@qq.com>
Date: 星期四, 29 六月 2023 17:28:22 +0800
Subject: [PATCH] 修改报警逻辑 增加优先级队列

---
 ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/GlobalAlarmServiceImpl.java |  273 +++++++++++++++++++++++---------------
 ard-work/src/main/java/com/ruoyi/device/hiksdk/util/hikSdkUtil/LoginResultCallBack.java     |    8 +
 ruoyi-common/src/main/java/com/ruoyi/common/utils/DateUtils.java                            |    7 
 ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/SdkTask.java                               |    5 
 ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/domain/GuidePriorityQueue.java           |    7 
 ard-work/src/main/java/com/ruoyi/alarm/radarAlarm/domain/RadarAlarmData.java                |    5 
 ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/domain/GuideTask.java                    |    6 
 /dev/null                                                                                   |   42 ------
 ard-work/src/main/java/com/ruoyi/alarm/radarAlarm/mapper/ArdAlarmRadarMapper.java           |   15 ++
 ard-work/src/main/java/com/ruoyi/constant/CamPriority.java                                  |    6 
 ard-work/src/main/java/com/ruoyi/device/hiksdk/service/impl/HikClientServiceImpl.java       |    2 
 ard-work/src/main/java/com/ruoyi/alarm/radarAlarm/domain/ArdAlarmRadar.java                 |    7 
 ard-work/src/main/resources/mapper/alarm/ArdAlarmRadarMapper.xml                            |   27 +++
 13 files changed, 244 insertions(+), 166 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/domain/GuidePriorityQueue.java b/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/domain/GuidePriorityQueue.java
index 937237d..11c5aac 100644
--- a/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/domain/GuidePriorityQueue.java
+++ b/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/domain/GuidePriorityQueue.java
@@ -1,13 +1,12 @@
 package com.ruoyi.alarm.globalAlarm.domain;
 
-import com.ruoyi.alarm.globalAlarm.service.impl.GuideTask;
-
 import java.util.Comparator;
 import java.util.HashMap;
 import java.util.Map;
+import java.util.PriorityQueue;
 
 /**
- * @Description:
+ * @Description: 寮曞浼樺厛绾ч槦鍒�
  * @ClassName: PriorityQueue
  * @Author: 鍒樿嫃涔�
  * @Date: 2023骞�06鏈�29鏃�11:18
@@ -17,7 +16,7 @@
     /**
      * 鐩告満闃熷垪锛屾瘡涓浉鏈轰竴涓紭鍏堢骇闃熷垪
      */
-    public static Map<String, java.util.PriorityQueue<GuideTask>> cameraQueueMap = new HashMap<>();
+    public static Map<String, PriorityQueue<GuideTask>> cameraQueueMap = new HashMap<>();
 
     /**
      * 鍒涘缓涓�涓嚜瀹氫箟鐨勬瘮杈冨櫒锛屾牴鎹紭鍏堢骇灞炴�ц繘琛屾瘮杈�
diff --git a/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/GuideTask.java b/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/domain/GuideTask.java
similarity index 73%
rename from ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/GuideTask.java
rename to ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/domain/GuideTask.java
index 56ea080..7636988 100644
--- a/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/GuideTask.java
+++ b/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/domain/GuideTask.java
@@ -1,7 +1,8 @@
-package com.ruoyi.alarm.globalAlarm.service.impl;
+package com.ruoyi.alarm.globalAlarm.domain;
 
 import lombok.AllArgsConstructor;
 import lombok.Data;
+import lombok.NoArgsConstructor;
 
 /**
  * @Description: 寮曞浠诲姟
@@ -11,11 +12,12 @@
  * @Version: 1.0
  **/
 @Data
+@NoArgsConstructor
 @AllArgsConstructor
 public class GuideTask {
 
+    String cameraId;
     String alarmId;
-    String alarmType;
     Integer priority;
     String alarmTime;
     Integer num;
diff --git a/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/GlobalAlarmServiceImpl.java b/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/GlobalAlarmServiceImpl.java
index 90cbeb2..2fa6745 100644
--- a/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/GlobalAlarmServiceImpl.java
+++ b/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/GlobalAlarmServiceImpl.java
@@ -5,6 +5,8 @@
 import com.ruoyi.alarm.cameraAlarm.mapper.ArdAlarmCameraMapper;
 import com.ruoyi.alarm.globalAlarm.domain.GlobalAlarmCondition;
 import com.ruoyi.alarm.globalAlarm.domain.GlobalAlarmData;
+import com.ruoyi.alarm.globalAlarm.domain.GuidePriorityQueue;
+import com.ruoyi.alarm.globalAlarm.domain.GuideTask;
 import com.ruoyi.alarm.globalAlarm.service.IGlobalAlarmService;
 import com.ruoyi.alarm.radarAlarm.domain.ArdAlarmRadar;
 import com.ruoyi.alarm.radarAlarm.domain.RadarAlarmData;
@@ -22,6 +24,7 @@
 import com.ruoyi.common.core.redis.RedisCache;
 import com.ruoyi.common.utils.DateUtils;
 import com.ruoyi.common.utils.StringUtils;
+import com.ruoyi.constant.CamPriority;
 import com.ruoyi.utils.tools.ArdTool;
 import com.ruoyi.utils.tools.GisTool;
 import com.ruoyi.common.utils.uuid.IdUtils;
@@ -54,19 +57,19 @@
 @Slf4j(topic = "mqtt")
 public class GlobalAlarmServiceImpl implements IGlobalAlarmService {
     @Resource
-    ArdAlarmRadarMapper ardAlarmRadarMapper;
+    private ArdAlarmRadarMapper ardAlarmRadarMapper;
     @Resource
-    ArdAlarmStealelecMapper ardAlarmStealelecMapper;
+    private ArdAlarmStealelecMapper ardAlarmStealelecMapper;
     @Resource
-    ArdAlarmTubeMapper ardAlarmTubeMapper;
+    private ArdAlarmTubeMapper ardAlarmTubeMapper;
     @Resource
-    ArdAlarmCameraMapper ardAlarmCameraMapper;
+    private ArdAlarmCameraMapper ardAlarmCameraMapper;
     @Resource
-    ArdTubesMapper ardTubesMapper;
+    private ArdTubesMapper ardTubesMapper;
     @Resource
-    ArdAlarmpointsWellMapper ardAlarmpointsWellMapper;
+    private ArdAlarmpointsWellMapper ardAlarmpointsWellMapper;
     @Resource
-    ArdTubesDetailsMapper ardTubesDetailsMapper;
+    private ArdTubesDetailsMapper ardTubesDetailsMapper;
     @Resource
     private ISysConfigService configService;
     @Resource
@@ -212,7 +215,7 @@
      * @淇敼浜哄拰鍏跺畠淇℃伅
      */
     @Override
-    @Async("alarmExecutor")
+//    @Async("alarmExecutor")
     public void receiveAlarm(String topic, String message) {
         try {
             switch (topic) {
@@ -227,28 +230,6 @@
                     int aas = ardAlarmStealelecMapper.insertArdAlarmStealelec(ardAlarmStealelec);
                     if (aas > 0) {
                         log.info("stealelec鍏ュ簱鎴愬姛锛�" + ardAlarmStealelec);
-                        ArdAlarmpointsWell well = ardAlarmpointsWellMapper.selectArdAlarmpointsWellByWellId(ardAlarmStealelec.getDescribe());
-                        if (well != null) {
-                            ardAlarmStealelec.setLongitude(well.getLongitude());
-                            ardAlarmStealelec.setLatitude(well.getLatitude());
-                            ardAlarmStealelec.setAltitude(well.getAltitude());
-                            //寮曞褰曞儚
-                            CameraCmd cmd = new CameraCmd();
-                            cmd.setRecordBucketName("record");
-                            cmd.setRecordObjectName("stealelec");
-                            cmd.setOperator("sys_steal_elec");
-                            cmd.setExpired(30);
-                            cmd.setTargetPosition(new double[]{well.getLongitude(), well.getLatitude(), well.getAltitude()});
-                            boolean res = guideCamera(cmd);
-                            if (res) {
-                                String url = alarmToRecord(cmd);
-                                if (StringUtils.isNotEmpty(url)) {
-                                    //鏇存柊褰曞儚
-                                    ardAlarmStealelec.setRecordUrl(url);
-                                    ardAlarmStealelecMapper.updateArdAlarmStealelec(ardAlarmStealelec);
-                                }
-                            }
-                        }
                     }
                     //endregion
                     break;
@@ -276,21 +257,9 @@
                     int aat = ardAlarmTubeMapper.insertArdAlarmTube(ardAlarmTube);
                     if (aat > 0) {
                         log.debug("tube鍏ュ簱鎴愬姛锛�" + ardAlarmTube);
-                        //寮曞褰曞儚
-                        CameraCmd cmd = new CameraCmd();
-                        cmd.setRecordBucketName("record");
-                        cmd.setRecordObjectName("tube");
-                        cmd.setOperator("sys_tube_leak");
-                        cmd.setExpired(30);
-                        cmd.setTargetPosition(new double[]{ardAlarmTube.getLongitude(), ardAlarmTube.getLatitude(), ardAlarmTube.getAltitude()});
-                        boolean res = guideCamera(cmd);
-                        if (res) {
-                            String url = alarmToRecord(cmd);
-                            if (StringUtils.isNotEmpty(url)) {
-                                //鏇存柊褰曞儚
-                                ardAlarmTube.setRecordUrl(url);
-                                ardAlarmTubeMapper.updateArdAlarmTube(ardAlarmTube);
-                            }
+                        String nearbyCamera = getNearbyCamera(new double[]{ardAlarmTube.getLongitude(), ardAlarmTube.getLatitude()});
+                        if(StringUtils.isNotEmpty(nearbyCamera)) {
+                            addTaskQueue(nearbyCamera, ardAlarmTube.getId(), "sys_tube_leak", ardAlarmTube.getAlarmTime(), 1);
                         }
                     }
                     //endregion
@@ -299,25 +268,30 @@
                     //region 澶勭悊閫氱敤鍏夌數鎶ヨ
                     ArdAlarmCamera ardAlarmCamera = JSONObject.parseObject(message, ArdAlarmCamera.class);
                     ardAlarmCamera.setId(IdUtils.simpleUUID());
+
                     int aac = ardAlarmCameraMapper.insertArdAlarmCamera(ardAlarmCamera);
                     if (aac > 0) {
                         log.debug("camera鍏ュ簱鎴愬姛锛�" + ardAlarmCamera);
-                        //寮曞褰曞儚
-                        CameraCmd cmd = new CameraCmd();
-                        cmd.setRecordBucketName("record");
-                        cmd.setRecordObjectName("camera");
-                        cmd.setOperator("sys_camera");
-                        cmd.setExpired(30);
-                        cmd.setTargetPosition(new double[]{ardAlarmCamera.getLongitude(), ardAlarmCamera.getLatitude()});
-                        boolean res = guideCamera(cmd);
-                        if (res) {
-                            String url = alarmToRecord(cmd);
-                            if (StringUtils.isNotEmpty(url)) {
-                                //鏇存柊褰曞儚
-                                ardAlarmCamera.setRecordUrl(url);
-                                ardAlarmCameraMapper.updateArdAlarmCamera(ardAlarmCamera);
-                            }
+                        String nearbyCamera = getNearbyCamera(new double[]{ardAlarmCamera.getLongitude(), ardAlarmCamera.getLatitude()});
+                        if(StringUtils.isNotEmpty(nearbyCamera)) {
+                            addTaskQueue(nearbyCamera, ardAlarmCamera.getId(), "sys_camera", ardAlarmCamera.getAlarmTime(), 1);
                         }
+                        //寮曞褰曞儚
+//                        CameraCmd cmd = new CameraCmd();
+//                        cmd.setRecordBucketName("record");
+//                        cmd.setRecordObjectName("camera");
+//                        cmd.setOperator("sys_camera");
+//                        cmd.setExpired(30);
+//                        cmd.setTargetPosition(new double[]{ardAlarmCamera.getLongitude(), ardAlarmCamera.getLatitude()});
+//                        boolean res = guideCamera(cmd);
+//                        if (res) {
+//                            String url = alarmToRecord(cmd);
+//                            if (StringUtils.isNotEmpty(url)) {
+//                                //鏇存柊褰曞儚
+//                                ardAlarmCamera.setRecordUrl(url);
+//                                ardAlarmCameraMapper.updateArdAlarmCamera(ardAlarmCamera);
+//                            }
+//                        }
                     }
                     //endregion
                     break;
@@ -325,35 +299,142 @@
                     //region 澶勭悊闆疯揪鎶ヨ
                     RadarAlarmData radarAlarmData = JSONObject.parseObject(message, RadarAlarmData.class);
                     List<ArdAlarmRadar> ardAlarmRadars = radarAlarmData.getArdAlarmRadars();
-                    Map<String, Object> readyGuide = new HashMap<>();
                     for (ArdAlarmRadar ardAlarmRadar : ardAlarmRadars) {
-                        ardAlarmRadar.setId(IdUtils.simpleUUID());
+                        String uuid = IdUtils.simpleUUID();
+                        ardAlarmRadar.setId(uuid);
                         ardAlarmRadar.setAlarmTime(radarAlarmData.getAlarmTime());
-                        int aar = ardAlarmRadarMapper.insertArdAlarmRadar(ardAlarmRadar);
-                        if (aar > 0) {
-                            log.debug("radar鍏ュ簱鎴愬姛锛�" + ardAlarmRadar);
+                        String name = ardAlarmRadar.getName() + "(" + radarAlarmData.getRadarName() + ")";
+                        ardAlarmRadar.setName(name);
+                        ardAlarmRadar.setCreateTime(new Date());
+                        String alarmType = "";
+                        switch (ardAlarmRadar.getAlarmType()) {
+                            case "杩愬姩鐩爣妫�娴�":
+                                alarmType = "sys_radar_move";
+                                break;
+                            case "鐑簮妫�娴�":
+                                alarmType = "sys_radar_fire";
+                                break;
                         }
-                        readyGuide.put(ardAlarmRadar.getName(), ardAlarmRadar);//姣忎釜鎶ヨ鐐瑰彇鍑轰竴鏉℃姤璀�
+                        //鍒ゆ柇褰撳墠鎶ヨ鐐�5鍒嗛挓鍐呮槸鍚﹀凡寮曞
+                        ardAlarmRadar.setGuideFlag(1);
+                        ArdAlarmRadar AlarmRadar = ardAlarmRadarMapper.getArdAlarmRadarWithGuide(ardAlarmRadar);
+                        if (StringUtils.isNull(AlarmRadar)) {
+                            //5鍒嗛挓鍐呮湭寮曞鐩存帴鍏ュ簱
+                            ardAlarmRadarMapper.insertArdAlarmRadar(ardAlarmRadar);
+                            //鑾峰彇闆疯揪鎵�鍦ㄥ涓婄殑澶у厜鐢�
+                            String cameraIdWithTower = ardAlarmRadarMapper.getCameraByRadar(radarAlarmData.getRadarId());
+                            if (StringUtils.isNotNull(cameraIdWithTower) && StringUtils.isNotEmpty(cameraIdWithTower)) {
+                                //鍏ラ槦鍒楀緟寮曞
+                                addTaskQueue(cameraIdWithTower, uuid, alarmType, ardAlarmRadar.getAlarmTime(), 1);
+                            }
+                        } else {
+                            //5鍒嗛挓鍐呮湁寮曞
+                            ardAlarmRadar.setGuideFlag(0);
+                            int count = ardAlarmRadarMapper.getArdAlarmRadarWithNotGuide(ardAlarmRadar, AlarmRadar.getCreateTime());
+                            if (count >= 3) {
+                                //鏈紩瀵艰秴杩�3娆★紝鐩存帴鍏ュ簱鍏ラ槦
+                                //5鍒嗛挓鍐呮湭寮曞鐩存帴鍏ュ簱
+                                ardAlarmRadar.setGuideFlag(1);
+                                ardAlarmRadarMapper.insertArdAlarmRadar(ardAlarmRadar);
+                                //鍏ラ槦鍒楀緟寮曞
+                                //鑾峰彇闆疯揪鎵�鍦ㄥ涓婄殑澶у厜鐢�
+                                String cameraIdWithTower = ardAlarmRadarMapper.getCameraByRadar(radarAlarmData.getRadarId());
+                                if (StringUtils.isNotNull(cameraIdWithTower) && StringUtils.isNotEmpty(cameraIdWithTower)) {
+                                    //濡傛灉闆疯揪濉斾笂鏈夊厜鐢�
+                                    addTaskQueue(cameraIdWithTower, uuid, alarmType, ardAlarmRadar.getAlarmTime(), count);
+                                }
+                            } else {
+                                //鏈紩瀵兼湭瓒呰繃3娆★紝鐩存帴鍏ュ簱
+                                ardAlarmRadarMapper.insertArdAlarmRadar(ardAlarmRadar);
+                            }
+
+                        }
+
+
+                        //鑾峰彇鍏磋叮鐐瑰叧鑱旂殑澶у厜鐢�
+//                            ArdAlarmpointsWell well=new ArdAlarmpointsWell();
+//                            well.setWellId(ardAlarmRadar.getName());
+//                            List<ArdAlarmpointsWell> ardAlarmpointsWells = ardAlarmpointsWellMapper.selectArdAlarmpointsWellList(well);
+//                            if(ardAlarmpointsWells!=null&&ardAlarmpointsWells.size()>0)
+//                            {
+//                                String cameraIdWithWell = ardAlarmpointsWells.get(0).getCameraId();
+//                            }
+
                     }
-                    //鑾峰彇姣忎釜鎶ヨ鐐瑰叧鑱旂殑鐩告満
-
-                    //鍏堟壘鎶ヨ闆疯揪濉斾笂鐨勭浉鏈�
-                    CameraCmd cmd = new CameraCmd();
-                    cmd.setCameraId("1");
-                    cmd.setChannelNum(1);
-                    boolean b = guideCamera(cmd);
-
-                    //鍐嶆壘鎶ヨ鐐瑰叧鑱旂殑鐩告満
-                    cmd.setCameraId("2");
-                    cmd.setChannelNum(1);
-                    boolean b1 = guideCamera(cmd);
-
+                    printPriorityQueue();
                     //endregion
                     break;
             }
+            printPriorityQueue();
         } catch (Exception ex) {
             log.error("鎺ユ敹鎶ヨ寮傚父:" + ex.getMessage());
         }
+    }
+
+    /**
+     * 寮曞浠诲姟鍏ラ槦鏂规硶
+     */
+    private void addTaskQueue(String cameraId, String alarmId, String alarmType, Date alarmTime, Integer num) {
+
+        GuideTask guideTask = new GuideTask();
+        guideTask.setCameraId(cameraId);
+        guideTask.setAlarmId(alarmId);
+        SimpleDateFormat fmt = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+        guideTask.setAlarmTime(fmt.format(alarmTime));
+        Integer priority = CamPriority.priorityMap.get(alarmType);
+        guideTask.setPriority(priority);
+        guideTask.setNum(num);
+
+        PriorityQueue<GuideTask> priorityQueue = GuidePriorityQueue.cameraQueueMap.get(guideTask.getCameraId());
+        priorityQueue.add(guideTask);
+    }
+
+    /**
+     * 鎵撳嵃闃熷垪
+     */
+    private void printPriorityQueue() {
+        for (String cameraId : GuidePriorityQueue.cameraQueueMap.keySet()) {
+            log.info("cameraId" + cameraId);
+            PriorityQueue<GuideTask> priorityQueue = GuidePriorityQueue.cameraQueueMap.get(cameraId);
+            for (GuideTask task : priorityQueue) {
+                log.info("alarmId:" + task.getAlarmId() + "  alarmTime:" + task.getAlarmTime() + "  priority:" + task.getPriority() + "  num:" + task.getNum() + "  cameraId:" + task.getCameraId());
+            }
+
+        }
+    }
+
+    /**
+     * 鏌ユ壘闄勮繎寮�鍚姤璀﹀紩瀵煎姛鑳藉厜鐢�
+     */
+    private String getNearbyCamera(double[] targetPosition) {
+        String minDistanceCameraId = "";
+        //鑾峰彇鎵�鏈夊ぇ鍏夌數
+        List<ArdCameras> ardCamerasList = ardCamerasMapper.selectArdCamerasList(new ArdCameras("1"));
+        //缁熻鎵�鏈夊ぇ鍏夌數鍙鑼冨洿鍐呬笌鎶ヨ鐐圭殑璺濈
+        Map<String, Double> distanceMap = new HashMap<>();
+        Map<String, Integer> guideMap = new HashMap<>();
+        for (ArdCameras camera : ardCamerasList) {
+            double[] camPosition = new double[]{camera.getLongitude(), camera.getLatitude()};
+            double distance = GisTool.getDistance(targetPosition, camPosition);
+            if (distance != 0.0 && distance <= camera.getCamMaxVisibleDistance()) {
+                distanceMap.put(camera.getId(), distance);
+                if (StringUtils.isNull(camera.getCamAlarmGuideEnable())) {
+                    camera.setCamAlarmGuideEnable(0);
+                }
+                guideMap.put(camera.getId(), camera.getCamAlarmGuideEnable());
+            }
+        }
+        if (distanceMap.size() > 0) {
+            log.debug("灏濊瘯鏌ユ壘鏈�杩戝厜鐢�");
+            //鑾峰彇璺濈瀛楀吀涓渶杩戠殑涓�涓浉鏈篒D
+            minDistanceCameraId = ArdTool.getKeyByMinValue(distanceMap);
+            log.debug("鏌ユ壘鍒版渶杩戝厜鐢�:" + minDistanceCameraId);
+            if (guideMap.get(minDistanceCameraId).equals(0)) {
+                log.debug("璇ュ厜鐢垫湭寮�鍚姤璀﹀紩瀵�");
+                return " ";
+            }
+        }
+        return minDistanceCameraId;
     }
 
     /**
@@ -367,45 +448,23 @@
     private boolean guideCamera(CameraCmd cmd) {
         try {
             String dayNightTime = redisCache.getCacheObject("sys_config:dayNightTime");
-            //鑾峰彇鎵�鏈夊ぇ鍏夌數
-            List<ArdCameras> ardCamerasList = ardCamerasMapper.selectArdCamerasList(new ArdCameras("1"));
-            //缁熻鎵�鏈夊ぇ鍏夌數鍙鑼冨洿鍐呬笌鎶ヨ鐐圭殑璺濈
-            Map<String, Double> distanceMap = new HashMap<>();
-            Map<String, Integer> guideMap = new HashMap<>();
-            for (ArdCameras camera : ardCamerasList) {
-                double[] camPosition = new double[]{camera.getLongitude(), camera.getLatitude()};
-                double distance = GisTool.getDistance(cmd.getTargetPosition(), camPosition);
-                if (distance != 0.0 && distance <= camera.getCamMaxVisibleDistance()) {
-                    distanceMap.put(camera.getId(), distance);
-                    if (StringUtils.isNull(camera.getCamAlarmGuideEnable())) {
-                        camera.setCamAlarmGuideEnable(0);
-                    }
-                    guideMap.put(camera.getId(), camera.getCamAlarmGuideEnable());
-                }
-            }
-            if (distanceMap.size() > 0) {
-                log.debug("灏濊瘯鏌ユ壘鏈�杩戝厜鐢�");
-                //鑾峰彇璺濈瀛楀吀涓渶杩戠殑涓�涓浉鏈篒D
-                String minDistanceCameraId = ArdTool.getKeyByMinValue(distanceMap);
-                log.debug("鏌ユ壘鍒版渶杩戝厜鐢�:" + minDistanceCameraId + "锛屽皾璇曞紩瀵�");
-                if (guideMap.get(minDistanceCameraId).equals(0)) {
-                    log.debug("璇ュ厜鐢垫湭寮�鍚姤璀﹀紩瀵�");
-                    return false;
-                }
+            String nearbyCamera = getNearbyCamera(cmd.getTargetPosition());
+            if (StringUtils.isNotEmpty(nearbyCamera)) {
                 //寮曞鍏夌數
-                cmd.setCameraId(minDistanceCameraId);
+                cmd.setCameraId(nearbyCamera);
                 cmd.setChannelNum(ArdTool.getChannelBydayNightTime(dayNightTime));
                 boolean guideRes = hikClientService.guideTargetPosition(cmd);
                 return guideRes;
-
             } else {
                 log.debug("鏈煡鎵惧埌鏈�杩戝厜鐢�");
                 return false;
             }
-        } catch (Exception ex) {
+        } catch (
+                Exception ex) {
             log.error("寮曞寮傚父:" + ex.getMessage());
             return false;
         }
+
     }
 
     /**
diff --git a/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/PriorityQueueExample.java b/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/PriorityQueueExample.java
deleted file mode 100644
index fa468d4..0000000
--- a/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/PriorityQueueExample.java
+++ /dev/null
@@ -1,42 +0,0 @@
-package com.ruoyi.alarm.globalAlarm.service.impl;
-import com.ruoyi.alarm.globalAlarm.domain.GuidePriorityQueue;
-import java.util.Comparator;
-import java.util.PriorityQueue;
-/**
- * @Description:
- * @ClassName: PriorityQueueExample
- * @Author: 鍒樿嫃涔�
- * @Date: 2023骞�06鏈�29鏃�10:41
- * @Version: 1.0
- **/
-
-public class PriorityQueueExample {
-    public static void main(String[] args) {
-
-        Comparator<GuideTask> comparator = GuidePriorityQueue.getComparator();
-        // 鍒涘缓鐩告満1鐨勪紭鍏堢骇闃熷垪锛屽苟浼犲叆鑷畾涔夌殑姣旇緝鍣�
-        PriorityQueue<GuideTask> queue1 = new PriorityQueue<>(comparator);
-        // 娣诲姞瀵硅薄鍒伴槦鍒椾腑
-        GuideTask task1 = new GuideTask("task1", "radar", 999, "2023-06-29 11:10:00", 1);
-        GuideTask task2 = new GuideTask("task2", "radar", 999, "2023-06-29 11:11:00", 2);
-        GuideTask task3 = new GuideTask("task3", "radar", 999, "2023-06-29 11:12:00", 1);
-        GuideTask task4 = new GuideTask("task4", "radar", 888, "2023-06-29 11:13:00", 3);
-        queue1.add(task1);
-        queue1.add(task2);
-        queue1.add(task3);
-        queue1.add(task4);
-
-
-        GuidePriorityQueue.cameraQueueMap.put("鐩告満1", queue1);
-
-        for (String camera :  GuidePriorityQueue.cameraQueueMap.keySet()) {
-            PriorityQueue<GuideTask> queue =  GuidePriorityQueue.cameraQueueMap.get(camera);
-
-            // 渚濇鍙栧嚭闃熷垪涓殑瀵硅薄骞舵墦鍗�
-            while (!queue.isEmpty()) {
-                GuideTask obj = queue.poll();
-                System.out.println(obj.getAlarmId() + " - Priority: " + obj.getPriority() + "- Num:" + obj.getNum() + "- time-" + obj.getAlarmTime());
-            }
-        }
-    }
-}
diff --git a/ard-work/src/main/java/com/ruoyi/alarm/radarAlarm/domain/ArdAlarmRadar.java b/ard-work/src/main/java/com/ruoyi/alarm/radarAlarm/domain/ArdAlarmRadar.java
index c41e78d..2a92045 100644
--- a/ard-work/src/main/java/com/ruoyi/alarm/radarAlarm/domain/ArdAlarmRadar.java
+++ b/ard-work/src/main/java/com/ruoyi/alarm/radarAlarm/domain/ArdAlarmRadar.java
@@ -69,7 +69,8 @@
      * 鏈鎶ヨ鏁伴噺
      */
     private Integer count;
-
-
-
+    /**
+     * 寮曞鏍囪
+     */
+    private  Integer guideFlag;
 }
diff --git a/ard-work/src/main/java/com/ruoyi/alarm/radarAlarm/domain/RadarAlarmData.java b/ard-work/src/main/java/com/ruoyi/alarm/radarAlarm/domain/RadarAlarmData.java
index 2d8da84..3fa809d 100644
--- a/ard-work/src/main/java/com/ruoyi/alarm/radarAlarm/domain/RadarAlarmData.java
+++ b/ard-work/src/main/java/com/ruoyi/alarm/radarAlarm/domain/RadarAlarmData.java
@@ -17,11 +17,14 @@
 @Data
 public class RadarAlarmData {
 
+    /** 闆疯揪id */
+    private String radarId;
+    /** 闆疯揪鍚嶇О*/
+    private String radarName;
     /** 鎶ヨ鏃堕棿 */
     @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
     @Excel(name = "鎶ヨ鏃堕棿", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
     private Date alarmTime;
-
     private List<ArdAlarmRadar> ardAlarmRadars;
 
 }
diff --git a/ard-work/src/main/java/com/ruoyi/alarm/radarAlarm/mapper/ArdAlarmRadarMapper.java b/ard-work/src/main/java/com/ruoyi/alarm/radarAlarm/mapper/ArdAlarmRadarMapper.java
index 5f6d460..ae971ad 100644
--- a/ard-work/src/main/java/com/ruoyi/alarm/radarAlarm/mapper/ArdAlarmRadarMapper.java
+++ b/ard-work/src/main/java/com/ruoyi/alarm/radarAlarm/mapper/ArdAlarmRadarMapper.java
@@ -2,6 +2,8 @@
 
 import com.ruoyi.alarm.radarAlarm.domain.ArdAlarmRadar;
 import org.apache.ibatis.annotations.Param;
+
+import java.util.Date;
 import java.util.List;
 
 
@@ -63,4 +65,17 @@
 
     public List<ArdAlarmRadar> selectListAllByCommand(@Param("refreshTime")String refreshTime,@Param("alarmType")String alarmType);
     int selectCountByAlarmTime(@Param("refreshTime")String refreshTime,@Param("alarmType")String alarmType);
+
+    /**
+     * 閫氳繃闆疯揪id鎵惧埌鍏宠仈濉斾笂鐨勫ぇ鍏夌數id
+     *
+     */
+     String getCameraByRadar(String radarId);
+
+     /**
+      *  鏌ユ壘5鍒嗛挓鍐呭紩瀵艰繃鐨勮褰�
+      * */
+     public ArdAlarmRadar getArdAlarmRadarWithGuide(ArdAlarmRadar ardAlarmRadar);
+
+     public int getArdAlarmRadarWithNotGuide(@Param("ardAlarmRadar")ArdAlarmRadar ardAlarmRadar, @Param("guideTime")Date guideTime);
 }
diff --git a/ard-work/src/main/java/com/ruoyi/constant/CamPriority.java b/ard-work/src/main/java/com/ruoyi/constant/CamPriority.java
index 6ccff29..a9315b5 100644
--- a/ard-work/src/main/java/com/ruoyi/constant/CamPriority.java
+++ b/ard-work/src/main/java/com/ruoyi/constant/CamPriority.java
@@ -1,10 +1,7 @@
 package com.ruoyi.constant;
 
-import com.ruoyi.alarm.globalAlarm.service.impl.GuideTask;
-
 import java.util.HashMap;
 import java.util.Map;
-import java.util.PriorityQueue;
 
 /**
  * @Description: 鐩告満鎺у埗浼樺厛绾�
@@ -15,9 +12,10 @@
  **/
 public class CamPriority {
 
-    public static Map<String,Object> priorityMap=new HashMap<>();
+    public static Map<String,Integer> priorityMap=new HashMap<>();
     static {
         priorityMap.put("sys_radar_fire",999);//闆疯揪闃茬伀鎶ヨ
+        priorityMap.put("sys_radar_move",999);//闆疯揪绉诲姩鎶ヨ
         priorityMap.put("sys_tube_leak",998);//绠$嚎娉勯湶鎶ヨ
         priorityMap.put("sys_camera",997);//閫氱敤鍏夌數鎶ヨ
         priorityMap.put("sys_steal_elec",996);//鐩楃數鎶ヨ
diff --git a/ard-work/src/main/java/com/ruoyi/device/hiksdk/service/impl/HikClientServiceImpl.java b/ard-work/src/main/java/com/ruoyi/device/hiksdk/service/impl/HikClientServiceImpl.java
index d7295fc..9a5e8ed 100644
--- a/ard-work/src/main/java/com/ruoyi/device/hiksdk/service/impl/HikClientServiceImpl.java
+++ b/ard-work/src/main/java/com/ruoyi/device/hiksdk/service/impl/HikClientServiceImpl.java
@@ -210,7 +210,7 @@
             log.debug("鍔犺浇lib瀹屾垚锛�");
             List<ArdCameras> ardCameras = ardCamerasMapper.selectArdCamerasListNoDataScope(new ArdCameras());
             for (ArdCameras camera : ardCameras) {
-                Thread.sleep(100);
+                Thread.sleep(500);
                 login(camera);
             }
         } catch (Exception ex) {
diff --git a/ard-work/src/main/java/com/ruoyi/device/hiksdk/util/hikSdkUtil/LoginResultCallBack.java b/ard-work/src/main/java/com/ruoyi/device/hiksdk/util/hikSdkUtil/LoginResultCallBack.java
index b3c34c7..a4d1d6c 100644
--- a/ard-work/src/main/java/com/ruoyi/device/hiksdk/util/hikSdkUtil/LoginResultCallBack.java
+++ b/ard-work/src/main/java/com/ruoyi/device/hiksdk/util/hikSdkUtil/LoginResultCallBack.java
@@ -1,5 +1,7 @@
 package com.ruoyi.device.hiksdk.util.hikSdkUtil;
 
+import com.ruoyi.alarm.globalAlarm.domain.GuidePriorityQueue;
+import com.ruoyi.alarm.globalAlarm.domain.GuideTask;
 import com.ruoyi.common.utils.spring.SpringUtils;
 import com.ruoyi.device.camera.domain.ArdCameras;
 import com.ruoyi.device.camera.mapper.ArdCamerasMapper;
@@ -9,6 +11,8 @@
 import org.springframework.stereotype.Component;
 
 import javax.annotation.Resource;
+import java.util.Comparator;
+import java.util.PriorityQueue;
 
 /**
  * @Description: 寮傛鐧诲綍鍥炶皟
@@ -35,6 +39,10 @@
             log.info(camera.getIp() + ":" + camera.getPort() + "鐧诲綍鎴愬姛");
             camera.setLoginId(lUserID);
             camera.setChannel((int) lpDeviceinfo.byChanNum);
+            //鍒涘缓寮曞闃熷垪
+            Comparator<GuideTask> comparator = GuidePriorityQueue.getComparator();
+            PriorityQueue<GuideTask> priorityQueue=new PriorityQueue<>(comparator);
+            GuidePriorityQueue.cameraQueueMap.put(camera.getId(),priorityQueue);
         } else {
             log.info(camera.getIp() + ":" + camera.getPort() + "鐧诲綍澶辫触");
             camera.setChannel(0);
diff --git a/ard-work/src/main/resources/mapper/alarm/ArdAlarmRadarMapper.xml b/ard-work/src/main/resources/mapper/alarm/ArdAlarmRadarMapper.xml
index 1a98bc8..3068afe 100644
--- a/ard-work/src/main/resources/mapper/alarm/ArdAlarmRadarMapper.xml
+++ b/ard-work/src/main/resources/mapper/alarm/ArdAlarmRadarMapper.xml
@@ -63,6 +63,7 @@
             <if test="createTime != null">create_time,</if>
             <if test="userId != null">user_id,</if>
             <if test="deptId != null">dept_id,</if>
+            <if test="guideFlag != null">guide_flag,</if>
         </trim>
         <trim prefix="values (" suffix=")" suffixOverrides=",">
             <if test="id != null">#{id},</if>
@@ -77,6 +78,7 @@
             <if test="createTime != null">#{createTime},</if>
             <if test="userId != null">#{userId},</if>
             <if test="deptId != null">#{deptId},</if>
+            <if test="guideFlag != null">#{guideFlag},</if>
         </trim>
     </insert>
 
@@ -94,6 +96,7 @@
             <if test="createTime != null">create_time = #{createTime},</if>
             <if test="userId != null">user_id = #{userId},</if>
             <if test="deptId != null">dept_id = #{deptId},</if>
+            <if test="guideFlag != null">guide_flag = #{guideFlag},</if>
         </trim>
         where id = #{id}
     </update>
@@ -140,4 +143,28 @@
         WHERE aar.alarm_time >= CURRENT_TIMESTAMP - INTERVAL '%${refreshTime}%' MINUTE
           and aar.alarm_type = #{alarmType}
     </select>
+    <select id="getCameraByRadar" resultType="String">
+        select ac.id
+        from ard_equip_radar aer
+                 INNER JOIN ard_towers at
+        on aer.tower_id= at.id
+            INNER JOIN ard_cameras ac on aer.tower_id=ac.tower_id
+    </select>
+    <select id="getArdAlarmRadarWithGuide" resultMap="ArdAlarmRadarResult">
+        select *
+        from ard_alarm_radar
+        where create_time > current_timestamp - interval '5' minute
+          and guide_flag = #{guideFlag}
+          and alarm_type =#{alarmType}
+          and name = #{name}
+        ORDER BY create_time desc  limit 1
+    </select>
+    <select id="getArdAlarmRadarWithNotGuide" resultType="Integer">
+        select count(*)
+        from ard_alarm_radar
+        where create_time >= #{guideTime}
+          and guide_flag = #{ardAlarmRadar.guideFlag}
+          and alarm_type =#{ardAlarmRadar.alarmType}
+          and name = #{ardAlarmRadar.name}
+    </select>
 </mapper>
\ No newline at end of file
diff --git a/ruoyi-common/src/main/java/com/ruoyi/common/utils/DateUtils.java b/ruoyi-common/src/main/java/com/ruoyi/common/utils/DateUtils.java
index e2bec71..00f2c57 100644
--- a/ruoyi-common/src/main/java/com/ruoyi/common/utils/DateUtils.java
+++ b/ruoyi-common/src/main/java/com/ruoyi/common/utils/DateUtils.java
@@ -27,6 +27,7 @@
     public static String YYYYMMDDHHMMSS = "yyyyMMddHHmmss";
 
     public static String YYYY_MM_DD_HH_MM_SS = "yyyy-MM-dd HH:mm:ss";
+    public static String YYYY_MM_DD_HH_MM_SS_MS = "yyyy-MM-dd HH:mm:ss.fff";
     public static String HH_MM_SS = "HH:mm:ss";
 
     private static String[] parsePatterns = {
@@ -58,12 +59,14 @@
     {
         return dateTimeNow(YYYY_MM_DD_HH_MM_SS);
     }
-
     public static final String dateTimeNow()
     {
         return dateTimeNow(YYYYMMDDHHMMSS);
     }
-
+    public static final String dateTimeNowMS()
+    {
+        return dateTimeNow(YYYY_MM_DD_HH_MM_SS_MS);
+    }
     public static final String dateTimeNow(final String format)
     {
         return parseDateToStr(format, new Date());
diff --git a/ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/SdkTask.java b/ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/SdkTask.java
index 00e9fc9..674c5bd 100644
--- a/ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/SdkTask.java
+++ b/ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/SdkTask.java
@@ -1,5 +1,6 @@
 package com.ruoyi.quartz.task;
 
+import com.ruoyi.common.utils.StringUtils;
 import com.ruoyi.common.utils.spring.SpringUtils;
 import com.ruoyi.common.websocket.util.WebSocketUtils;
 import com.ruoyi.device.camera.domain.ArdCameras;
@@ -46,6 +47,10 @@
             cmd.setCameraId(camera.getId());
             cmd.setChannelNum(1);
             Map<String, Object> ptz = hikClientService.getPtz(cmd);
+            if(StringUtils.isNull(ptz))
+            {
+                continue;
+            }
             if (ptz.size() > 0) {
                 ptz.put("cameraId", camera.getId());
                 ptz.put("operatorExpired",camera.getOperatorExpired());

--
Gitblit v1.9.3