From a244194128df25b5d94cd1ee61e5e0a5e0c8ffd9 Mon Sep 17 00:00:00 2001
From: ‘liusuyi’ <1951119284@qq.com>
Date: 星期五, 30 六月 2023 15:31:54 +0800
Subject: [PATCH] 增加ptz解锁接口

---
 ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/domain/GuideTask.java                    |   16 ++
 ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/GlobalAlarmServiceImpl.java |  145 ++++++++++------------------
 ard-work/src/main/java/com/ruoyi/device/hiksdk/controller/SdkController.java                |   10 +
 ard-work/src/main/java/com/ruoyi/device/hiksdk/service/impl/HikClientServiceImpl.java       |   25 +++++
 ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/QueueManager.java           |    9 +
 ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/QueueTaskExecutor.java      |    7 +
 ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/domain/GuidePriorityQueue.java           |   55 +++++++++-
 ard-work/src/main/java/com/ruoyi/device/hiksdk/service/IHikClientService.java               |    3 
 ard-work/src/main/resources/mapper/alarm/ArdAlarmRadarMapper.xml                            |    2 
 9 files changed, 166 insertions(+), 106 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 1ba629f..f6036a4 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,11 +1,12 @@
 package com.ruoyi.alarm.globalAlarm.domain;
 
+import lombok.AllArgsConstructor;
+import lombok.Data;
 import lombok.extern.slf4j.Slf4j;
 
-import java.util.Comparator;
-import java.util.HashMap;
-import java.util.Map;
-import java.util.PriorityQueue;
+import java.time.LocalDateTime;
+import java.time.format.DateTimeFormatter;
+import java.util.*;
 import java.util.concurrent.PriorityBlockingQueue;
 
 /**
@@ -28,8 +29,8 @@
     public static Comparator<GuideTask> getComparator() {
         Comparator<GuideTask> PriorityDescCom = Comparator.comparingInt(GuideTask::getPriority).reversed();
         Comparator<GuideTask> NumDescCom = Comparator.comparingInt(GuideTask::getNum).reversed();
-        Comparator<GuideTask> alarmTimeAscCom = Comparator.comparing(GuideTask::getAlarmTime);
-        Comparator<GuideTask> Comparator = PriorityDescCom.thenComparing(NumDescCom).thenComparing(alarmTimeAscCom);
+        Comparator<GuideTask> receiveTimeAscCom = Comparator.comparing(GuideTask::getReceiveTime);
+        Comparator<GuideTask> Comparator = PriorityDescCom.thenComparing(NumDescCom).thenComparing(receiveTimeAscCom);
         return Comparator;
     }
 
@@ -39,9 +40,47 @@
     public static void printPriorityQueue() {
         for (String cameraId : GuidePriorityQueue.cameraQueueMap.keySet()) {
             PriorityBlockingQueue<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());
+//            for (GuideTask task : priorityQueue) {
+//
+//                log.info("銆恆larmId銆�" + task.getAlarmId() + "銆恟eceiveTime銆�" + task.getReceiveTime()
+//                        + "銆恜riority銆�" + task.getPriority() + "銆恘um銆�" + task.getNum()
+//                        + "銆恈han銆�" + task.getChanNum() + "銆恟ecordSn銆�" + task.getRecordSn() + "銆恈ameraId銆�" + task.getCameraId());
+//            }
+            while (priorityQueue.size() > 0) {
+                GuideTask task = priorityQueue.poll();
+                log.info("銆恆larmId銆�" + task.getAlarmId() + "銆恟eceiveTime銆�" + task.getReceiveTime()
+                        + "銆恜riority銆�" + task.getPriority() + "銆恘um銆�" + task.getNum()
+                        + "銆恈han銆�" + task.getChanNum() + "銆恟ecordSn銆�" + task.getRecordSn() + "銆恈ameraId銆�" + task.getCameraId());;
             }
         }
     }
+
+
+    public static void main(String[] args) {
+        Comparator<obj> com1 = Comparator.comparingInt(obj::getNUM1).reversed();
+        Comparator<obj> com2 = Comparator.comparingInt(obj::getNUM2).reversed();
+        Comparator<obj> com3 = Comparator.comparingInt(obj::getNUM3).reversed();
+        Comparator<obj> objComparator = com1.thenComparing(com2).thenComparing(com3);
+        PriorityQueue<obj> priorityQueue = new PriorityQueue<>(objComparator);
+        priorityQueue.add(new obj(1, 1, 65));
+        priorityQueue.add(new obj(1, 4, 21));
+        priorityQueue.add(new obj(1, 4, 33));
+        priorityQueue.add(new obj(1, 4, 44));
+        priorityQueue.add(new obj(1, 4, 51));
+
+        while (priorityQueue.size() > 0) {
+            obj task = priorityQueue.poll();
+            log.info("銆恘um1銆�" + task.getNUM1() + "銆恘um2銆�" + task.getNUM2() + "銆恘um3銆�" + task.getNUM3());
+        }
+        log.info("=======================================================================");
+    }
+
 }
+
+@Data
+@AllArgsConstructor
+class obj {
+    Integer NUM1;
+    Integer NUM2;
+    Integer NUM3;
+}
\ No newline at end of file
diff --git a/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/domain/GuideTask.java b/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/domain/GuideTask.java
index 25f1db5..2e6fade 100644
--- a/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/domain/GuideTask.java
+++ b/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/domain/GuideTask.java
@@ -4,6 +4,8 @@
 import lombok.Data;
 import lombok.NoArgsConstructor;
 
+import java.util.Date;
+
 /**
  * @Description: 寮曞浠诲姟
  * @ClassName: GuideTask
@@ -37,16 +39,24 @@
      */
     Integer priority;
     /**
-     * 鎶ヨ鏃堕棿
+     * 鎺ユ敹鏃堕棿
      */
