From 2d10f00422f1c501f2cffec29fef1c6a8eba3a55 Mon Sep 17 00:00:00 2001
From: zhangnaisong <2434969829@qq.com>
Date: 星期三, 31 一月 2024 13:57:44 +0800
Subject: [PATCH] 禁出电子围栏报警逻辑bug修改提交

---
 ard-work/src/main/java/com/ruoyi/app/position/service/impl/ArdAppPositionServiceImpl.java |  150 ++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 140 insertions(+), 10 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 52031a3..b6105ec 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
@@ -241,7 +241,7 @@
      * 鍒樿嫃涔�
      * 2023/8/31 8:54:06
      */
-    public List<ArdAlarmWall> DetectionWallAlarm(ArdAppPosition ardAppPosition) {
+    /*public List<ArdAlarmWall> DetectionWallAlarm(ArdAppPosition ardAppPosition) {
         List<ArdAlarmWall> ardAlarmWalls = new ArrayList<>();
         //鑾峰彇褰撳墠鐢ㄦ埛鐨勯儴闂�
         String userId = ardAppPosition.getUserId();
@@ -327,6 +327,130 @@
             }
         }
         return ardAlarmWalls;
+    }*/
+
+    public List<ArdAlarmWall> DetectionWallAlarm(ArdAppPosition ardAppPosition) {
+        List<ArdAlarmWall> ardAlarmWalls = new ArrayList<>();
+        //鑾峰彇褰撳墠鐢ㄦ埛鐨勯儴闂�
+        String userId = ardAppPosition.getUserId();
+        //鑾峰彇鐢ㄦ埛鍏宠仈鐨勬墍鏈夌數瀛愬洿鏍�
+        List<ArdWall> ardWalls = ardWallMapper.selectArdWallListByUserId(userId);
+        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("2")).collect(Collectors.toList());
+        //褰撳墠鐢ㄦ埛鐨勪綅缃�
+        Point userPoint = new Point(ardAppPosition.getLongitude(), ardAppPosition.getLatitude());
+        if(ardWallsNoIn.size() > 0){//鍒ゆ柇绂佸叆
+            for(ArdWall wall : ardWallsNoIn){
+                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());
+                ardAlarmWall.setWallName(wall.getWallName());
+                ardAlarmWall.setUserId(userId);
+                ardAlarmWall.setAlarmTime(DateUtils.getNowDate());
+                ardAlarmWall.setAlarmType(wall.getType());
+                ardAlarmWall.setLongitude(ardAppPosition.getLongitude());
+                ardAlarmWall.setLatitude(ardAppPosition.getLatitude());
+                ardAlarmWall.setAltitude(ardAppPosition.getAltitude());
+                String key = userId + "_" + wallId;//鏈�鍚庝竴娆℃姤璀︾紦瀛榢ey
+                if (inPolygon) {
+                    //绂佸叆鍥存爮鍒欒嫢鍦ㄥ洿鏍忓唴,鑾峰彇棣栨杩涘叆鍥存爮鎶ヨID
+                    String lastInAlarmId = firstAlarmMap.get(key);
+                    //鍒ゆ柇褰撳墠鐢ㄦ埛鏄惁棣栨杩涘叆鍥存爮鍐�
+                    if (lastInAlarmId == null) {
+                        //褰撳墠鐢ㄦ埛棣栨杩涘叆鐢熸垚鎶ヨ
+                        String uuid = IdUtils.simpleUUID();
+                        ardAlarmWall.setId(uuid);
+                        ardAlarmWallService.insertArdAlarmWall(ardAlarmWall);
+                        //璁板綍棣栨鎶ヨid
+                        firstAlarmMap.put(key, uuid);
+                    } else {
+                        //鐢ㄦ埛宸茶繘鍏ユ洿鏂版渶鍚庢姤璀�
+                        ardAlarmWall.setId(lastInAlarmId);
+                        ardAlarmWallService.updateArdAlarmWall(ardAlarmWall);
+                    }
+                    ardAlarmWalls.add(ardAlarmWall);
+                } else {
+                    //绂佸叆鍥存爮鍒欒嫢鍦ㄥ洿鏍忓鍒欑Щ闄ゆ姤璀︾紦瀛�
+                    firstAlarmMap.remove(key);
+                }
+            }
+        }
+
+        Boolean noOutFlag = true;
+        if(ardWallsNoOut.size() > 0) {//鍒ゆ柇绂佸嚭
+            for(ArdWall wall : ardWallsNoOut){
+                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);//鍒ゆ柇鏄惁鍦ㄥ洿鏍忓唴
+                if (!inPolygon) {
+                    noOutFlag = true;
+                } else {
+                    noOutFlag = false;
+                    break;
+                }
+            }
+        }
+        if(noOutFlag){//鍏ㄩ儴绂佸嚭鐢靛瓙鍥存爮閮藉嚭鍘讳簡
+            for(ArdWall wall : ardWallsNoOut){
+                String wallId = wall.getId();//鍥存爮ID
+                //鍒涘缓鍥存爮鎶ヨ瀹炰綋瀵硅薄
+                ArdAlarmWall ardAlarmWall = new ArdAlarmWall();
+                ardAlarmWall.setWallId(wall.getId());
+                ardAlarmWall.setWallName(wall.getWallName());
+                ardAlarmWall.setUserId(userId);
+                ardAlarmWall.setAlarmTime(DateUtils.getNowDate());
+                ardAlarmWall.setAlarmType(wall.getType());
+                ardAlarmWall.setLongitude(ardAppPosition.getLongitude());
+                ardAlarmWall.setLatitude(ardAppPosition.getLatitude());
+                ardAlarmWall.setAltitude(ardAppPosition.getAltitude());
+                String key = userId + "_" + wallId;//鏈�鍚庝竴娆℃姤璀︾紦瀛榢ey
+                //绂佸嚭鍥存爮鍒欒嫢鍦ㄥ洿鏍忓,鑾峰彇棣栨璧板嚭鍥存爮鎶ヨ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){
+                String wallId = wall.getId();//鍥存爮ID
+                String key = userId + "_" + wallId;//鏈�鍚庝竴娆℃姤璀︾紦瀛榢ey
+                firstAlarmMap.remove(key);
+            }
+        }
+        return ardAlarmWalls;
     }
 
     @Override
