From 9e4440e8ce1ed3c72932f3f62f4d05f55c9080e6 Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期四, 17 八月 2023 11:49:12 +0800
Subject: [PATCH] 新增加司机端接口

---
 driver/guns-admin/src/main/java/com/supersavedriving/driver/modular/system/service/impl/OrderPositionServiceImpl.java |   23 +++++++++++++++++++++--
 1 files changed, 21 insertions(+), 2 deletions(-)

diff --git a/driver/guns-admin/src/main/java/com/supersavedriving/driver/modular/system/service/impl/OrderPositionServiceImpl.java b/driver/guns-admin/src/main/java/com/supersavedriving/driver/modular/system/service/impl/OrderPositionServiceImpl.java
index 8c6a2bd..4ee5ef9 100644
--- a/driver/guns-admin/src/main/java/com/supersavedriving/driver/modular/system/service/impl/OrderPositionServiceImpl.java
+++ b/driver/guns-admin/src/main/java/com/supersavedriving/driver/modular/system/service/impl/OrderPositionServiceImpl.java
@@ -7,6 +7,7 @@
 import com.supersavedriving.driver.modular.system.model.Order;
 import com.supersavedriving.driver.modular.system.service.IOrderService;
 import com.supersavedriving.driver.modular.system.util.GeodesyUtil;
+import com.supersavedriving.driver.modular.system.util.PushUtil;
 import com.supersavedriving.driver.modular.system.util.RedisUtil;
 import com.supersavedriving.driver.modular.system.warpper.DriverPositionWarpper;
 import com.supersavedriving.driver.modular.system.warpper.OrderPositionWarpper;
@@ -34,6 +35,9 @@
     @Autowired
     private IOrderService orderService;
 
+    @Autowired
+    private PushUtil pushUtil;
+
     private Map<String, Integer> map = new HashMap<>();
 
 
@@ -48,7 +52,22 @@
     @Override
     public void saveOrderPosition(DriverPositionWarpper driverPositionWarpper) throws Exception {
         Integer orderId = driverPositionWarpper.getOrderId();
+        Integer driverId = driverPositionWarpper.getDriverId();
         Order order = orderService.selectById(orderId);
+        if(null == order.getDriverId() || order.getDriverId().compareTo(driverId) != 0){
+            return;
+        }
+        //开始服务提醒
+        if(order.getState() == 104){
+            String fromLonLat = order.getStartLng() + "," + order.getStartLat();
+            String toLonLat = driverPositionWarpper.getLon() + "," + driverPositionWarpper.getLat();
+            Map<String, Double> distance = GeodesyUtil.getDistance(fromLonLat, toLonLat);
+            Double wgs84 = distance.get("WGS84");
+            if(wgs84.compareTo(200D) >= 0){
+                pushUtil.pushStartServer(2, driverId);
+            }
+        }
+
         if(order.getState() != 105 && order.getState() != 401){
             return;
         }
@@ -136,7 +155,7 @@
             }
         }
 
-        if(50 >= wgs84 && 3 <= (null == num ? 0 : num)){//20秒(5秒上传一次数据)
+        if(50 >= wgs84 && 6 <= (null == num ? 0 : num)){//30秒(5秒上传一次数据)
             Integer integer = map.get(order.getId().toString());
             map.put(order.getId().toString(), null == integer ? 0 : integer + 1);
             //进入等待状态
@@ -152,7 +171,7 @@
                 e.printStackTrace();
             }
         }
-        if(50 >= wgs84 && 3 > (null == num ? 0 : num)){
+        if(50 >= wgs84 && 6 > (null == num ? 0 : num)){
             Integer integer = map.get(order.getId().toString());
             map.put(order.getId().toString(), null == integer ? 0 : integer + 1);
         }

--
Gitblit v1.7.1