-    String alarmTime;
+    String receiveTime;
+    /**
+     * 鎺ユ敹鏃堕棿鐨勬绉掑��
+     */
+    Integer receiveMillisecond;
     /**
      * 鎶ヨ娆℃暟
      */
     Integer num;
     /**
-     * 褰曞儚瀛樺偍浣嶇疆
+     * 褰曞儚瀛樺偍浣嶇疆-杩欓噷鏈夌殑鎶ヨ闇�瑕佸紩瀵�2涓浉鏈猴紝鏁呴渶瑕佹寚瀹氬摢涓浉鏈哄綍鍍忓洖鍐欏埌鍝釜瀛楁
      */
     Integer recordSn;
 
+    /**
+     * 寮曞鐩爣缁忕含搴�
+     */
+    double[] targetPosition;
 }
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 b90f567..6097259 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
@@ -48,8 +48,8 @@
 
 
 /**
+ * @Description: 鍏ㄥ眬鎶ヨ涓氬姟
  * @ClassName: globalAlarmServiceImpl
- * @Description:
  * @Author: Administrator
  * @Date: 2023骞�03鏈�10鏃� 11:03
  * @Version: 1.0
@@ -332,6 +332,7 @@
                         ardAlarmTube.setColor(ardTubes.getColor());
                         ardAlarmTube.setPipeDiameter(ardTubes.getPipeDiameter());
                         ardAlarmTube.setTubeType(ardTubes.getType());
+                        ardAlarmTube.setCreateTime(new Date());
                         GeoPoint geoPoint = TubeTools.CalculateCoordinates(ardTubesDetails, ardAlarmTube.getPosition());
                         if (StringUtils.isNotNull(geoPoint)) {
                             ardAlarmTube.setLongitude(geoPoint.getLongitude());
@@ -342,9 +343,10 @@
                     int aat = ardAlarmTubeMapper.insertArdAlarmTube(ardAlarmTube);
                     if (aat > 0) {
                         log.debug("tube鍏ュ簱鎴愬姛锛�" + ardAlarmTube);
-                        String nearbyCamera = getNearbyCamera(new double[]{ardAlarmTube.getLongitude(), ardAlarmTube.getLatitude()});
-                        if (StringUtils.isNotEmpty(nearbyCamera)) {
-                            messagesEnqueued(nearbyCamera, ardAlarmTube.getId(), "sys_tube_leak", ardAlarmTube.getAlarmTime(), 1,1);
+                        double[] coordinate=new double[]{ardAlarmTube.getLongitude(),ardAlarmTube.getLatitude()};
+                        String nearbyCameraId = getNearbyCamera(new double[]{ardAlarmTube.getLongitude(), ardAlarmTube.getLatitude()});
+                        if (StringUtils.isNotEmpty(nearbyCameraId)) {
+                            messagesEnqueued(nearbyCameraId, ardAlarmTube.getId(), "sys_tube_leak",ardAlarmTube.getCreateTime(), 1,1,coordinate);
                         }
                     }
                     //endregion
@@ -366,11 +368,12 @@
                     List<ArdAlarmRadar> ardAlarmRadars = radarAlarmData.getArdAlarmRadars();
                     for (ArdAlarmRadar ardAlarmRadar : ardAlarmRadars) {
                         String uuid = IdUtils.simpleUUID();
-                        ardAlarmRadar.setId(uuid);
-                        ardAlarmRadar.setAlarmTime(radarAlarmData.getAlarmTime());
-                        String name = ardAlarmRadar.getName() + "(" + radarAlarmData.getRadarName() + ")";
-                        ardAlarmRadar.setName(name);
-                        ardAlarmRadar.setCreateTime(new Date());
+                        ardAlarmRadar.setId(uuid);//鎶ヨID
+                        ardAlarmRadar.setAlarmTime(radarAlarmData.getAlarmTime());//鎶ヨ鏃堕棿
+                        String alarmpointName = ardAlarmRadar.getName();//鍏磋叮鐐瑰悕绉�
+                        ardAlarmRadar.setName(ardAlarmRadar.getName() + "(" + radarAlarmData.getRadarName() + ")");//鎶ヨ鐐瑰悕绉�
+                        ardAlarmRadar.setCreateTime(new Date());//鎺ユ敹鏃堕棿
+                        double[] coordinate=new double[]{ardAlarmRadar.getLongitude(),ardAlarmRadar.getLatitude()};//鎶ヨ鍧愭爣
                         String alarmType = "";
                         switch (ardAlarmRadar.getAlarmType()) {
                             case "杩愬姩鐩爣妫�娴�":
@@ -389,8 +392,19 @@
                             //鑾峰彇闆疯揪鎵�鍦ㄥ涓婄殑澶у厜鐢�
                             String cameraIdWithTower = ardAlarmRadarMapper.getCameraByRadar(radarAlarmData.getRadarId());
                             if (StringUtils.isNotNull(cameraIdWithTower) && StringUtils.isNotEmpty(cameraIdWithTower)) {
-                                //鍏ラ槦鍒楀緟寮曞
-                                messagesEnqueued(cameraIdWithTower, uuid, alarmType, ardAlarmRadar.getAlarmTime(), 1,1);
+                                log.info("鑾峰彇鍒伴浄杈惧涓婄殑鍏夌數:"+cameraIdWithTower);
+                                //濡傛灉闆疯揪濉斾笂鏈夊厜鐢�
+                                messagesEnqueued(cameraIdWithTower, uuid, alarmType, ardAlarmRadar.getCreateTime(),1,1,coordinate);
+                            }
+                            //鑾峰彇鎶ヨ鐐瑰叧鑱旂殑澶у厜鐢�
+                            ArdAlarmpointsWell ardAlarmpointsWell = ardAlarmpointsWellMapper.selectArdAlarmpointsWellByWellId(alarmpointName);
+                            if(StringUtils.isNotNull(ardAlarmpointsWell) && StringUtils.isNotEmpty(ardAlarmpointsWell.getCameraId()))
+                            {
+
+                                String cameraId = ardAlarmpointsWell.getCameraId();
+                                log.info("鑾峰彇鍒版姤璀︾偣鍏宠仈鐨勫厜鐢�:"+cameraId);
+                                //濡傛灉鎶ヨ鐐瑰叧鑱斾簡鍏夌數
+                                messagesEnqueued(cameraId, uuid, alarmType,ardAlarmRadar.getCreateTime(), 1,2,coordinate);
                             }
                         } else {
                             //5鍒嗛挓鍐呮湁寮曞
@@ -404,16 +418,18 @@
                                 //鑾峰彇闆疯揪鎵�鍦ㄥ涓婄殑澶у厜鐢�
                                 String cameraIdWithTower = ardAlarmRadarMapper.getCameraByRadar(radarAlarmData.getRadarId());
                                 if (StringUtils.isNotNull(cameraIdWithTower) && StringUtils.isNotEmpty(cameraIdWithTower)) {
+                                    log.info("鑾峰彇鍒伴浄杈惧涓婄殑鍏夌數:"+cameraIdWithTower);
                                     //濡傛灉闆疯揪濉斾笂鏈夊厜鐢�
-                                    messagesEnqueued(cameraIdWithTower, uuid, alarmType, ardAlarmRadar.getAlarmTime(), count,1);
+                                    messagesEnqueued(cameraIdWithTower, uuid, alarmType,ardAlarmRadar.getCreateTime(), count,1,coordinate);
                                 }
                                 //鑾峰彇鎶ヨ鐐瑰叧鑱旂殑澶у厜鐢�
-                                ArdAlarmpointsWell ardAlarmpointsWell = ardAlarmpointsWellMapper.selectArdAlarmpointsWellByWellId(ardAlarmRadar.getName());
+                                ArdAlarmpointsWell ardAlarmpointsWell = ardAlarmpointsWellMapper.selectArdAlarmpointsWellByWellId(alarmpointName);
                                 if(StringUtils.isNotNull(ardAlarmpointsWell) && StringUtils.isNotEmpty(ardAlarmpointsWell.getCameraId()))
                                 {
                                     String cameraId = ardAlarmpointsWell.getCameraId();
+                                    log.info("鑾峰彇鍒版姤璀︾偣鍏宠仈鐨勫厜鐢�:"+cameraId);
                                     //濡傛灉鎶ヨ鐐瑰叧鑱斾簡鍏夌數
-                                    messagesEnqueued(cameraId, uuid, alarmType, ardAlarmRadar.getAlarmTime(), count,1);
+                                    messagesEnqueued(cameraId, uuid, alarmType,ardAlarmRadar.getCreateTime(), count,2,coordinate);
                                 }
                             } else {
                                 //鏈紩瀵兼湭瓒呰繃3娆★紝鐩存帴鍏ュ簱
@@ -430,39 +446,46 @@
         }
     }
 
-
     /**
      * 娑堟伅鍏ラ槦
+     *
+     * cameraId 鐩告満ID
+     * alarmId  鎶ヨID
+     * alarmType 鎶ヨ绫诲瀷
+     * num  鎶ヨ娆℃暟
+     * recordSn 褰曞儚瀛樺偍浣嶇疆 1-recordUrl1 2-recordUrl2
+     * targetPosition 鎶ヨ鐐逛綅缃潗鏍�
      */
