From b627f6ca5a5ba2a46099e1a3aea6aa5a516c683f Mon Sep 17 00:00:00 2001 From: ‘liusuyi’ <1951119284@qq.com> Date: 星期一, 31 七月 2023 16:36:23 +0800 Subject: [PATCH] app位置结构增加params 修改单兵端的任务详情和列表 --- ard-work/src/main/java/com/ruoyi/device/camera/service/impl/ArdCamerasServiceImpl.java | 74 +++++++++++++++++++++++++++++++------ 1 files changed, 62 insertions(+), 12 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 9a12c39..7a1a5be 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 @@ -3,10 +3,12 @@ import java.time.LocalTime; import java.util.*; +import com.ruoyi.common.constant.CacheConstants; import com.ruoyi.common.core.domain.entity.SysDept; import com.ruoyi.common.core.redis.RedisCache; import com.ruoyi.common.utils.DateUtils; import com.ruoyi.common.utils.SecurityUtils; +import com.ruoyi.common.utils.uuid.IdUtils; import com.ruoyi.device.camera.domain.CameraCmd; import com.ruoyi.device.hiksdk.common.GlobalVariable; import com.ruoyi.system.domain.SysConfig; @@ -39,6 +41,25 @@ @Resource private RedisCache redisCache; + + @PostConstruct + public void loadCameras() { + List<ArdCameras> ardCameras = selectArdCamerasListNoDataScope(new ArdCameras()); + for (ArdCameras ardCamera : ardCameras) { + redisCache.setCacheObject(getCacheKey(ardCamera.getId()), ardCamera); + } + + } + + /** + * 璁剧疆cache key + * + * @param configKey 鍙傛暟閿� + * @return 缂撳瓨閿甼ey + */ + private String getCacheKey(String configKey) { + return CacheConstants.CAMERA_LIST_KEY + configKey; + } /** * 鏌ヨ鐩告満璁惧 @@ -82,9 +103,11 @@ */ @Override public int insertArdCameras(ArdCameras ardCameras) { + ardCameras.setId(IdUtils.simpleUUID()); ardCameras.setCreateBy(SecurityUtils.getUsername()); ardCameras.setCreateTime(DateUtils.getNowDate()); ardCameras.setUserId(SecurityUtils.getUserId()); + redisCache.setCacheObject(getCacheKey(ardCameras.getId()), ardCameras); return ardCamerasMapper.insertArdCameras(ardCameras); } @@ -97,7 +120,12 @@ @Override public int updateArdCameras(ArdCameras ardCameras) { ardCameras.setUpdateTime(DateUtils.getNowDate()); - return ardCamerasMapper.updateArdCameras(ardCameras); + int res = ardCamerasMapper.updateArdCameras(ardCameras); + if (res > 0) { + redisCache.deleteObject(getCacheKey(ardCameras.getId())); + redisCache.setCacheObject(getCacheKey(ardCameras.getId()), ardCameras); + } + return res; } /** @@ -108,7 +136,15 @@ */ @Override public int deleteArdCamerasByIds(String[] ids) { - return ardCamerasMapper.deleteArdCamerasByIds(ids); + int res = ardCamerasMapper.deleteArdCamerasByIds(ids); + if(res>0) + { + for(String id:ids) + { + redisCache.deleteObject(getCacheKey(id)); + } + } + return res; } /** @@ -136,25 +172,26 @@ */ @Override - public Map getChildDeptAndCamera() { + public Map getChildDeptAndCamera(Boolean disabled) { Long deptId = SecurityUtils.getDeptId(); SysDept sysDept = sysDeptMapper.selectDeptById(deptId); - Map<String, Object> map = fetchChildDepartments(sysDept); + Map<String, Object> map = fetchChildDepartments(sysDept, disabled); return map; } + /** * @鎻忚堪 閫掑綊鏌ヨ * @鍙傛暟 [sysDept] - * @杩斿洖鍊� java.util.Map<java.lang.String,java.lang.Object> + * @杩斿洖鍊� java.util.Map<java.lang.String, java.lang.Object> * @鍒涘缓浜� 鍒樿嫃涔� * @鍒涘缓鏃堕棿 2023/6/2 14:38 * @淇敼浜哄拰鍏跺畠淇℃伅 */ - public Map<String, Object> fetchChildDepartments(SysDept sysDept) { + public Map<String, Object> fetchChildDepartments(SysDept sysDept, Boolean disabled) { Map<String, Object> map = new HashMap<>(); map.put("name", sysDept.getDeptName()); map.put("deptId", sysDept.getDeptId()); - map.put("disabled", true); + map.put("disabled", disabled); List<SysDept> sysDepts = sysDeptMapper.selectNextChildrenDeptById(sysDept.getDeptId()); List<ArdCameras> ardCameras = ardCamerasMapper.selectArdCamerasByDeptId(sysDept.getDeptId()); List<Object> childList = new ArrayList<>(); @@ -162,8 +199,8 @@ Map<String, Object> childMap = new HashMap<>(); childMap.put("name", childDept.getDeptName()); childMap.put("deptId", childDept.getDeptId()); - childMap.put("disabled", true); - Map<String, Object> map1 = fetchChildDepartments(childDept); + childMap.put("disabled", disabled); + Map<String, Object> map1 = fetchChildDepartments(childDept, disabled); childMap.putAll(map1); childList.add(childMap); } @@ -177,6 +214,7 @@ return map; } + /** * @鎻忚堪 閫氳繃鍧愭爣鑾峰彇闄勮繎鐨勭浉鏈� * @鍙傛暟 [cmd] @@ -188,24 +226,36 @@ @Override public TreeMap getNearCamerasBycoordinate(CameraCmd cmd) { try { + double[] targetPosition = cmd.getTargetPosition(); + if (targetPosition == null || (targetPosition != null && targetPosition.length == 0)) { + log.debug("鐩爣浣嶇疆涓虹┖"); + return new TreeMap<>(); + } String dayNightTime = redisCache.getCacheObject("sys_config:dayNightTime"); //鑾峰彇鎵�鏈夊ぇ鍏夌數 List<ArdCameras> ardCamerasList = ardCamerasMapper.selectArdCamerasList(new ArdCameras("1")); //缁熻鎵�鏈夊ぇ鍏夌數鍙鑼冨洿鍐呬笌鎶ヨ鐐圭殑璺濈 Map<String, Double> distanceMap = new HashMap<>(); - TreeMap<Double,ArdCameras> ardCameras = new TreeMap<>(); + TreeMap<Double, ArdCameras> ardCameras = new TreeMap<>(); for (ArdCameras camera : ardCamerasList) { + if (camera.getLongitude() == null && camera.getLatitude() == null) { + continue; + } double[] camPosition = new double[]{camera.getLongitude(), camera.getLatitude()}; double distance = GisTool.getDistance(cmd.getTargetPosition(), camPosition); + if (camera.getCamMaxVisibleDistance() == null) { + continue; + } if (distance != 0.0 && distance <= camera.getCamMaxVisibleDistance()) { distanceMap.put(camera.getId(), distance); camera.setChannel(ArdTool.getChannelBydayNightTime(dayNightTime)); - ardCameras.put(distance,camera); + ardCameras.put(distance, camera); } + } return ardCameras; } catch (Exception ex) { - log.error("寮曞寮傚父:" + ex.getMessage()); + log.error("鑾峰彇闄勮繎鐩告満寮傚父:" + ex.getMessage()); } return null; } -- Gitblit v1.9.3