From 8ad9561f36bda4ccc8a3547d9157af706397c136 Mon Sep 17 00:00:00 2001
From: aijinhui <aijinhui>
Date: 星期二, 24 十月 2023 16:29:17 +0800
Subject: [PATCH] 清淤接口

---
 ard-work/src/main/java/com/ruoyi/sy/service/ArdAccessNumService.java          |   12 +++
 ard-work/src/main/java/com/ruoyi/sy/domain/ArdAccessNum.java                  |   13 +++
 ard-work/src/main/java/com/ruoyi/sy/domain/ArdWallWarming.java                |   13 +++
 ard-work/src/main/java/com/ruoyi/sy/mapper/ArdAccessNumMapper.java            |   10 ++
 ard-work/src/main/java/com/ruoyi/sy/controller/OilWallController.java         |   29 +++++--
 ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplPosition.java         |  104 +++++++++++++++----------
 ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdAccessNumServiceImpl.java |   26 ++++++
 ard-work/src/main/java/com/ruoyi/sy/domain/ArdAccessFence.java                |    4 
 8 files changed, 160 insertions(+), 51 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/sy/controller/OilWallController.java b/ard-work/src/main/java/com/ruoyi/sy/controller/OilWallController.java
index 2e34462..af41116 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/controller/OilWallController.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/controller/OilWallController.java
@@ -3,15 +3,10 @@
 import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.common.utils.spring.SpringUtils;
 import com.ruoyi.common.utils.uuid.UUID;
-import com.ruoyi.sy.domain.ArdAccessFence;
-import com.ruoyi.sy.domain.ArdOilWall;
+import com.ruoyi.sy.domain.*;
+import com.ruoyi.sy.mapper.ArdAccessNumMapper;
 import com.ruoyi.sy.param.OilWallParam;
-import com.ruoyi.sy.service.ArdAccessFenceService;
-import com.ruoyi.sy.service.ArdOilWallService;
-import com.ruoyi.sy.domain.ArdSyCar;
-import com.ruoyi.sy.domain.ArdSyUser;
-import com.ruoyi.sy.service.IArdSyCarService;
-import com.ruoyi.sy.service.IArdSyUserService;
+import com.ruoyi.sy.service.*;
 import com.ruoyi.sy.service.impl.ArdAccessFenceServiceImpl;
 import com.ruoyi.sy.service.impl.ArdOilWallServiceImpl;
 import com.ruoyi.system.service.ISysConfigService;
@@ -49,6 +44,9 @@
 
     @Autowired
     private ArdAccessFenceService ardAccessFenceService;
+
+    @Autowired
+    private ArdAccessNumService ardAccessNumService;
 
     @PostMapping("/add")
     @ApiOperation("娣诲姞鐢靛瓙鍥存爮")
@@ -108,6 +106,21 @@
         return Results.succeed(ardAccessFenceService.all());
     }
 
+    @GetMapping("/rollTime")
+    @ApiOperation("鏌ヨ鏃堕棿姝ラ暱")
+    public Results rollTime(){
+        return Results.succeed(ardAccessNumService.queryNum());
+    }
 
+    @GetMapping("/updTime")
+    @ApiOperation("淇濆瓨鏃堕棿姝ラ暱")
+    public Results updTime(@RequestBody ArdAccessNum ardAccessNum){
+        return Results.succeed(ardAccessNumService.add(ardAccessNum));
+    }
 
+//    @GetMapping("/addCar")
+//    @ApiOperation("鎵嬪姩娣诲姞杞﹁締")
+//    public Results addCar(@RequestBody ArdAccessNum ardAccessNum){
+//        return Results.succeed();
+//    }
 }
diff --git a/ard-work/src/main/java/com/ruoyi/sy/domain/ArdAccessFence.java b/ard-work/src/main/java/com/ruoyi/sy/domain/ArdAccessFence.java
index 6f0e30a..bb14e25 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/domain/ArdAccessFence.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/domain/ArdAccessFence.java
@@ -14,8 +14,10 @@
     private String deptName;
     private String lng;
     private String lat;
-    private String intoShipment;
+    private String intoShipmentId;
     private String intoShipmentTime;
     private String intoUnloadId;
     private String intoUnloadTime;
+    private String outShipmentId;
+    private String outShipmentTime;
 }