-    private void messagesEnqueued(String cameraId, String alarmId, String alarmType, Date alarmTime, Integer num, Integer recordSn) {
-
+    private void messagesEnqueued(String cameraId, String alarmId, String alarmType,Date receiveTime, Integer num, Integer recordSn,double[] targetPosition) {
+        SimpleDateFormat fmt = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
         GuideTask guideTask = new GuideTask();
-        /*閰嶇疆鐩告満ID*/
+        //鐩告満ID
         guideTask.setCameraId(cameraId);
-        /*鏍规嵁閰嶇疆鏃堕棿閰嶇疆閫氶亾*/
+        //鎶ヨ绫诲瀷
+        guideTask.setAlarmType(alarmType);
+        //閫氶亾(閫氳繃鏃ュ鏃堕棿鐮斿垽)
         String dayNightTime = redisCache.getCacheObject("sys_config:dayNightTime");
         Integer channel = ArdTool.getChannelBydayNightTime(dayNightTime);
         guideTask.setChanNum(channel);
-        /*閰嶇疆鎶ヨID*/
+        //鎶ヨID
         guideTask.setAlarmId(alarmId);
-        /*閰嶇疆鎶ヨ鏃堕棿*/
-        SimpleDateFormat fmt = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
-        guideTask.setAlarmTime(fmt.format(alarmTime));
-        /*閰嶇疆鎶ヨ浼樺厛绾�*/
+        //鎺ユ敹鏃堕棿
+        guideTask.setReceiveTime(fmt.format(receiveTime));
+        //鎶ヨ浼樺厛绾�(閫氳繃浼樺厛绾у瓧鍏�)
         Integer priority = CamPriority.priorityMap.get(alarmType);
         guideTask.setPriority(priority);
-        /*閰嶇疆鎶ヨ娆℃暟*/
+        //鎶ヨ娆℃暟
         guideTask.setNum(num);
-        /*閰嶇疆褰曞儚瀛樺偍浣嶇疆*/
+        //褰曞儚瀛樺偍浣嶇疆
         guideTask.setRecordSn(recordSn);
-        /*娑堟伅鍏ラ槦*/
+        //鐩爣缁忕含搴�
+        guideTask.setTargetPosition(targetPosition);
+        //娑堟伅鍏ラ槦
         queueManager.addTaskToQueue(cameraId, guideTask);
-//        PriorityBlockingQueue<GuideTask> priorityBlockingQueue = GuidePriorityQueue.cameraQueueMap.get(guideTask.getCameraId());
-//        priorityBlockingQueue.add(guideTask);
     }
 
     /**
-     * 鏌ユ壘闄勮繎寮�鍚姤璀﹀紩瀵煎姛鑳藉厜鐢�
+     * 鑾峰彇闄勮繎寮�鍚姤璀﹀紩瀵煎姛鑳藉厜鐢�
      */
     private String getNearbyCamera(double[] targetPosition) {
         String minDistanceCameraId = "";
@@ -493,68 +516,6 @@
             }
         }
         return minDistanceCameraId;
