From 1f7e0b769fdf0308818b12523752675bd41eeff6 Mon Sep 17 00:00:00 2001 From: ‘liusuyi’ <1951119284@qq.com> Date: 星期四, 31 八月 2023 10:33:51 +0800 Subject: [PATCH] 增加电子围栏根据app位置上报实时检测 --- ard-work/src/main/java/com/ruoyi/app/position/service/impl/ArdAppPositionServiceImpl.java | 223 ++++++++++++++++++++++++++++++++++++++++++++----------- 1 files changed, 176 insertions(+), 47 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 2ca4552..db67b30 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 @@ -1,27 +1,27 @@ package com.ruoyi.app.position.service.impl; +import com.ruoyi.alarm.wall.domain.ArdAlarmWall; +import com.ruoyi.alarm.wall.mapper.ArdAlarmWallMapper; +import com.ruoyi.alarm.wall.service.IArdAlarmWallService; +import com.ruoyi.alarmpoints.wall.domain.ArdWall; +import com.ruoyi.alarmpoints.wall.mapper.ArdWallMapper; import com.ruoyi.app.position.domain.ArdAppPosition; import com.ruoyi.app.position.mapper.ArdAppPositionMapper; import com.ruoyi.app.position.service.IArdAppPositionService; -import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.common.core.domain.entity.SysUser; +import com.ruoyi.common.core.redis.RedisCache; import com.ruoyi.common.utils.DateUtils; import com.ruoyi.common.utils.SecurityUtils; -import com.ruoyi.common.utils.StringUtils; -import com.ruoyi.common.utils.spring.SpringUtils; import com.ruoyi.common.utils.uuid.IdUtils; import com.ruoyi.scheduling.domian.SchedulingParam; import com.ruoyi.system.service.ISysUserService; -import com.ruoyi.utils.tools.GisTool; +import com.ruoyi.utils.gis.GisUtil; +import com.ruoyi.utils.gis.Point; import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Service; -import javax.annotation.PostConstruct; import javax.annotation.Resource; -import java.util.ArrayList; -import java.util.HashMap; -import java.util.List; -import java.util.Map; +import java.util.*; import java.util.stream.Collectors; @@ -79,10 +79,11 @@ * @return 缁撴灉 */ @Override - public int insertArdAppPosition(ArdAppPosition ardAppPosition) { + public List<ArdAlarmWall> insertArdAppPosition(ArdAppPosition ardAppPosition) { ardAppPosition.setId(IdUtils.simpleUUID()); ardAppPosition.setCreateTime(DateUtils.getNowDate()); - return ardAppPositionMapper.insertArdAppPosition(ardAppPosition); + ardAppPositionMapper.insertArdAppPosition(ardAppPosition); + return DetectionWallAlarm(ardAppPosition); } /** @@ -125,47 +126,175 @@ */ @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) { - Map<String,Object> params=new HashMap<>(); - params.put("longitude",lon); - params.put("latitude",lat); - sysUser.setParams(params); - 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"))) + .filter(sysUser -> (sysUser.getAppUserType().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 = GisUtil.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; } + /** + * 鑾峰彇灏佹帶鍦堝唴鎵�鏈夊湪绾縜pp鐢ㄦ埛(澶氳竟褰�) + * 鍒樿嫃涔� + * 2023/8/17 13:56:36 + */ + @Override + public List<SysUser> getNearAppUsersWithPolygon(SchedulingParam param) { + List<SysUser> filteredList = new ArrayList<>(); + try { + Long deptId = SecurityUtils.getLoginUser().getUser().getDeptId(); + List<Point> partitionLocation = param.getPartitionLocation(); + + SysUser user = new SysUser(); + user.setDeptId(deptId); + List<SysUser> appUserList = iSysUserService.selectAllAppUserList(user); + //杩囨护鍦ㄧ嚎 + List<SysUser> onLineList = appUserList.stream() + .filter(sysUser -> (sysUser.getAppOnlineState().equals("1"))) + .filter(sysUser -> (sysUser.getAppUserType().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 (lon == null || lat == null) { + continue; + } + Point point2D = new Point(lon, lat); + boolean inPolygon = GisUtil.isInPolygon(point2D, partitionLocation); + if (inPolygon) { + 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; + } + + + @Resource + RedisCache redisCache; + @Resource + ArdWallMapper ardWallMapper; + @Resource + IArdAlarmWallService ardAlarmWallService; + Map<String, String> userLastAlarm = new HashMap<>(); + + /** + * 瀹炴椂浣嶇疆妫�娴嬪洿鏍忔姤璀� + * 鍒樿嫃涔� + * 2023/8/31 8:54:06 + */ + public List<ArdAlarmWall> DetectionWallAlarm(ArdAppPosition ardAppPosition) { + List<ArdAlarmWall> ardAlarmWalls=new ArrayList<>(); + //鑾峰彇褰撳墠鐢ㄦ埛鐨勯儴闂� + String userId = ardAppPosition.getUserId(); + SysUser sysUser = redisCache.getCacheObject("user_list:" + userId); + Long deptId = sysUser.getDeptId(); + //鑾峰彇閮ㄩ棬涓嬬殑鎵�鏈夌數瀛愬洿鏍� + ArdWall ardWall = new ArdWall(); + ardWall.setDeptId(deptId); + List<ArdWall> ardWalls = ardWallMapper.selectArdWallList(ardWall); + if (ardWalls.size() > 0) { + for (ArdWall wall : ardWalls) { + String wallPoi = wall.getWallPoi(); + //澶勭悊澶氳竟褰㈢殑姣忎釜鐐圭殑缁忕含搴� + String[] parts = wallPoi.split(","); + List<Point> pointList = new ArrayList<>(); + for (int i = 0; i < parts.length; i += 3) { + Point point = new Point(); + point.setLongitude(Double.valueOf(parts[i])); + point.setLatitude(Double.valueOf(parts[i + 1])); + pointList.add(point); + } + + //鍒ゆ柇褰撳墠鐢ㄦ埛浣嶇疆鏄惁鍦ㄥ洿鏍忓唴 + Point userPoint=new Point(); + userPoint.setLongitude(ardAppPosition.getLongitude()); + userPoint.setLatitude(ardAppPosition.getLatitude()); + boolean inPolygon = GisUtil.isInPolygon(userPoint, pointList); + if (inPolygon) { + String lastAlarmId = userLastAlarm.get(userId); + ArdAlarmWall ardAlarmWall = new ArdAlarmWall(); + ardAlarmWall.setWallId(wall.getId()); + ardAlarmWall.setWallName(wall.getWallName()); + ardAlarmWall.setUserId(userId); + ardAlarmWall.setAlarmTime(new Date()); + ardAlarmWall.setAlarmType(wall.getType()); + ardAlarmWall.setLongitude(ardAppPosition.getLongitude()); + ardAlarmWall.setLatitude(ardAppPosition.getLatitude()); + ardAlarmWall.setAltitude(ardAppPosition.getAltitude()); + if (lastAlarmId == null) { + String uuid = IdUtils.simpleUUID(); + // 褰撳墠鐢ㄦ埛涓婁竴娆$姸鎬佹湭杩涘叆锛岀敓鎴愭姤璀� + ardAlarmWall.setId(uuid); + ardAlarmWallService.insertArdAlarmWall(ardAlarmWall); + //鏇存柊鏈�鍚庢姤璀d + userLastAlarm.put(userId, uuid); + } else { + // 涓婁竴娆$敤鎴风姸鎬佸凡杩涘叆锛屾洿鏂版渶鍚庢姤璀� + ardAlarmWall.setId(lastAlarmId); + ardAlarmWallService.updateArdAlarmWall(ardAlarmWall); + } + ardAlarmWalls.add(ardAlarmWall); + } + else + { + //绉婚櫎鏈�鍚庢姤璀d + userLastAlarm.remove(userId); + } + } + } + return ardAlarmWalls; + } } -- Gitblit v1.9.3