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/app/position/service/impl/ArdAppPositionServiceImpl.java | 73 ++++++++++++++++++++---------------- 1 files changed, 41 insertions(+), 32 deletions(-) diff --git a/ard-work/src/main/java/com/ruoyi/app/position/service/impl/ArdAppPositionServiceImpl.java b/ard-work/src/main/java/com/ruoyi/app/position/service/impl/ArdAppPositionServiceImpl.java index e204a69..c046a48 100644 --- a/ard-work/src/main/java/com/ruoyi/app/position/service/impl/ArdAppPositionServiceImpl.java +++ b/ard-work/src/main/java/com/ruoyi/app/position/service/impl/ArdAppPositionServiceImpl.java @@ -125,41 +125,50 @@ */ @Override public List<SysUser> getNearAppUsers(SchedulingParam param) { - Double longitude = param.getLongitude(); - Double latitude = param.getLatitude(); - if (longitude == null && latitude == null) { - log.debug("鍘熺偣鍧愭爣涓虹┖"); - return null; - } - Integer radius = param.getSealingRadius(); - - if (radius == null) { - log.debug("鍗婂緞璺濈涓虹┖"); - return null; - } - - SysUser user = new SysUser(); - List<SysUser> appUserList = iSysUserService.selectAllAppUserList(user); - //杩囨护鍦ㄧ嚎 - List<SysUser> onLineList = appUserList.stream() - .filter(sysUser -> (sysUser.getAppOnlineState().equals("1"))) - .collect(Collectors.toList()); - //杩囨护鑼冨洿 List<SysUser> filteredList = new ArrayList<>(); - for(SysUser sysUser:onLineList) { - ArdAppPosition ardAppPosition = ardAppPositionMapper.selectLastArdAppPositionByUserId(sysUser.getUserId()); - if (ardAppPosition != null) { - Double lon = ardAppPosition.getLongitude(); - Double lat = ardAppPosition.getLatitude(); - if(longitude==null||latitude==null) - { - continue; - } - double distance = GisTool.getDistance(new double[]{ longitude, latitude}, new double[]{ lon, lat}); - if (distance <= radius) { - filteredList.add(sysUser); // 灏嗘弧瓒虫潯浠剁殑鐢ㄦ埛娣诲姞鍒扮瓫閫夊垪琛ㄤ腑 + 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.getSealingRadius(); + + if (radius == null) { + log.debug("鍗婂緞璺濈涓虹┖"); + return null; + } + + SysUser user = new SysUser(); + user.setDeptId(deptId); + List<SysUser> appUserList = iSysUserService.selectAllAppUserList(user); + //杩囨护鍦ㄧ嚎 + List<SysUser> onLineList = appUserList.stream() + .filter(sysUser -> (sysUser.getAppOnlineState().equals("1"))) + .collect(Collectors.toList()); + //杩囨护鑼冨洿 + for (SysUser sysUser : onLineList) { + ArdAppPosition ardAppPosition = ardAppPositionMapper.selectLastArdAppPositionByUserId(sysUser.getUserId()); + if (ardAppPosition != null) { + Double lon = ardAppPosition.getLongitude(); + Double lat = ardAppPosition.getLatitude(); + if (longitude == null || latitude == null) { + continue; + } + double distance = GisTool.getDistance(new double[]{longitude, latitude}, new double[]{lon, lat}); + if (distance <= radius) { + Map<String, Object> params = new HashMap<>(); + params.put("longitude", lon); + params.put("latitude", lat); + sysUser.setParams(params); + filteredList.add(sysUser); // 灏嗘弧瓒虫潯浠剁殑鐢ㄦ埛娣诲姞鍒扮瓫閫夊垪琛ㄤ腑 + } } } + } catch (Exception ex) { + log.error("鑾峰彇灏佹帶鍦堝唴鎵�鏈夊湪绾縜pp鐢ㄦ埛寮傚父" + ex.getMessage()); } return filteredList; } -- Gitblit v1.9.3