-    }
-
-    /**
-     * @鎻忚堪 寮曞鏈�杩戠殑澶у厜鐢垫寚鍚戠洰鏍�
-     * @鍙傛暟 [cmd]
-     * @杩斿洖鍊� boolean
-     * @鍒涘缓浜� 鍒樿嫃涔�
-     * @鍒涘缓鏃堕棿 2023/6/28 16:34
-     * @淇敼浜哄拰鍏跺畠淇℃伅
-     */
-    private boolean guideCamera(CameraCmd cmd) {
-        try {
-            String dayNightTime = redisCache.getCacheObject("sys_config:dayNightTime");
-            String nearbyCamera = getNearbyCamera(cmd.getTargetPosition());
-            if (StringUtils.isNotEmpty(nearbyCamera)) {
-                //寮曞鍏夌數
-                cmd.setCameraId(nearbyCamera);
-                cmd.setChannelNum(ArdTool.getChannelBydayNightTime(dayNightTime));
-                boolean guideRes = hikClientService.guideTargetPosition(cmd);
-                return guideRes;
-            } else {
-                log.debug("鏈煡鎵惧埌鏈�杩戝厜鐢�");
-                return false;
-            }
-        } catch (
-                Exception ex) {
-            log.error("寮曞寮傚父:" + ex.getMessage());
-            return false;
-        }
-
-    }
-
-    /**
-     * @鎻忚堪 鎶ヨ褰曞儚
-     * @鍙傛暟 [cmd]
-     * @杩斿洖鍊� java.lang.String
-     * @鍒涘缓浜� 鍒樿嫃涔�
-     * @鍒涘缓鏃堕棿 2023/6/28 16:33
-     * @淇敼浜哄拰鍏跺畠淇℃伅
-     */
-    private String alarmToRecord(CameraCmd cmd) {
-        String url = "";
-        try {
-            log.debug("寮曞鎴愬姛锛屽皾璇曞綍鍍�");
-            String cameraId = cmd.getCameraId();
-            hikClientService.controlLock(cmd);//涓婇攣
-            cmd.setEnable(true);//寮�濮嬪綍鍍�
-            hikClientService.recordToMinio(cmd);//寮�濮嬪綍鍍�
-            GlobalVariable.threadMap.put(cameraId, Thread.currentThread().getName());//灏嗙浉鏈篿d涓庡綋鍓嶅鐞嗙嚎绋嬪悕绉扮粦瀹�
-            Thread.sleep(cmd.getExpired() * 1000);//褰曞儚鏃堕暱
-            String thread = GlobalVariable.threadMap.get(cameraId);
-            String currentThread = Thread.currentThread().getName();
-            //鍒ゆ柇鐩告満缁戝畾绾跨▼鏄惁鏄綋鍓嶇嚎绋嬶紝濡傛灉鏄紝鍋滄褰曞儚锛屽鏋滀笉鏄紝璇存槑鐩告満琚叾浠栫嚎绋嬫姠鍗狅紝涓嶅仠姝㈠綍鍍�
-            if (thread.equals(currentThread)) {
-                cmd.setEnable(false);//鍋滄褰曞儚
-                cmd.setUploadMinio(true);//涓婁紶minio
-                url = hikClientService.recordToMinio(cmd);//鍋滄褰曞儚杩斿洖url
-            }
-        } catch (Exception ex) {
-            log.error("褰曞儚寮傚父:" + ex.getMessage());
-        }
-        return url;
     }
 
 }
