From 8a87e4226aa802d6a0e3566c66824fedf68e77da Mon Sep 17 00:00:00 2001
From: aijinhui <aijinhui>
Date: 星期二, 24 十月 2023 16:30:48 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 ard-work/src/main/java/com/ruoyi/device/camera/service/impl/ArdCamerasServiceImpl.java |   87 ++++++++++++++++++++++++++++++++-----------
 1 files changed, 65 insertions(+), 22 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/device/camera/service/impl/ArdCamerasServiceImpl.java b/ard-work/src/main/java/com/ruoyi/device/camera/service/impl/ArdCamerasServiceImpl.java
index 245b74e..22b1c04 100644
--- a/ard-work/src/main/java/com/ruoyi/device/camera/service/impl/ArdCamerasServiceImpl.java
+++ b/ard-work/src/main/java/com/ruoyi/device/camera/service/impl/ArdCamerasServiceImpl.java
@@ -12,15 +12,18 @@
 import com.ruoyi.device.camera.domain.CameraCmd;
 import com.ruoyi.device.channel.domain.ArdChannel;
 import com.ruoyi.device.channel.mapper.ArdChannelMapper;
+import com.ruoyi.device.hiksdk.service.IHikClientService;
+import com.ruoyi.media.domain.Vtdu;
+import com.ruoyi.media.service.IVtduService;
 import com.ruoyi.scheduling.domian.SchedulingParam;
+import com.ruoyi.utils.gis.GisUtil;
 import com.ruoyi.utils.tools.ArdTool;
 import com.ruoyi.device.camera.domain.ArdCameras;
 import com.ruoyi.device.camera.mapper.ArdCamerasMapper;
 import com.ruoyi.device.camera.service.IArdCamerasService;
 import com.ruoyi.common.annotation.DataScope;
 import com.ruoyi.system.mapper.SysDeptMapper;
-import com.ruoyi.utils.tools.GisTool;
-import com.ruoyi.utils.tools.Point;
+import com.ruoyi.utils.gis.Point;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.stereotype.Service;
 
@@ -45,10 +48,15 @@
 
     @Resource
     private ArdChannelMapper ardChannelMapper;
-
+    @Resource
+    private IVtduService vtduService;
 
     @PostConstruct
     public void loadCameras() {
+        //娓呯┖鐩告満缂撳瓨
+        Collection<String> cacheKeys = redisCache.keys(getCacheKey("*"));
+        redisCache.deleteObject(cacheKeys);
+        //閲嶆柊鍔犺浇鐩告満鍒扮紦瀛�
         List<ArdCameras> ardCameras = selectArdCamerasListNoDataScope(new ArdCameras());
         for (ArdCameras ardCamera : ardCameras) {
             redisCache.setCacheObject(getCacheKey(ardCamera.getId()), ardCamera);
@@ -74,7 +82,16 @@
      */
     @Override
     public ArdCameras selectArdCamerasById(String id) {
-        return ardCamerasMapper.selectArdCamerasById(id);
+        ArdCameras ardCameras = ardCamerasMapper.selectArdCamerasById(id);
+        if (ardCameras != null) {
+            ArdChannel ardChannel = new ArdChannel();
+            ardChannel.setDeviceId(ardCameras.getId());
+            List<ArdChannel> ardChannels = ardChannelMapper.selectArdChannelList(ardChannel);
+            if (ardChannels != null) {
+                ardCameras.setChannelList(ardChannels);
+            }
+        }
+        return ardCameras;
     }
 
     /**
@@ -86,7 +103,18 @@
     @Override
     @DataScope(deptAlias = "d", userAlias = "u")
     public List<ArdCameras> selectArdCamerasList(ArdCameras ardCameras) {
-        return ardCamerasMapper.selectArdCamerasList(ardCameras);
+        List<ArdCameras> ardCamerasList = ardCamerasMapper.selectArdCamerasList(ardCameras);
+        if (ardCamerasList.size() > 0) {
+            for (ArdCameras camera : ardCamerasList) {
+                ArdChannel ardChannel = new ArdChannel();
+                ardChannel.setDeviceId(camera.getId());
+                List<ArdChannel> ardChannels = ardChannelMapper.selectArdChannelList(ardChannel);
+                if (ardChannels != null) {
+                    camera.setChannelList(ardChannels);
+                }
+            }
+        }
+        return ardCamerasList;
     }
 
     /**
@@ -145,6 +173,8 @@
         if (res > 0) {
             for (String id : ids) {
                 redisCache.deleteObject(getCacheKey(id));
+                //鍒犻櫎娴佸獟浣�
+                vtduService.deleteVtduByCameraId(id);
                 //鍒犻櫎褰撳墠鐩告満鐨勬墍鏈夐�氶亾
                 ardChannelMapper.deleteArdChannelByDeviceId(id);
             }
@@ -169,7 +199,15 @@
     }
 
     public List findOptions(ArdCameras ardCameras) {
-        return ardCamerasMapper.findOptions(ardCameras);
+        List<ArdCameras> options = ardCamerasMapper.findOptions(ardCameras);
+        for (ArdCameras camera :
+                options) {
+            ArdChannel ardChannel = new ArdChannel();
+            ardChannel.setDeviceId(camera.getId());
+            List<ArdChannel> ardChannels = ardChannelMapper.selectArdChannelList(ardChannel);
+            camera.setChannelList(ardChannels);
+        }
+        return options;
     }
 
     /**
@@ -216,11 +254,10 @@
         }
         if (ardCameras.size() > 0) {
             for (ArdCameras camera : ardCameras) {
-                ArdChannel ardChannel=new ArdChannel();
+                ArdChannel ardChannel = new ArdChannel();
                 ardChannel.setDeviceId(camera.getId());
                 List<ArdChannel> ardChannels = ardChannelMapper.selectArdChannelList(ardChannel);
-                if(ardChannels!=null)
-                {
+                if (ardChannels != null) {
                     camera.setChannelList(ardChannels);
                 }
                 Map<String, Object> cameraMap = ArdTool.convertEntityToMap(camera);
@@ -259,7 +296,7 @@
                     continue;
                 }
                 double[] camPosition = new double[]{camera.getLongitude(), camera.getLatitude()};
-                double distance = GisTool.getDistance(cmd.getTargetPosition(), camPosition);
+                double distance = GisUtil.getDistance(cmd.getTargetPosition(), camPosition);
                 if (camera.getCamMaxVisibleDistance() == null) {
                     continue;
                 }
@@ -268,7 +305,13 @@
                     camera.setChanNo(ArdTool.getChannelBydayNightTime(dayNightTime));
                     ardCameras.put(distance, camera);
                 }
-
+                //鑾峰彇閫氶亾鍒楄〃
+                ArdChannel ardChannel = new ArdChannel();
+                ardChannel.setDeviceId(camera.getId());
+                List<ArdChannel> ardChannels = ardChannelMapper.selectArdChannelList(ardChannel);
+                if (ardChannels != null) {
+                    camera.setChannelList(ardChannels);
+                }
             }
             return ardCameras;
         } catch (Exception ex) {
@@ -285,7 +328,7 @@
     @Override
     public List<ArdCameras> getNearCameras(SchedulingParam param) {
         try {
-            Long deptId=SecurityUtils.getLoginUser().getUser().getDeptId();
+            Long deptId = SecurityUtils.getLoginUser().getUser().getDeptId();
             Double longitude = param.getLongitude();
             Double latitude = param.getLatitude();
             if (longitude == null && latitude == null) {
@@ -299,7 +342,7 @@
             }
             String dayNightTime = redisCache.getCacheObject("sys_config:dayNightTime");
             //鑾峰彇鎵�鏈夊厜鐢�(鎸夐儴闂�)
-            ArdCameras cameras= new ArdCameras();
+            ArdCameras cameras = new ArdCameras();
             cameras.setDeptId(deptId);
             List<ArdCameras> ardCamerasList = ardCamerasMapper.selectArdCamerasList(cameras);
             //缁熻鎵�鏈夊厜鐢靛彲瑙嗚寖鍥村唴涓庢姤璀︾偣鐨勮窛绂�
@@ -309,10 +352,10 @@
                     continue;
                 }
                 double[] camPosition = new double[]{camera.getLongitude(), camera.getLatitude()};
-                double distance = GisTool.getDistance(new double[]{longitude, latitude}, camPosition);
+                double distance = GisUtil.getDistance(new double[]{longitude, latitude}, camPosition);
                 if (distance <= radius) {
                     /*鑾峰彇閫氶亾鍒楄〃*/
-                    ArdChannel ardChannel=new ArdChannel();
+                    ArdChannel ardChannel = new ArdChannel();
                     ardChannel.setDeviceId(camera.getId());
                     List<ArdChannel> ardChannels = ardChannelMapper.selectArdChannelList(ardChannel);
                     camera.setChannelList(ardChannels);
@@ -329,6 +372,7 @@
         }
         return null;
     }
