From b5b9378fcc0013a8b95d654f3aa09905c224182c Mon Sep 17 00:00:00 2001
From: ‘liusuyi’ <1951119284@qq.com>
Date: 星期一, 03 七月 2023 09:18:38 +0800
Subject: [PATCH] 增加雷达报警1003和1004查看报警 修改查看报警点数量只获取未读数量

---
 ard-work/src/main/java/com/ruoyi/alarm/globalAlarm/service/impl/GlobalAlarmServiceImpl.java |  112 ++++++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 80 insertions(+), 32 deletions(-)

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 63a106c..c6af0b3 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
@@ -29,23 +29,20 @@
 import com.ruoyi.utils.tools.GisTool;
 import com.ruoyi.common.utils.uuid.IdUtils;
 import com.ruoyi.device.camera.domain.ArdCameras;
-import com.ruoyi.device.camera.domain.CameraCmd;
 import com.ruoyi.device.camera.mapper.ArdCamerasMapper;
-import com.ruoyi.device.hiksdk.common.GlobalVariable;
-import com.ruoyi.device.hiksdk.service.IHikClientService;
 import com.ruoyi.system.service.ISysConfigService;
 import com.ruoyi.utils.tube.GeoPoint;
 import com.ruoyi.utils.tube.TubeTools;
+import lombok.AllArgsConstructor;
+import lombok.Data;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.scheduling.annotation.Async;
 import org.springframework.stereotype.Service;
-
 import javax.annotation.Resource;
 import java.text.SimpleDateFormat;
 import java.util.*;
 import java.util.concurrent.PriorityBlockingQueue;
 import java.util.stream.Collectors;