diff --git a/ard-work/src/main/java/com/ruoyi/sy/domain/ArdAccessNum.java b/ard-work/src/main/java/com/ruoyi/sy/domain/ArdAccessNum.java
new file mode 100644
index 0000000..71d8a81
--- /dev/null
+++ b/ard-work/src/main/java/com/ruoyi/sy/domain/ArdAccessNum.java
@@ -0,0 +1,13 @@
+package com.ruoyi.sy.domain;
+
+import lombok.Data;
+
+/**
+ * @author Administrator
+ */
+@Data
+public class ArdAccessNum {
+    private String id;
+    private String name;
+    private String num;
+}
diff --git a/ard-work/src/main/java/com/ruoyi/sy/domain/ArdWallWarming.java b/ard-work/src/main/java/com/ruoyi/sy/domain/ArdWallWarming.java
new file mode 100644
index 0000000..957dbe9
--- /dev/null
+++ b/ard-work/src/main/java/com/ruoyi/sy/domain/ArdWallWarming.java
@@ -0,0 +1,13 @@
+package com.ruoyi.sy.domain;
+
+import lombok.Data;
+
+@Data
+public class ArdWallWarming {
+    private String id;
+    private String accessId;
+    private String lng;
+    private String lat;
+    private String time;
+    private String sustain;
+}
diff --git a/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplPosition.java b/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplPosition.java
index 04f03c5..7fd9962 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplPosition.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplPosition.java
@@ -86,13 +86,6 @@
                 String time = (String) gpsMap.get("result");//瀹氫綅鏃堕棿
                 String deptNum = (String) result.get("deptId");//鑾峰彇閮ㄩ棬ID
                 String deptName = (String) result.get("deptName");//鑾峰彇閮ㄩ棬鍚嶇О
-//                String carId = "13";
-//                String lng = "124.74695492384757";
-//                String lat = "46.09510768522894";
-//                String carName = "榛慐21397";//鑾峰彇杞︾墝鍙�
-//                String time = "20231019161815";//瀹氫綅鏃堕棿
-//                String deptNum = "100";//鑾峰彇閮ㄩ棬ID
-//                String deptName = "鍘傜骇";//鑾峰彇閮ㄩ棬鍚嶇О
                 //瀹氫箟2缁寸┖闂�
                 Point2D.Double point = new Point2D.Double(Double.parseDouble(lng), Double.parseDouble(lat));
                 List<Point2D.Double> pts = new ArrayList<Point2D.Double>();