diff --git a/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/QueueManager.java b/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/QueueManager.java
index f9b3861..aef3545 100644
--- a/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/QueueManager.java
+++ b/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/QueueManager.java
@@ -2,6 +2,8 @@
 
 import com.ruoyi.alarm.globalAlarm.domain.GuidePriorityQueue;
 import com.ruoyi.alarm.globalAlarm.domain.GuideTask;
+import com.ruoyi.common.utils.StringUtils;
+import lombok.extern.slf4j.Slf4j;
 import org.apache.tomcat.util.threads.TaskThread;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
@@ -10,6 +12,8 @@
 import java.util.Map;
 import java.util.concurrent.ConcurrentHashMap;
 import java.util.concurrent.PriorityBlockingQueue;
+
+import static jdk.nashorn.internal.runtime.regexp.joni.Config.log;
 
 /**
  * @ClassName QueueManager
@@ -20,6 +24,7 @@
  */
 
 @Component
+@Slf4j
 public class QueueManager {
 
     @Autowired
@@ -57,6 +62,10 @@
     public void addTaskToQueue(String cameraId, GuideTask task) {
         /*閫氳繃鐩告満ID鑾峰彇寮曞闃熷垪锛屽苟灏嗗紩瀵间换鍔″姞鍏ラ槦鍒�*/
         PriorityBlockingQueue<GuideTask> guideTaskQueue = GuidePriorityQueue.cameraQueueMap.get(cameraId);
+        if(StringUtils.isNull(guideTaskQueue))
+        {
+            log.info("鐩告満鏈垵濮嬪寲鎴愬姛锛屾病鏈夐槦鍒�");
+        }
         guideTaskQueue.add(task);
         /*鑾峰彇璇ョ浉鏈虹殑褰撳墠鎵ц绾跨▼*/
         TaskThread currentTaskThread = threadMap.get(cameraId);
diff --git a/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/QueueTaskExecutor.java b/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/QueueTaskExecutor.java
index 3f43366..4f4ce6a 100644
--- a/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/QueueTaskExecutor.java
+++ b/ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/QueueTaskExecutor.java
@@ -35,7 +35,12 @@
         try {
             CameraCmd cmd = new CameraCmd();
             cmd.setCameraId(guideTask.getCameraId());
-            cmd.setChannelNum(guideTask.getNum());
+            cmd.setChannelNum(guideTask.getChanNum());
+            cmd.setTargetPosition(guideTask.getTargetPosition());
+            cmd.setOperator(guideTask.getAlarmType());
+            cmd.setExpired(30);
+            cmd.setRecordBucketName("record");
+            cmd.setRecordObjectName("alarm");
             boolean guideRes = hikClientService.guideTargetPosition(cmd);
             if (guideRes) {
                 hikClientService.controlLock(cmd);//涓婇攣
diff --git a/ard-work/src/main/java/com/ruoyi/device/hiksdk/controller/SdkController.java b/ard-work/src/main/java/com/ruoyi/device/hiksdk/controller/SdkController.java
index 22e153f..aedce0f 100644
--- a/ard-work/src/main/java/com/ruoyi/device/hiksdk/controller/SdkController.java
+++ b/ard-work/src/main/java/com/ruoyi/device/hiksdk/controller/SdkController.java
@@ -192,7 +192,15 @@
         cmd.setOperator(SecurityUtils.getUserId());
         return toAjax(sdk.controlLock(cmd));
     }
-
+    @ApiOperation("璁剧疆瑙i攣")
+    @PostMapping("/setPTZUnLock")
+    @ApiOperationSupport(includeParameters = {"cmd.cameraId"})
+    @Log(title = "璁剧疆瑙i攣", businessType = BusinessType.CONTROL)
+    public @ResponseBody
+    AjaxResult setPTZUnLock(@RequestBody CameraCmd cmd) {
+        cmd.setOperator(SecurityUtils.getUserId());
+        return AjaxResult.success(sdk.controlUnLock(cmd));
+    }
     @ApiOperation("鑾峰彇浜戝彴閿佸畾淇℃伅")
     @PostMapping("/getPTZLockInfo")
     @ApiOperationSupport(includeParameters = {"cmd.cameraId", "cmd.channelNum"})
diff --git a/ard-work/src/main/java/com/ruoyi/device/hiksdk/service/IHikClientService.java b/ard-work/src/main/java/com/ruoyi/device/hiksdk/service/IHikClientService.java
index 59ddfb1..6ef6268 100644
--- a/ard-work/src/main/java/com/ruoyi/device/hiksdk/service/IHikClientService.java
+++ b/ard-work/src/main/java/com/ruoyi/device/hiksdk/service/IHikClientService.java
@@ -64,7 +64,8 @@
 
     //閰嶇疆閿佸畾
     boolean controlLock(CameraCmd cmd);
-
+    //閰嶇疆瑙i攣
+    boolean controlUnLock(CameraCmd cmd);
     //鑾峰彇浜戝彴閿佸畾淇℃伅
     int getPTZLockInfo(CameraCmd cmd);
 
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 9a5e8ed..39d07e9 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
@@ -758,6 +758,31 @@
         }
         return true;
     }
+    /**
+     * @鎻忚堪 鎿嶆帶瑙i攣
+     * @鍙傛暟 [userId, channelNum]
+     * @杩斿洖鍊� boolean
+     * @鍒涘缓浜� 鍒樿嫃涔�
+     * @鍒涘缓鏃堕棿 2023/6/30 15:36
+     * @淇敼浜哄拰鍏跺畠淇℃伅
+     */
+    @Override
+    public boolean controlUnLock(CameraCmd cmd) {
+        String cameraId = cmd.getCameraId();//鐢宠瑙i攣鐨勭浉鏈�
+        String operator = cmd.getOperator();//鐢宠鑰�
+        ArdCameras ardCameras = ardCamerasMapper.selectArdCamerasById(cameraId);
+        if(ardCameras.getOperatorId().equals(operator))
+        {
+            //濡傛灉瑙i攣鐩告満鐨勫綋鍓嶇敤鎴锋槸鐢宠鑰咃紝鍒欐竻绌鸿鐩告満鐨勮繃鏈熸椂闂�
+            ardCameras.setOperatorExpired(null);
+            int i = ardCamerasMapper.updateArdCameras(ardCameras);
+            if(i>0)
+            {
+                log.debug(cameraId+"--瑙i攣鎴愬姛");
+            }
+        }
+        return true;
+    }
 
     /**
      * @鎻忚堪 鑾峰彇ptz閿佸畾淇℃伅
diff --git a/ard-work/src/main/resources/mapper/alarm/ArdAlarmRadarMapper.xml b/ard-work/src/main/resources/mapper/alarm/ArdAlarmRadarMapper.xml
index 3068afe..09d5dff 100644
--- a/ard-work/src/main/resources/mapper/alarm/ArdAlarmRadarMapper.xml
+++ b/ard-work/src/main/resources/mapper/alarm/ArdAlarmRadarMapper.xml
@@ -96,6 +96,8 @@
             <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="recordUrl1 != null">record_url1 = #{recordUrl1},</if>
+            <if test="recordUrl2 != null">record_url2 = #{recordUrl2},</if>
             <if test="guideFlag != null">guide_flag = #{guideFlag},</if>
         </trim>
         where id = #{id}

--
Gitblit v1.9.3