@@ -349,6 +473,12 @@
     }
 
     @Override
+    public List<Map<String,Object>> getOnlineCommanderPosition(String soilderId) {
+        List<Map<String,Object>> result = ardAppPositionMapper.getOnlineCommanderPosition(soilderId);
+        return result;
+    }
+
+    /*@Override
     public void sendCheckCommandersPosition(String usersId,Map<String, Object> para) {
         String reason = (String) para.get("reason");
         List<String> usersIdList = (List<String>) para.get("usersIdList");
@@ -363,9 +493,9 @@
             value.put("soilderId",usersId);
             redisCache.setCacheObject(key, JSON.toJSONString(value));
         }
-    }
+    }*/
 
-    @Override
+    /*@Override
     public void sendCheckSYCarsPosition(String usersId, Map<String, Object> para) {
         String reason = (String) para.get("reason");
         List<String> usersIdList = (List<String>) para.get("usersIdList");
@@ -380,9 +510,9 @@
             value.put("soilderId",usersId);
             redisCache.setCacheObject(key, JSON.toJSONString(value));
         }
-    }
+    }*/
 
-    @Override
+    /*@Override
     public List<Map<String, Object>> getCheckCommandersPosition(String usersId) {
         String key = "checkCommanderPosition_" + usersId + "_";
         List<Object> keyValueList = redisCache.getListKey(key);
@@ -396,9 +526,9 @@
             }
         }
         return result;
-    }
+    }*/
 
-    @Override
+    /*@Override
     public List<Map<String, Object>> getCheckSYCarsPosition(String usersId) {
         String key = "checkSYCarsPosition_" + usersId + "_";
         List<Object> keyValueList = redisCache.getListKey(key);
@@ -412,9 +542,9 @@
             }
         }
         return result;
-    }
+    }*/
 
-    @Override
+    /*@Override
     public Map<String, List<Map<String, Object>>> getCheckPosition(String usersId) {
         Map<String, List<Map<String, Object>>> result = new HashMap();
         //鏌ョ湅鎸囨尌绔綅缃敵璇�
@@ -454,5 +584,5 @@
         result.put("commander",resultCommanderPosition);
         result.put("SYCars",resultSYCarsPosition);
         return result;
-    }
+    }*/
 }

--
Gitblit v1.9.3