From 0cc3db009a4388b83953f3ce439413122424abb8 Mon Sep 17 00:00:00 2001 From: zhangnaisong <2434969829@qq.com> Date: 星期一, 19 二月 2024 14:37:51 +0800 Subject: [PATCH] app历史轨迹查询提交 --- ard-work/src/main/java/com/ruoyi/app/position/service/impl/ArdAppPositionServiceImpl.java | 60 +++++++++++++++++++++++++++--------------------------------- 1 files changed, 27 insertions(+), 33 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 2a3b7ca..2909fdf 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 @@ -338,7 +338,7 @@ List<ArdWall> ardWallsNoIn = new ArrayList();//绂佸叆鐢靛瓙鍥存爮 List<ArdWall> ardWallsNoOut = new ArrayList();//绂佸嚭鐢靛瓙鍥存爮 ardWallsNoIn = ardWalls.stream().filter(ardWall -> ardWall.getType().equals("1")).collect(Collectors.toList()); - ardWallsNoOut = ardWalls.stream().filter(ardWall -> ardWall.getType().equals("0")).collect(Collectors.toList()); + ardWallsNoOut = ardWalls.stream().filter(ardWall -> ardWall.getType().equals("2")).collect(Collectors.toList()); //褰撳墠鐢ㄦ埛鐨勪綅缃� Point userPoint = new Point(ardAppPosition.getLongitude(), ardAppPosition.getLatitude()); if(ardWallsNoIn.size() > 0){//鍒ゆ柇绂佸叆 @@ -408,23 +408,13 @@ noOutFlag = true; } else { noOutFlag = false; + break; } } } if(noOutFlag){//鍏ㄩ儴绂佸嚭鐢靛瓙鍥存爮閮藉嚭鍘讳簡 for(ArdWall wall : ardWallsNoOut){ String wallId = wall.getId();//鍥存爮ID - //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); - } - boolean inPolygon = GisUtil.isInPolygon(userPoint, pointList);*///鍒ゆ柇鏄惁鍦ㄥ洿鏍忓唴 //鍒涘缓鍥存爮鎶ヨ瀹炰綋瀵硅薄 ArdAlarmWall ardAlarmWall = new ArdAlarmWall(); ardAlarmWall.setWallId(wall.getId()); @@ -436,27 +426,22 @@ ardAlarmWall.setLatitude(ardAppPosition.getLatitude()); ardAlarmWall.setAltitude(ardAppPosition.getAltitude()); String key = userId + "_" + wallId;//鏈�鍚庝竴娆℃姤璀︾紦瀛榢ey - //if (!inPolygon) { - //绂佸嚭鍥存爮鍒欒嫢鍦ㄥ洿鏍忓,鑾峰彇棣栨璧板嚭鍥存爮鎶ヨID - String lastAlarmId = firstAlarmMap.get(key); - //鍒ゆ柇褰撳墠鐢ㄦ埛鏄惁棣栨鍦ㄥ洿鏍忓 - if (lastAlarmId == null) { - String uuid = IdUtils.simpleUUID(); - //褰撳墠鐢ㄦ埛棣栨鍑哄洿鏍忕敓鎴愭姤璀� - ardAlarmWall.setId(uuid); - ardAlarmWallService.insertArdAlarmWall(ardAlarmWall); - //璁板綍棣栨鎶ヨid - firstAlarmMap.put(key, uuid); - } else { - //鐢ㄦ埛宸茬粡鍦ㄥ洿鏍忓鏇存柊鎶ヨ - ardAlarmWall.setId(lastAlarmId); - ardAlarmWallService.updateArdAlarmWall(ardAlarmWall); - } - ardAlarmWalls.add(ardAlarmWall); - /*} else { - //绉婚櫎棣栨鎶ヨ缂撳瓨 - firstAlarmMap.remove(key); - }*/ + //绂佸嚭鍥存爮鍒欒嫢鍦ㄥ洿鏍忓,鑾峰彇棣栨璧板嚭鍥存爮鎶ヨID + String lastAlarmId = firstAlarmMap.get(key); + //鍒ゆ柇褰撳墠鐢ㄦ埛鏄惁棣栨鍦ㄥ洿鏍忓 + if (lastAlarmId == null) { + String uuid = IdUtils.simpleUUID(); + //褰撳墠鐢ㄦ埛棣栨鍑哄洿鏍忕敓鎴愭姤璀� + ardAlarmWall.setId(uuid); + ardAlarmWallService.insertArdAlarmWall(ardAlarmWall); + //璁板綍棣栨鎶ヨid + firstAlarmMap.put(key, uuid); + } else { + //鐢ㄦ埛宸茬粡鍦ㄥ洿鏍忓鏇存柊鎶ヨ + ardAlarmWall.setId(lastAlarmId); + ardAlarmWallService.updateArdAlarmWall(ardAlarmWall); + } + ardAlarmWalls.add(ardAlarmWall); } }else{ for(ArdWall wall : ardWallsNoOut){ @@ -493,6 +478,15 @@ return result; } + @Override + public List<ArdAppPosition> getAPPPositionByUserIdAndTime(Map<String, String> para) { + String userId = para.get("userId"); + String beginTime = para.get("beginTime"); + String endTime = para.get("endTime"); + List<ArdAppPosition> result = ardAppPositionMapper.getAPPPositionByUserIdAndTime(userId,beginTime,endTime); + return result; + } + /*@Override public void sendCheckCommandersPosition(String usersId,Map<String, Object> para) { String reason = (String) para.get("reason"); -- Gitblit v1.9.3