From d02ea504ec952cdc920be3f7ddb6b79dccd24f56 Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期日, 30 七月 2023 05:03:09 +0800
Subject: [PATCH] 添加企业流水记录
---
driver/guns-admin/src/main/java/com/supersavedriving/driver/modular/system/service/impl/OrderPositionServiceImpl.java | 72 +++++++++++++++++++++++++++++-------
1 files changed, 58 insertions(+), 14 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 3fded99..8c6a2bd 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
@@ -48,8 +48,12 @@
@Override
public void saveOrderPosition(DriverPositionWarpper driverPositionWarpper) throws Exception {
Integer orderId = driverPositionWarpper.getOrderId();
+ Order order = orderService.selectById(orderId);
+ if(order.getState() != 105 && order.getState() != 401){
+ return;
+ }
Integer orderType = driverPositionWarpper.getOrderType();
- File file = new File(filePath + orderId + "_" + orderType + ".json");
+ File file = new File(filePath + orderId + ".json");
if(!file.exists()){
file.getParentFile().mkdirs();
file.createNewFile();
@@ -59,14 +63,37 @@
OrderPositionWarpper orderPositionWarpper = orderPositionWarppers.get(orderPositionWarppers.size() - 1);
saveOrderMileage(driverPositionWarpper, orderPositionWarpper);
}
- OrderPositionWarpper orderPositionWarpper = new OrderPositionWarpper();
- BeanUtils.copyProperties(driverPositionWarpper, orderPositionWarpper);
- orderPositionWarpper.setInsertTime(new Date());
- orderPositionWarppers.add(orderPositionWarpper);
+ //大于100米才存储有效定位数据
+ if(orderPositionWarppers.size() > 0){
+ OrderPositionWarpper orderPositionWarpper1 = orderPositionWarppers.get(orderPositionWarppers.size() - 1);
+ String fromLonLat = driverPositionWarpper.getLon() + "," + driverPositionWarpper.getLat();
+ String toLonLat = orderPositionWarpper1.getLon() + "," + orderPositionWarpper1.getLat();
+ Map<String, Double> distance = GeodesyUtil.getDistance(fromLonLat, toLonLat);
+ Double wgs84 = distance.get("WGS84");
+
+// long timeMillis = System.currentTimeMillis();
+// long time = orderPositionWarpper1.getInsertTime().getTime();
+// long t = timeMillis - time;
+// if(wgs84 >= 200 && t <= 8){//排除位置漂移
+// return;
+// }
+
+ if(wgs84 >= 50){//5秒165米
+ OrderPositionWarpper orderPositionWarpper = new OrderPositionWarpper();
+ BeanUtils.copyProperties(driverPositionWarpper, orderPositionWarpper);
+ orderPositionWarpper.setInsertTime(new Date());
+ orderPositionWarppers.add(orderPositionWarpper);
+ }
+ }else{
+ OrderPositionWarpper orderPositionWarpper = new OrderPositionWarpper();
+ BeanUtils.copyProperties(driverPositionWarpper, orderPositionWarpper);
+ orderPositionWarpper.setInsertTime(new Date());
+ orderPositionWarppers.add(orderPositionWarpper);
+ }
//写入相应的文件
PrintWriter out = new PrintWriter(new FileWriter(file));
- out.write(JSON.toJSONString(driverPositionWarpper));
+ out.write(JSON.toJSONString(orderPositionWarppers));
out.flush();
out.close();
}
@@ -84,8 +111,17 @@
Order order = orderService.selectById(driverPositionWarpper.getOrderId());
Double wgs84 = distance.get("WGS84");
Integer num = map.get(order.getId().toString());
- if(50 < wgs84){
+
+// long timeMillis = System.currentTimeMillis();
+// long time = orderPositionWarpper.getInsertTime().getTime();
+// long t = timeMillis - time;
+// if(wgs84 >= 200 && t <= 8){//排除位置漂移
+// return;
+// }
+
+ if(50 < wgs84){//5秒165米
order.setActualMileage(order.getActualMileage() + wgs84.intValue());
+ orderService.updateById(order);
map.put(order.getId().toString(), 0);
if(order.getState() == 401){//定位变动,自动开始服务
@@ -98,12 +134,15 @@
e.printStackTrace();
}
}
-
}
- if(50 >= wgs84 && 12 <= (null == num ? 0 : num)){//1分钟(5秒上传一次数据)
+
+ if(50 >= wgs84 && 3 <= (null == num ? 0 : num)){//20秒(5秒上传一次数据)
Integer integer = map.get(order.getId().toString());
- map.put(order.getId().toString(), integer++);
+ map.put(order.getId().toString(), null == integer ? 0 : integer + 1);
//进入等待状态
+ if(order.getState() == 401){
+ return;
+ }
ProcessOperationsWarpper processOperationsWarpper = new ProcessOperationsWarpper();
processOperationsWarpper.setOrderId(order.getId());
processOperationsWarpper.setState(401);
@@ -112,11 +151,10 @@
} catch (Exception e) {
e.printStackTrace();
}
-
}
- if(50 >= wgs84 && 12 > (null == num ? 0 : num)){
+ if(50 >= wgs84 && 3 > (null == num ? 0 : num)){
Integer integer = map.get(order.getId().toString());
- map.put(order.getId().toString(), integer++);
+ map.put(order.getId().toString(), null == integer ? 0 : integer + 1);
}
}
@@ -133,8 +171,9 @@
@Override
public List<OrderPositionWarpper> queryPosition(Integer orderId, Integer orderType) throws Exception {
//将数据存储到文件中
- File file = new File(filePath + orderId + "_" + orderType + ".txt");
+ File file = new File(filePath + orderId + ".json");
if(!file.exists()){
+ System.err.println("不存在");
return new ArrayList<>();
}
//读取文件(字符流)
@@ -153,4 +192,9 @@
}
+ @Override
+ public void initMap(Long orderId) throws Exception {
+ map.put(orderId.toString(), 0);
+ }
+
}
--
Gitblit v1.7.1