From aa3706580edc249216c20db6992aaf5b249dd960 Mon Sep 17 00:00:00 2001
From: aijinhui <aijinhui>
Date: 星期五, 22 十二月 2023 17:00:58 +0800
Subject: [PATCH] 群组

---
 ard-work/src/main/java/com/ruoyi/alarm/global/service/impl/QueueHandler.java |   79 +++++++++++++++++++++++++--------------
 1 files changed, 51 insertions(+), 28 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/alarm/global/service/impl/QueueHandler.java b/ard-work/src/main/java/com/ruoyi/alarm/global/service/impl/QueueHandler.java
index 7797e6e..1ca7cc7 100644
--- a/ard-work/src/main/java/com/ruoyi/alarm/global/service/impl/QueueHandler.java
+++ b/ard-work/src/main/java/com/ruoyi/alarm/global/service/impl/QueueHandler.java
@@ -14,14 +14,18 @@
 import com.ruoyi.alarm.radar.service.IArdAlarmRadarPumpService;
 import com.ruoyi.alarm.tube.domain.ArdAlarmTube;
 import com.ruoyi.alarm.tube.service.IArdAlarmTubeService;
+import com.ruoyi.common.constant.CacheConstants;
+import com.ruoyi.common.core.redis.RedisCache;
 import com.ruoyi.common.utils.StringUtils;
 import com.ruoyi.common.utils.spring.SpringUtils;
+import com.ruoyi.device.camera.domain.ArdCameras;
 import com.ruoyi.device.camera.domain.CameraCmd;
 import com.ruoyi.device.camera.service.ICameraSdkService;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.scheduling.annotation.Async;
 import org.springframework.stereotype.Component;
 
+import javax.annotation.Resource;
 import java.time.Duration;
 import java.time.Instant;
 import java.util.HashMap;
@@ -37,6 +41,9 @@
 @Slf4j(topic = "guideQueue")
 @Component
 public class QueueHandler {
+    @Resource
+    private RedisCache redisCache;
+
     /**
      * 寮曞浠诲姟鍏ラ槦
      * 鍒樿嫃涔�
@@ -46,7 +53,7 @@
         /*閫氳繃鐩告満ID鑾峰彇寮曞闃熷垪锛屽苟灏嗗紩瀵间换鍔″姞鍏ラ槦鍒�*/
         PriorityBlockingQueue<GuideTask> guideTaskQueue = GuidePriorityQueue.cameraQueueMap.get(cameraId);
         if (StringUtils.isNull(guideTaskQueue)) {
-            log.info("鐩告満鏈櫥褰�,娌℃湁闃熷垪,鏃犳硶鍏ラ槦寮曞");
+            log.debug("鐩告満鏈櫥褰�,娌℃湁闃熷垪,鏃犳硶鍏ラ槦寮曞");
             return;
         }
         log.debug("鏂颁换鍔″叆闃�:" + task.getAlarmId());
@@ -71,6 +78,7 @@
         //    newThread.start();
         //}
     }
+
     @Async("guideExecutor")
     public void process(String cameraId) {
         log.debug("CameraId:銆�" + cameraId + "銆戝紩瀵奸槦鍒楀鐞嗗櫒鍚姩鎴愬姛");
@@ -96,26 +104,35 @@
             }
         }
     }