@@ -100,7 +93,7 @@
                 ArdAccessFence ardAccessFence = ((ArdAccessFenceServiceImpl)SpringUtils.getBean("ArdAccessFenceServiceImpl")).queryAccess(carId);
                 //濡傛灉娌℃湁璇存槑杞﹁締鏈繘鍏ヨ娌圭偣锛岄渶瑕佸尮閰嶆墍鏈夎娌圭偣鍥存爮
                 if(ardAccessFence==null){
-                    //鍖归厤鍏ㄩ儴瑁呮补鐐瑰洿鏍�
+                    //杞﹁締鏈繘鍏ヨ娌圭偣
                     List<ArdOilWall> ardOilWalls = ((ArdOilWallServiceImpl)SpringUtils.getBean("ArdOilWallServiceImpl")).accessAll();
                     for (int i = 0; i < ardOilWalls.size(); i++) {
                         pts.clear();
@@ -110,14 +103,14 @@
                             pts.add(new Point2D.Double(Double.parseDouble(coord[j]), Double.parseDouble(coord[j+1])));
                         }
                         if(GeoTools.IsPtInPoly(point, pts)){
-                            //杩涘叆浜嗗洿鏍忓叆搴�
+                            //杩涘叆瑁呮补鐐瑰叆搴�
                             ArdAccessFence ardAccessFence1 = new ArdAccessFence();
                             ardAccessFence1.setId(String.valueOf(UUID.randomUUID()));
                             ardAccessFence1.setCarId(carId);
                             ardAccessFence1.setCarName(carName);
                             ardAccessFence1.setDeptId(deptNum);
                             ardAccessFence1.setDeptName(deptName);
-                            ardAccessFence1.setIntoShipment("杩涘叆瑁呮补鐐�");
+                            ardAccessFence1.setIntoShipmentId(ardOilWall.getId());
                             ardAccessFence1.setIntoShipmentTime(time);
                             ardAccessFence1.setLng(lng);
                             ardAccessFence1.setLat(lat);
@@ -126,47 +119,74 @@
                         }
                     }
                 }else {
-                    String unload = ardAccessFence.getIntoUnloadId();
-                    //濡傛灉unload涓虹┖锛屽垽鏂槸鍚﹁繘鍏ュ嵏娌圭偣
-                    if(unload==null){
-                        //鏌ヨ鍏ㄩ儴鍗告补鐐�
-                        List<ArdOilWall> ardOilWalls = ((ArdOilWallServiceImpl) SpringUtils.getBean("ArdOilWallServiceImpl")).uploadAll();
-                        for (int i = 0; i < ardOilWalls.size(); i++) {
-                            pts.clear();
-                            ArdOilWall ardOilWall = ardOilWalls.get(i);
-                            String[] coord = ardOilWall.getCoord().split(",");
-                            for (int j = 0; j < coord.length; j = j + 3) {
-                                pts.add(new Point2D.Double(Double.parseDouble(coord[j]), Double.parseDouble(coord[j + 1])));
-                            }
-                            if (GeoTools.IsPtInPoly(point, pts)) {
-                                //杩涘叆鍗告补鐐�,瀛樺叆鍗告补鐐瑰洿鏍廔D
-                                ardAccessFence.setIntoUnloadId(ardOilWall.getId());
-                                ardAccessFence.setIntoUnloadTime(time);
-                                break;
-                            }
-                        }
-                        ardAccessFence.setLng(lng);
-                        ardAccessFence.setLat(lat);
-                        ((ArdAccessFenceServiceImpl)SpringUtils.getBean("ArdAccessFenceServiceImpl")).updAccess(ardAccessFence);
-                    }else {
-                        //濡傛灉unload鏈夊�硷紝鍒欑户缁垽鏂槸鍚﹀嚭浜嗗嵏娌圭偣锛屽尮閰嶅嵏娌圭偣鐨勫敮涓�ID
-                        ArdOilWall ardOilWall = ((ArdOilWallServiceImpl) SpringUtils.getBean("ArdOilWallServiceImpl")).one(unload);
+                    String out = ardAccessFence.getOutShipmentId();
+                    if(out == null){
+                        //杞﹁締鏈紑鍑鸿娌圭偣
+                        String into = ardAccessFence.getIntoShipmentId();
+                        ArdOilWall ardOilWall = ((ArdOilWallServiceImpl) SpringUtils.getBean("ArdOilWallServiceImpl")).one(into);
                         pts.clear();
                         String[] coord = ardOilWall.getCoord().split(",");
                         for (int j = 0; j < coord.length; j = j + 3) {
                             pts.add(new Point2D.Double(Double.parseDouble(coord[j]), Double.parseDouble(coord[j + 1])));
                         }
                         if (!GeoTools.IsPtInPoly(point, pts)) {
-                            //寮�鍑轰簡鍗告补鐐瑰洿鏍忥紝鍒犻櫎璇ユ潯杞﹁締鏁版嵁
-                            ((ArdAccessFenceServiceImpl) SpringUtils.getBean("ArdAccessFenceServiceImpl")).delAccess(carId);
+                            //杞﹁締寮�鍑鸿娌圭偣
+                            ardAccessFence.setOutShipmentId(into);
+                            ardAccessFence.setOutShipmentTime(time);
+                        }
+                        ardAccessFence.setLng(lng);
+                        ardAccessFence.setLat(lat);
+                        ((ArdAccessFenceServiceImpl)SpringUtils.getBean("ArdAccessFenceServiceImpl")).updAccess(ardAccessFence);
+                    }else {
+                        //杞﹁締宸茬粡寮�鍑鸿娌圭偣锛屽垽鏂槸鍚﹁繘鍏ュ嵏娌圭偣
+                        String unload = ardAccessFence.getIntoUnloadId();
+                        //濡傛灉unload涓虹┖锛屽垽鏂槸鍚﹁繘鍏ュ嵏娌圭偣
+                        if (unload == null) {
+                            //杞﹁締鏈繘鍏ュ嵏娌圭偣
+                            List<ArdOilWall> ardOilWalls = ((ArdOilWallServiceImpl) SpringUtils.getBean("ArdOilWallServiceImpl")).uploadAll();
+                            //鏄惁鍦ㄨ矾涓�
+                            Boolean isRoad = true;
+                            for (int i = 0; i < ardOilWalls.size(); i++) {
+                                pts.clear();
+                                ArdOilWall ardOilWall = ardOilWalls.get(i);
+                                String[] coord = ardOilWall.getCoord().split(",");
+                                for (int j = 0; j < coord.length; j = j + 3) {
+                                    pts.add(new Point2D.Double(Double.parseDouble(coord[j]), Double.parseDouble(coord[j + 1])));
+                                }
+                                if (GeoTools.IsPtInPoly(point, pts)) {
+                                    //杩涘叆鍗告补鐐�,瀛樺叆鍗告补鐐瑰洿鏍廔D
+                                    ardAccessFence.setIntoUnloadId(ardOilWall.getId());
+                                    ardAccessFence.setIntoUnloadTime(time);
+                                    ardAccessFence.setLng(lng);
+                                    ardAccessFence.setLat(lat);
+                                    ((ArdAccessFenceServiceImpl) SpringUtils.getBean("ArdAccessFenceServiceImpl")).updAccess(ardAccessFence);
+                                    //宸茬粡杩涘叆鍗告补鐐癸紝涓嶅湪璺笂涓嶉渶瑕佸仠杞︽姤璀�
+                                    isRoad = false;
+                                    break;
+                                }
+                            }
+                            if(isRoad){
+                                //濡傛灉鍦ㄨ矾涓婇渶瑕佽褰曟瘡娆″潗鏍囦笌涓婃鏄惁鐩稿悓锛屽鏋滀竴鏍锋洿鏂板仠鐣欐椂闂�
+                            }
                         }else {
-                            //鏈紑鍑哄嵏娌圭偣锛屾洿鏂扮粡绾害淇濆瓨
-                            ardAccessFence.setLng(lng);
-                            ardAccessFence.setLat(lat);
-                            ((ArdAccessFenceServiceImpl)SpringUtils.getBean("ArdAccessFenceServiceImpl")).updAccess(ardAccessFence);
+                            //杞﹁締宸茬粡杩涘叆鍗告补鐐癸紝鍒ゆ柇鏄惁宸茬粡寮�鍑哄嵏娌圭偣
+                            ArdOilWall ardOilWall = ((ArdOilWallServiceImpl) SpringUtils.getBean("ArdOilWallServiceImpl")).one(unload);
+                            pts.clear();
+                            String[] coord = ardOilWall.getCoord().split(",");
+                            for (int j = 0; j < coord.length; j = j + 3) {
+                                pts.add(new Point2D.Double(Double.parseDouble(coord[j]), Double.parseDouble(coord[j + 1])));
+                            }
+                            if (!GeoTools.IsPtInPoly(point, pts)) {
+                                //寮�鍑轰簡鍗告补鐐瑰洿鏍忥紝鍒犻櫎璇ユ潯杞﹁締鏁版嵁
+                                ((ArdAccessFenceServiceImpl) SpringUtils.getBean("ArdAccessFenceServiceImpl")).delAccess(carId);
+                            }else {
+                                //鏈紑鍑哄嵏娌圭偣锛屾洿鏂扮粡绾害淇濆瓨
+                                ardAccessFence.setLng(lng);
+                                ardAccessFence.setLat(lat);
+                                ((ArdAccessFenceServiceImpl)SpringUtils.getBean("ArdAccessFenceServiceImpl")).updAccess(ardAccessFence);
+                            }
                         }
                     }
-
                 }
                 //娓呮筏鍏ユ爮缁撴潫------------
 
diff --git a/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdAccessNumMapper.java b/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdAccessNumMapper.java
new file mode 100644
index 0000000..6633f15
--- /dev/null
+++ b/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdAccessNumMapper.java
@@ -0,0 +1,10 @@
+package com.ruoyi.sy.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.ruoyi.sy.domain.ArdAccessNum;
+
+/**
+ * @author Administrator
+ */
+public interface ArdAccessNumMapper extends BaseMapper<ArdAccessNum> {
+}
diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/ArdAccessNumService.java b/ard-work/src/main/java/com/ruoyi/sy/service/ArdAccessNumService.java
new file mode 100644
index 0000000..316b89f
--- /dev/null
+++ b/ard-work/src/main/java/com/ruoyi/sy/service/ArdAccessNumService.java
@@ -0,0 +1,12 @@
+package com.ruoyi.sy.service;
+
+import com.ruoyi.sy.domain.ArdAccessNum;
+
+import java.util.List;
+
+public interface ArdAccessNumService {
+
+    List<ArdAccessNum> queryNum();
+
+    int add(ArdAccessNum ardAccessNum);
+}
diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdAccessNumServiceImpl.java b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdAccessNumServiceImpl.java
new file mode 100644
index 0000000..d799a92
--- /dev/null
+++ b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdAccessNumServiceImpl.java
@@ -0,0 +1,26 @@
+package com.ruoyi.sy.service.impl;
+
+import com.ruoyi.sy.domain.ArdAccessNum;
+import com.ruoyi.sy.mapper.ArdAccessNumMapper;
+import com.ruoyi.sy.service.ArdAccessNumService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+
+import java.util.List;
+
+@Service
+public class ArdAccessNumServiceImpl implements ArdAccessNumService {
+
+    @Autowired
+    private ArdAccessNumMapper ardAccessNumMapper;
+
+    @Override
+    public List<ArdAccessNum> queryNum() {
+        return ardAccessNumMapper.selectList(null);
+    }
+
+    @Override
+    public int add(ArdAccessNum ardAccessNum) {
+        return ardAccessNumMapper.insert(ardAccessNum);
+    }
+}

--
Gitblit v1.9.3