From fdbb8d1d091524727456bf63d86b9612d39f822d Mon Sep 17 00:00:00 2001
From: Administrator <1144154118@qq.com>
Date: 星期一, 21 八月 2023 17:18:17 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 ard-work/src/main/java/com/ruoyi/device/camera/service/impl/ArdCamerasServiceImpl.java |   97 +++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 90 insertions(+), 7 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 7a1a5be..e14f950 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
@@ -2,6 +2,7 @@
 
 import java.time.LocalTime;
 import java.util.*;
+import java.util.stream.Collectors;
 
 import com.ruoyi.common.constant.CacheConstants;
 import com.ruoyi.common.core.domain.entity.SysDept;
@@ -10,7 +11,12 @@
 import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.common.utils.uuid.IdUtils;
 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.channel.service.IArdChannelService;
 import com.ruoyi.device.hiksdk.common.GlobalVariable;
+import com.ruoyi.device.hiksdk.service.IHikClientService;
+import com.ruoyi.scheduling.domian.SchedulingParam;
 import com.ruoyi.system.domain.SysConfig;
 import com.ruoyi.utils.tools.ArdTool;
 import com.ruoyi.device.camera.domain.ArdCameras;
@@ -19,6 +25,7 @@
 import com.ruoyi.common.annotation.DataScope;
 import com.ruoyi.system.mapper.SysDeptMapper;
 import com.ruoyi.utils.tools.GisTool;
+import com.sun.org.apache.bcel.internal.generic.NEW;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.stereotype.Service;
 
@@ -40,6 +47,9 @@
     private SysDeptMapper sysDeptMapper;
     @Resource
     private RedisCache redisCache;
+
+    @Resource
+    private ArdChannelMapper ardChannelMapper;
 
 
     @PostConstruct
@@ -108,7 +118,20 @@
         ardCameras.setCreateTime(DateUtils.getNowDate());
         ardCameras.setUserId(SecurityUtils.getUserId());
         redisCache.setCacheObject(getCacheKey(ardCameras.getId()), ardCameras);
-        return ardCamerasMapper.insertArdCameras(ardCameras);
+        int i = ardCamerasMapper.insertArdCameras(ardCameras);
+        if (i > 0) {
+//            //鍒犻櫎褰撳墠鐩告満鐨勬墍鏈夐�氶亾
+//            ardChannelMapper.deleteArdChannelByDeviceId(ardCameras.getId());
+//            //鑾峰彇鐩告満閫氶亾
+//            List<ArdChannel> ipChannelList = hikClientService.getCameraChannelList(ardCameras);
+//            if (ipChannelList.size() > 0) {
+//                for (ArdChannel channel : ipChannelList) {
+//                    channel.setId(IdUtils.simpleUUID());
+//                    ardChannelMapper.insertArdChannel(channel);
+//                }
+//            }
+        }
+        return i;
     }
 
     /**
@@ -137,11 +160,11 @@
     @Override
     public int deleteArdCamerasByIds(String[] ids) {
         int res = ardCamerasMapper.deleteArdCamerasByIds(ids);
-        if(res>0)
-        {
-            for(String id:ids)
-            {
+        if (res > 0) {
+            for (String id : ids) {
                 redisCache.deleteObject(getCacheKey(id));
+                //鍒犻櫎褰撳墠鐩告満鐨勬墍鏈夐�氶亾
+                ardChannelMapper.deleteArdChannelByDeviceId(id);
             }
         }
         return res;
@@ -155,7 +178,12 @@
      */
     @Override
     public int deleteArdCamerasById(String id) {
-        return ardCamerasMapper.deleteArdCamerasById(id);
+        int i = ardCamerasMapper.deleteArdCamerasById(id);
+        if (i > 0) {
+            //鍒犻櫎褰撳墠鐩告満鐨勬墍鏈夐�氶亾
+            ardChannelMapper.deleteArdChannelByDeviceId(id);
+        }
+        return i;
     }
 
     public List findOptions(ArdCameras ardCameras) {
@@ -206,6 +234,13 @@
         }
         if (ardCameras.size() > 0) {
             for (ArdCameras camera : ardCameras) {
+                ArdChannel ardChannel=new ArdChannel();
+                ardChannel.setDeviceId(camera.getId());
+                List<ArdChannel> ardChannels = ardChannelMapper.selectArdChannelList(ardChannel);
+                if(ardChannels!=null)
+                {
+                    camera.setChannelList(ardChannels);
+                }
                 Map<String, Object> cameraMap = ArdTool.convertEntityToMap(camera);
                 childList.add(cameraMap);
             }
@@ -248,7 +283,7 @@
                 }
                 if (distance != 0.0 && distance <= camera.getCamMaxVisibleDistance()) {
                     distanceMap.put(camera.getId(), distance);
-                    camera.setChannel(ArdTool.getChannelBydayNightTime(dayNightTime));
+                    camera.setChanNo(ArdTool.getChannelBydayNightTime(dayNightTime));
                     ardCameras.put(distance, camera);
                 }
 
@@ -260,5 +295,53 @@
         return null;
     }
 
+    /**
+     * 鑾峰彇鐩戞帶鍦堝唴鎵�鏈夊湪绾垮厜鐢�
+     * 鍒樿嫃涔�
+     * 2023/8/17 13:57:21
+     */
+    @Override
+    public List<ArdCameras> getNearCameras(SchedulingParam param) {
+        try {
+            Long deptId=SecurityUtils.getLoginUser().getUser().getDeptId();
+            Double longitude = param.getLongitude();
+            Double latitude = param.getLatitude();
+            if (longitude == null && latitude == null) {
+                log.debug("鍘熺偣鍧愭爣涓虹┖");
+                return null;
+            }
+            Integer radius = param.getMonitoringRadius();
+            if (radius == null) {
+                log.debug("鐩戞帶鍦堝崐寰勮窛绂讳负绌�");
+                return null;
+            }
+            String dayNightTime = redisCache.getCacheObject("sys_config:dayNightTime");
+            //鑾峰彇鎵�鏈夊厜鐢�(鎸夐儴闂�)
+            ArdCameras cameras= new ArdCameras();
+            cameras.setDeptId(deptId);
+            List<ArdCameras> ardCamerasList = ardCamerasMapper.selectArdCamerasList(cameras);
+            //缁熻鎵�鏈夊厜鐢靛彲瑙嗚寖鍥村唴涓庢姤璀︾偣鐨勮窛绂�
+            List<ArdCameras> ardCameras = new ArrayList<>();
+            for (ArdCameras camera : ardCamerasList) {
+                if (camera.getLongitude() == null && camera.getLatitude() == null) {
+                    continue;
+                }
+                double[] camPosition = new double[]{camera.getLongitude(), camera.getLatitude()};
+                double distance = GisTool.getDistance(new double[]{longitude, latitude}, camPosition);
+                if (distance <= radius) {
+                    camera.setChanNo(ArdTool.getChannelBydayNightTime(dayNightTime));
+                    ardCameras.add(camera);
+                }
+            }
+            //杩囨护鍦ㄧ嚎鐩告満
+            List<ArdCameras> onlineList = ardCameras.stream()
+                    .filter(ardCamera -> (!ardCamera.getLoginId().equals(-1)))
+                    .collect(Collectors.toList());
+            return onlineList;
+        } catch (Exception ex) {
+            log.error("鑾峰彇闄勮繎鐩告満寮傚父:" + ex.getMessage());
+        }
+        return null;
+    }
 
 }

--
Gitblit v1.9.3