-
 
 /**
  * @Description: 鍏ㄥ眬鎶ヨ涓氬姟
@@ -76,8 +73,6 @@
     private ISysConfigService configService;
     @Resource
     private ArdCamerasMapper ardCamerasMapper;
-    @Resource
-    private IHikClientService hikClientService;
     @Resource
     private RedisCache redisCache;
     @Resource
@@ -137,8 +132,7 @@
                                     .setCount(ardAlarmStealelec.getCount())
                                     .setTotal(ardAlarmStealelec.getTotal());
                             return globalAlarmData;
-                        })
-                        .collect(Collectors.toList());
+                        }).collect(Collectors.toList());
             case 1002:
                 List<ArdAlarmCamera> ardAlarmCameras = ardAlarmCameraMapper.selectListAllByCommand(refreshTime);
                 return ardAlarmCameras.stream()
@@ -152,8 +146,7 @@
                                     .setCount(ardAlarmCamera.getCount())
                                     .setTotal(ardAlarmCamera.getTotal());
                             return globalAlarmData;
-                        })
-                        .collect(Collectors.toList());
+                        }).collect(Collectors.toList());
             case 1003:
                 List<ArdAlarmRadar> ardAlarmRadars = ardAlarmRadarMapper.selectListAllByCommand(refreshTime, "杩愬姩鐩爣妫�娴�");
                 return ardAlarmRadars.stream()
@@ -167,8 +160,7 @@
                                     .setCount(ardAlarmRadar.getCount())
                                     .setTotal(ardAlarmRadar.getTotal());
                             return globalAlarmData;
-                        })
-                        .collect(Collectors.toList());
+                        }).collect(Collectors.toList());
             case 1004:
                 ardAlarmRadars = ardAlarmRadarMapper.selectListAllByCommand(refreshTime, "鐑簮妫�娴�");
                 return ardAlarmRadars.stream()
@@ -182,8 +174,7 @@
                                     .setCount(ardAlarmRadar.getCount())
                                     .setTotal(ardAlarmRadar.getTotal());
                             return globalAlarmData;
-                        })
-                        .collect(Collectors.toList());
+                        }).collect(Collectors.toList());
             case 1014:
                 List<ArdAlarmTube> ardAlarmTubes = ardAlarmTubeMapper.selectListAllByCommand(refreshTime);
                 return ardAlarmTubes.stream()
@@ -198,8 +189,7 @@
                                     .setCount(ardAlarmTube.getCount())
                                     .setTotal(ardAlarmTube.getTotal());
                             return globalAlarmData;
-                        })
-                        .collect(Collectors.toList());
+                        }).collect(Collectors.toList());
             default:
                 return null;
         }
@@ -224,38 +214,33 @@
                 aas.setParams(params);
                 aas.setPageNum(pageNum);
                 aas.setPageSize(pageSize);
-                List<ArdAlarmStealelec> ardAlarmStealelecs = ardAlarmStealelecMapper.selectArdAlarmStealelecList(aas);
-                return ardAlarmStealelecs;
+                return ardAlarmStealelecMapper.selectArdAlarmStealelecList(aas);
             case 1002:
                 ArdAlarmCamera aac = new ArdAlarmCamera();
                 aac.setParams(params);
                 aac.setPageNum(pageNum);
                 aac.setPageSize(pageSize);
-                List<ArdAlarmCamera> ardAlarmCameras = ardAlarmCameraMapper.selectArdAlarmCameraList(aac);
-                return ardAlarmCameras;
+                return ardAlarmCameraMapper.selectArdAlarmCameraList(aac);
             case 1003:
                 ArdAlarmRadar aar = new ArdAlarmRadar();
                 aar.setParams(params);
                 aar.setPageNum(pageNum);
                 aar.setPageSize(pageSize);
                 aar.setAlarmType("杩愬姩鐩爣妫�娴�");
-                List<ArdAlarmRadar> ardAlarmRadar = ardAlarmRadarMapper.selectArdAlarmRadarList(aar);
-                return ardAlarmRadar;
+                return ardAlarmRadarMapper.selectArdAlarmRadarList(aar);
             case 1004:
                 ArdAlarmRadar aarr = new ArdAlarmRadar();
                 aarr.setParams(params);
                 aarr.setPageNum(pageNum);
                 aarr.setPageSize(pageSize);
                 aarr.setAlarmType("鐑簮妫�娴�");
-                List<ArdAlarmRadar> ardAlarmRadarr = ardAlarmRadarMapper.selectArdAlarmRadarList(aarr);
-                return ardAlarmRadarr;
+                return ardAlarmRadarMapper.selectArdAlarmRadarList(aarr);
             case 1014:
                 ArdAlarmTube aat = new ArdAlarmTube();
                 aat.setParams(params);
                 aat.setPageNum(pageNum);
                 aat.setPageSize(pageSize);
-                List<ArdAlarmTube> ardAlarmTubes = ardAlarmTubeMapper.selectArdAlarmTubeList(aat);
-                return ardAlarmTubes;
+                return ardAlarmTubeMapper.selectArdAlarmTubeList(aat);
         }
         return null;
     }
@@ -277,15 +262,33 @@
                 if (StringUtils.isNotNull(ardAlarmStealelec)) {
                     String describe = ardAlarmStealelec.getDescribe();
                     String startTime = fmt.format(ardAlarmStealelec.getStartTime());
-                    int i = ardAlarmStealelecMapper.updateViewTimeByDescribe(describe, startTime, DateUtils.getTime());
+                    ardAlarmStealelecMapper.updateViewTimeByDescribe(describe, startTime, DateUtils.getTime());
                     return ardAlarmStealelec;
+                }
+            case 1003:
+                ArdAlarmRadar ardAlarmRadar = ardAlarmRadarMapper.selectArdAlarmRadarById(condition.getId());
+                if (StringUtils.isNotNull(ardAlarmRadar)) {
+                    String name = ardAlarmRadar.getName();
+                    String alarmType=ardAlarmRadar.getAlarmType();
+                    String alarmTime=fmt.format(ardAlarmRadar.getAlarmTime());
+                    ardAlarmRadarMapper.updateViewTimeByCondition(name,alarmType, alarmTime,DateUtils.getTime());
+                    return ardAlarmRadar;
+                }
+            case 1004:
+                ardAlarmRadar = ardAlarmRadarMapper.selectArdAlarmRadarById(condition.getId());
+                if (StringUtils.isNotNull(ardAlarmRadar)) {
+                    String name = ardAlarmRadar.getName();
+                    String alarmType=ardAlarmRadar.getAlarmType();
+                    String alarmTime=fmt.format(ardAlarmRadar.getAlarmTime());
+                    ardAlarmRadarMapper.updateViewTimeByCondition(name,alarmType, alarmTime,DateUtils.getTime());
+                    return ardAlarmRadar;
                 }
             case 1014:
                 ArdAlarmTube ardAlarmTube = ardAlarmTubeMapper.selectArdAlarmTubeById(condition.getId());
                 if (StringUtils.isNotNull(ardAlarmTube)) {
                     String tubeId = ardAlarmTube.getTubeId();
                     String alarmTime = fmt.format(ardAlarmTube.getAlarmTime());
-                    int i = ardAlarmTubeMapper.updateViewTimeByTubeId(tubeId, alarmTime, DateUtils.getTime());
+                    ardAlarmTubeMapper.updateViewTimeByTubeId(tubeId, alarmTime, DateUtils.getTime());
                     return ardAlarmTube;
                 }
             default:
@@ -343,7 +346,13 @@
                     int aat = ardAlarmTubeMapper.insertArdAlarmTube(ardAlarmTube);
                     if (aat > 0) {
                         log.debug("tube鍏ュ簱鎴愬姛锛�" + ardAlarmTube);
-                        double[] coordinate=new double[]{ardAlarmTube.getLongitude(),ardAlarmTube.getLatitude()};
+                        Double longitude = ardAlarmTube.getLongitude();
+                        Double latitude = ardAlarmTube.getLatitude();
+                        if(StringUtils.isNull(longitude)||StringUtils.isNull(latitude))
+                        {
+                            return;
+                        }
+                        double[] coordinate=new double[]{longitude,latitude};
                         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);
@@ -400,8 +409,11 @@
                             ArdAlarmpointsWell ardAlarmpointsWell = ardAlarmpointsWellMapper.selectArdAlarmpointsWellByWellId(alarmpointName);
                             if(StringUtils.isNotNull(ardAlarmpointsWell) && StringUtils.isNotEmpty(ardAlarmpointsWell.getCameraId()))
                             {
-
                                 String cameraId = ardAlarmpointsWell.getCameraId();
+                                if(cameraIdWithTower.equals(cameraId))
+                                {
+                                    return;
+                                }
                                 log.info("鑾峰彇鍒版姤璀︾偣鍏宠仈鐨勫厜鐢�:"+cameraId);
                                 //濡傛灉鎶ヨ鐐瑰叧鑱斾簡鍏夌數
                                 messagesEnqueued(cameraId, uuid, alarmType,ardAlarmRadar.getCreateTime(), 1,2,coordinate);
@@ -414,7 +426,6 @@
                             if (count >= 3) {
                                 ardAlarmRadar.setGuideFlag(1);
                                 ardAlarmRadarMapper.insertArdAlarmRadar(ardAlarmRadar);
-
                                 //鑾峰彇闆疯揪鎵�鍦ㄥ涓婄殑澶у厜鐢�
                                 String cameraIdWithTower = ardAlarmRadarMapper.getCameraByRadar(radarAlarmData.getRadarId());
                                 if (StringUtils.isNotNull(cameraIdWithTower) && StringUtils.isNotEmpty(cameraIdWithTower)) {
@@ -427,6 +438,10 @@
                                 if(StringUtils.isNotNull(ardAlarmpointsWell) && StringUtils.isNotEmpty(ardAlarmpointsWell.getCameraId()))
                                 {
                                     String cameraId = ardAlarmpointsWell.getCameraId();
+                                    if(cameraIdWithTower.equals(cameraId))
+                                    {
+                                        return;
+                                    }
                                     log.info("鑾峰彇鍒版姤璀︾偣鍏宠仈鐨勫厜鐢�:"+cameraId);
                                     //濡傛灉鎶ヨ鐐瑰叧鑱斾簡鍏夌數
                                     messagesEnqueued(cameraId, uuid, alarmType,ardAlarmRadar.getCreateTime(), count,2,coordinate);
@@ -519,4 +534,37 @@
         return minDistanceCameraId;
     }
 
+    public static void main(String[] args) {
+        Comparator<Obj> PriorityDescCom = Comparator.comparingInt(Obj::getPriority).reversed();
+        Comparator<Obj> NumDescCom = Comparator.comparingInt(Obj::getNum).reversed();
+        Comparator<Obj> receiveTimeAscCom = Comparator.comparing(Obj::getAlarmTime);
+        Comparator<Obj> comparator = PriorityDescCom.thenComparing(NumDescCom).thenComparing(receiveTimeAscCom);
+
+        PriorityBlockingQueue<Obj> priorityQueue = new PriorityBlockingQueue<>(1000,comparator);
+
+        priorityQueue.add(new Obj(999,1,"2023-07-01 16:00:01"));
+        priorityQueue.add(new Obj(999,2,"2023-07-01 16:00:01"));
+        priorityQueue.add(new Obj(999,3,"2023-07-01 16:00:01"));
+
+        List<Obj> elements = new ArrayList<>(priorityQueue);
+        elements.sort(priorityQueue.comparator());  // 浣跨敤闃熷垪鐨勬瘮杈冨櫒杩涜鎺掑簭
+        for (Obj task : elements) {
+            log.info("姝e湪鎺掗槦銆恜riority銆�" + task.getPriority()+"銆恘um銆�" + task.getNum() + "銆恆larmTime銆�" + task.getAlarmTime());
+        }
+        log.info("===================================================================");
+        priorityQueue.add(new Obj(999,5,"2023-07-01 16:00:01"));
+        PriorityBlockingQueue queue = new PriorityBlockingQueue<>(priorityQueue);
+        while (priorityQueue.size() > 0) {
+            Obj task = priorityQueue.poll();
+            log.info("姝e湪鎺掗槦銆恜riority銆�" + task.getPriority()+"銆恘um銆�" + task.getNum() + "銆恆larmTime銆�" + task.getAlarmTime());
+        }
+    }
+    @Data
+    @AllArgsConstructor
+    static class Obj
+    {
+        Integer priority;
+        Integer num;
+        String alarmTime;
+    }
 }

--
Gitblit v1.9.3