+
     /**
      * 鑾峰彇鐩戞帶鍦堝唴鎵�鏈夊湪绾垮厜鐢�
      * 鍒樿嫃涔�
@@ -337,16 +381,15 @@
     @Override
     public List<ArdCameras> getNearCamerasWithPolygon(SchedulingParam param) {
         try {
-            Long deptId=SecurityUtils.getLoginUser().getUser().getDeptId();
+            Long deptId = SecurityUtils.getLoginUser().getUser().getDeptId();
             List<Point> partitionLocation = param.getPartitionLocation();
-            if(partitionLocation==null)
-            {
+            if (partitionLocation == null) {
                 log.debug("澶氳竟褰㈠潗鏍囬泦鍚堜负绌�");
                 return null;
             }
             String dayNightTime = redisCache.getCacheObject("sys_config:dayNightTime");
             //鑾峰彇鎵�鏈夊厜鐢�(鎸夐儴闂�)
-            ArdCameras cameras= new ArdCameras();
+            ArdCameras cameras = new ArdCameras();
             cameras.setDeptId(deptId);
             List<ArdCameras> ardCamerasList = ardCamerasMapper.selectArdCamerasList(cameras);
             List<ArdCameras> ardCameras = new ArrayList<>();
@@ -355,11 +398,11 @@
                     continue;
                 }
                 /*鍒ゆ柇鍧愭爣鏄惁鍦ㄥ杈瑰舰鑼冨洿鍐�*/
-                Point camPosition=new Point(camera.getLongitude(),camera.getLatitude());
-                boolean inPolygon = GisTool.isInPolygon(camPosition, partitionLocation);
+                Point camPosition = new Point(camera.getLongitude(), camera.getLatitude());
+                boolean inPolygon = GisUtil.isInPolygon(camPosition, partitionLocation);
                 if (inPolygon) {
                     /*鑾峰彇閫氶亾鍒楄〃*/
-                    ArdChannel ardChannel=new ArdChannel();
+                    ArdChannel ardChannel = new ArdChannel();
                     ardChannel.setDeviceId(camera.getId());
                     List<ArdChannel> ardChannels = ardChannelMapper.selectArdChannelList(ardChannel);
                     camera.setChannelList(ardChannels);

--
Gitblit v1.9.3