+
     public void processTask(GuideTask guideTask) {
         try {
-            String url="";
+            if (!IsEnableGuide(guideTask.getCameraId())) {
+                return;
+            }
+            String url = "";
             CameraCmd cmd = new CameraCmd();
             cmd.setCameraId(guideTask.getCameraId());
-            cmd.setChanNo(guideTask.getChanNum());
+            cmd.setChanNo(guideTask.getChanNo());
             cmd.setTargetPosition(guideTask.getTargetPosition());
             cmd.setOperator(guideTask.getAlarmType());
             cmd.setExpired(30);
             cmd.setRecordBucketName("record");
             Map<String, Double> ptzMap = new HashMap<>();
-            ptzMap.put("p", guideTask.getGuidePTZ().getP());
-            ptzMap.put("t", guideTask.getGuidePTZ().getT());
-            ptzMap.put("z", guideTask.getGuidePTZ().getZ());
-            cmd.setPtzMap(ptzMap);
-            if (guideTask.getRecordSn().equals(1)) {
-                cmd.setRecordObjectName("alarm_" + guideTask.getAlarmId() + "_1");
-            } else {
-                cmd.setRecordObjectName("alarm_" + guideTask.getAlarmId() + "_2");
+            switch (guideTask.getChanNo()) {
+                case 1:
+                    ptzMap.put("p", guideTask.getGuidePTZ().getP1());
+                    ptzMap.put("t", guideTask.getGuidePTZ().getT1());
+                    ptzMap.put("z", guideTask.getGuidePTZ().getZ1());
+                    break;
+                case 2:
+                    ptzMap.put("p", guideTask.getGuidePTZ().getP2());
+                    ptzMap.put("t", guideTask.getGuidePTZ().getT2());
+                    ptzMap.put("z", guideTask.getGuidePTZ().getZ2());
+                    break;
             }
+            cmd.setPtzMap(ptzMap);
+            cmd.setRecordObjectName("alarm_" + guideTask.getAlarmId());
             ICameraSdkService cameraSdkService = SpringUtils.getBean(ICameraSdkService.class);
             log.debug("寮�濮嬪紩瀵�");
             boolean guideRes = false;
@@ -137,8 +154,11 @@
                     Instant currentTime = Instant.now();
                     long elapsedSeconds = Duration.between(startTime, currentTime).getSeconds();
                     if (elapsedSeconds >= 30) {
-                        recordFlag = false;
+                        recordFlag = false;//杈惧埌30绉掑綍鍍忓仠姝�
                         url = cameraSdkService.recordStopToMinio(cmd);//鍋滄褰曞儚杩斿洖url
+                    }
+                    if (!IsEnableGuide(guideTask.getCameraId())) {
+                        recordFlag = false;//鐩告満鍏抽棴寮曞褰曞儚鍋滄
                     }
                     //鍒ゆ柇闃熷垪涓涓�鏉℃暟鎹殑浼樺厛绾ф槸鍚﹀ぇ浜庡綋鍓嶆暟鎹殑浼樺厛绾�
                     PriorityBlockingQueue<GuideTask> guideTasks = GuidePriorityQueue.cameraQueueMap.get(guideTask.getCameraId());
@@ -146,7 +166,6 @@
                         GuideTask firstTask = guideTasks.peek();
                         if (firstTask.getPriority() > guideTask.getPriority()) {
                             recordFlag = false;//褰曞儚鍋滄
-                            break;
                         }
                     }
                 }
@@ -162,33 +181,21 @@
                         case "sys_radar_move":
                             ArdAlarmRadarMove ardAlarmRadarMove = new ArdAlarmRadarMove();
                             ardAlarmRadarMove.setId(guideTask.getAlarmId());
-                            if (guideTask.getRecordSn().equals(1)) {
-                                ardAlarmRadarMove.setRecordUrl1(url);
-                            } else {
-                                ardAlarmRadarMove.setRecordUrl2(url);
-                            }
+                            ardAlarmRadarMove.setRecordUrl(url);
                             IArdAlarmRadarMoveService ardAlarmRadarMoveService = SpringUtils.getBean(IArdAlarmRadarMoveService.class);
                             ardAlarmRadarMoveService.updateArdAlarmRadarMove(ardAlarmRadarMove);
                             break;
                         case "sys_radar_fire":
                             ArdAlarmRadarFire ardAlarmRadarFire = new ArdAlarmRadarFire();
                             ardAlarmRadarFire.setId(guideTask.getAlarmId());
-                            if (guideTask.getRecordSn().equals(1)) {
-                                ardAlarmRadarFire.setRecordUrl1(url);
-                            } else {
-                                ardAlarmRadarFire.setRecordUrl2(url);
-                            }
+                            ardAlarmRadarFire.setRecordUrl(url);
                             IArdAlarmRadarFireService ardAlarmRadarFireService = SpringUtils.getBean(IArdAlarmRadarFireService.class);
                             ardAlarmRadarFireService.updateArdAlarmRadarFire(ardAlarmRadarFire);
                             break;
                         case "sys_radar_pump":
                             ArdAlarmRadarPump ardAlarmRadarPump = new ArdAlarmRadarPump();
                             ardAlarmRadarPump.setId(guideTask.getAlarmId());
-                            if (guideTask.getRecordSn().equals(1)) {
-                                ardAlarmRadarPump.setRecordUrl1(url);
-                            } else {
-                                ardAlarmRadarPump.setRecordUrl2(url);
-                            }
+                            ardAlarmRadarPump.setRecordUrl(url);
                             IArdAlarmRadarPumpService ardAlarmRadarPumpService = SpringUtils.getBean(IArdAlarmRadarPumpService.class);
                             ardAlarmRadarPumpService.updateArdAlarmRadarPump(ardAlarmRadarPump);
                             break;
@@ -213,4 +220,20 @@
             log.info("绾跨▼浠诲姟寮傚父:" + ex.getMessage());
         }
     }
+
+    /**
+     * 鍏夌數鏄惁寮�鍚姤璀﹀紩瀵煎姛鑳�
+     * 鍒樿嫃涔�
+     * 2023/7/7 14:03
+     */
+    private Boolean IsEnableGuide(String cameraId) {
+        boolean enabled = false;
+        ArdCameras ardCameras = redisCache.getCacheObject(CacheConstants.CAMERA_LIST_KEY + cameraId);
+        if (ardCameras != null) {
+            if (ardCameras.getCamAlarmGuideEnable().equals(1)) {
+                enabled = true;
+            }
+        }
+        return enabled;
+    }
 }
\ No newline at end of file

--
Gitblit v1.9.3