From e52227b01983146f2e3c81dc575141d8b9889497 Mon Sep 17 00:00:00 2001
From: yanghb <yanghb>
Date: 星期五, 21 四月 2023 10:16:30 +0800
Subject: [PATCH] 代码调整

---
 DriverTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/specialTrain/server/impl/OrderPrivateCarServiceImpl.java |  818 +++++++++++-----------------------------------------------
 1 files changed, 157 insertions(+), 661 deletions(-)

diff --git a/DriverTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/specialTrain/server/impl/OrderPrivateCarServiceImpl.java b/DriverTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/specialTrain/server/impl/OrderPrivateCarServiceImpl.java
index d2d2f21..e4521e0 100644
--- a/DriverTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/specialTrain/server/impl/OrderPrivateCarServiceImpl.java
+++ b/DriverTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/specialTrain/server/impl/OrderPrivateCarServiceImpl.java
@@ -1,18 +1,22 @@
 package com.stylefeng.guns.modular.specialTrain.server.impl;
 
 import com.alibaba.fastjson.JSON;
-import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.mapper.EntityWrapper;
 import com.baomidou.mybatisplus.service.impl.ServiceImpl;
-import com.stylefeng.guns.core.util.ToolUtil;
 import com.stylefeng.guns.modular.specialTrain.dao.OrderPrivateCarMapper;
 import com.stylefeng.guns.modular.specialTrain.model.OrderPrivateCar;
 import com.stylefeng.guns.modular.specialTrain.server.IOrderPrivateCarService;
+import com.stylefeng.guns.modular.system.dao.CarServiceMapper;
 import com.stylefeng.guns.modular.system.dao.RegionMapper;
 import com.stylefeng.guns.modular.system.dao.SystemPriceMapper;
-import com.stylefeng.guns.modular.system.model.*;
-import com.stylefeng.guns.modular.system.service.*;
+import com.stylefeng.guns.modular.system.model.CarService;
+import com.stylefeng.guns.modular.system.model.Driver;
+import com.stylefeng.guns.modular.system.model.OrderPosition;
+import com.stylefeng.guns.modular.system.model.Region;
+import com.stylefeng.guns.modular.system.service.IDriverService;
+import com.stylefeng.guns.modular.system.service.IOrderPositionService;
+import com.stylefeng.guns.modular.system.service.ISystemNoticeService;
 import com.stylefeng.guns.modular.system.util.*;
 import com.stylefeng.guns.modular.taxi.model.OrderTaxi;
 import com.stylefeng.guns.modular.taxi.service.IOrderTaxiService;
@@ -70,14 +74,8 @@
     @Autowired
     private GeodesyUtil geodesyUtil;
 
-    @Autowired
-    private IOrderAdditionalFeeService orderAdditionalFeeService;
-
-    @Autowired
-    private IAdditionalFeeService additionalFeeService;
-
-    @Autowired
-    private ICompanyService companyService;
+    @Resource
+    private CarServiceMapper carServiceMapper;
 
     @Value("${pushMinistryOfTransport}")
     private boolean pushMinistryOfTransport;
@@ -178,12 +176,19 @@
         orderPrivateCar.setTrackId(track);
 
         //调用移动的小号接口
-        Map<String, String> map = chinaMobileUtil.midAxbBindSend(orderPrivateCar.getPassengersPhone(), driver.getPhone(), (System.currentTimeMillis() + 86400000));
-            if(String.valueOf(map.get("code")).equals("200")){
+        Map<String, String> geocode = gdMapGeocodingUtil.geocode(orderPrivateCar.getStartLon().toString(), orderPrivateCar.getStartLat().toString());
+        Region region = regionMapper.query(geocode.get("districtCode"));
+        Map<String, String> map = chinaMobileUtil.midAxbBindSend(orderPrivateCar.getPassengersPhone(), driver.getPhone(), Integer.valueOf(region.getCitycode().substring(1)));
+        if(String.valueOf(map.get("code")).equals("200")){
             orderPrivateCar.setTelX(map.get("telX"));
             orderPrivateCar.setBindId(map.get("bindId"));
         }
 
+        //智慧屏订单
+        if(orderPrivateCar.getOrderSource() == 6){
+            CarService query = carServiceMapper.query(1, driver.getCarId());
+            orderPrivateCar.setServerCarModelId(query.getServerCarModelId());
+        }
         this.updateById(orderPrivateCar);
 
         //处理摆渡车的情况
@@ -195,7 +200,7 @@
                             .eq("userId", orderPrivateCar.getUserId())
                             .ne("state", 1)
                             .eq("crossCityOrderId", orderPrivateCar.getCrossCityOrderId())
-                            .eq("place", orderPrivateCar.getPlace()).ne("id", orderPrivateCar.getId())
+                            .eq("place", orderPrivateCar.getPlace())
             );
             List<OrderTaxi> list1 = orderTaxiService.selectList(
                     new EntityWrapper<OrderTaxi>()
@@ -241,8 +246,8 @@
             }
         }).start();
 
-        systemNoticeService.addSystemNotice(2, "您已成功抢得快车订单,请及时联系客户!", orderPrivateCar.getDriverId(), 1);
-        systemNoticeService.addSystemNotice(1, "您的订单已指派给" + driver.getName().substring(0, 1) + "师傅,请保持电话畅通!", orderPrivateCar.getUserId(), 1);
+        systemNoticeService.addSystemNotice(2, "您已成功抢得专车订单,请及时联系客户!", orderPrivateCar.getDriverId());
+        systemNoticeService.addSystemNotice(1, "您的订单已指派给" + driver.getName().substring(0, 1) + "师傅,请保持电话畅通!", orderPrivateCar.getUserId());
 
         new Thread(new Runnable() {
             @Override
@@ -259,8 +264,6 @@
     }
 
 
-    @Autowired
-    private RedisUtil redisUtil;
 
     /**
      * 获取订单详情页(服务中的页面)
@@ -270,106 +273,10 @@
      */
     @Override
     public Map<String, Object> queryOrderInfo(Integer orderId) throws Exception {
-        List<Map<String, Object>> orders = new ArrayList<>();
-
-        OrderPrivateCar orderPrivateCar = this.baseMapper.selectById(orderId);
-        if(orderPrivateCar.getPid()==null){
-            List<Map<String, Object>> order = this.baseMapper.queryOrderInfo(orderId,4,null,null);
-            if(order!=null){
-                orders.addAll(order);
-            }
-            String value = redisUtil.getValue("DRIVER" + String.valueOf(orderPrivateCar.getDriverId()));
-            order = this.baseMapper.queryOrderInfo(orderId,5,value.split(",")[0],value.split(",")[1]);
-            if(order!=null){
-                orders.addAll(order);
-            }
-
-            order = this.baseMapper.queryOrderInfo(orderId,6,null,null);
-            if(order!=null){
-                orders.addAll(order);
-            }
-        }else{
-            List<Map<String, Object>> order = this.baseMapper.queryOrderInfo(orderPrivateCar.getPid(),4,null,null);
-            if(order!=null){
-                orders.addAll(order);
-            }
-            String value = redisUtil.getValue("DRIVER" + String.valueOf(orderPrivateCar.getDriverId()));
-            order = this.baseMapper.queryOrderInfo(orderPrivateCar.getPid(),5,value.split(",")[0],value.split(",")[1]);
-            if(order!=null){
-                orders.addAll(order);
-            }
-
-            order = this.baseMapper.queryOrderInfo(orderPrivateCar.getPid(),6,null,null);
-            if(order!=null){
-                orders.addAll(order);
-            }
-        }
-
-
-        Map<String, Object> map = new HashMap<>();
-        map.put("line", "");
-        map.put("peopleNumber", 0);
-        map.put("orderNumber","");
-        map.put("totalMoney", 0d);
-        map.put("serverMoney", 0d);
-        map.put("emergencyCall",  "110");
-        map.put("orders", JSON.toJSONString(orders));
-        return map;
-        //return orderPrivateCarMapper.queryOrderInfo(orderId);
+        return orderPrivateCarMapper.queryOrderInfo(orderId);
     }
 
-    @Override
-    public Map<String, Object> queryOrderInfo2(Integer orderId) throws Exception {
-        /*List<Map<String, Object>> orders = new ArrayList<>();
 
-        List<Map<String, Object>> order = this.baseMapper.queryOrderInfo(orderId,4,null,null);
-        if(order!=null){
-            orders.addAll(order);
-        }
-        OrderPrivateCar orderPrivateCar = this.baseMapper.selectById(orderId);
-        String value = redisUtil.getValue("DRIVER" + String.valueOf(orderPrivateCar.getDriverId()));
-        order = this.baseMapper.queryOrderInfo(orderId,5,value.split(",")[0],value.split(",")[1]);
-        if(order!=null){
-            orders.addAll(order);
-        }
-
-        order = this.baseMapper.queryOrderInfo(orderId,6,null,null);
-        if(order!=null){
-            orders.addAll(order);
-        }
-
-        Map<String, Object> map = new HashMap<>();
-        map.put("line", "");
-        map.put("peopleNumber", 0);
-        map.put("orderNumber","");
-        map.put("totalMoney", 0d);
-        map.put("serverMoney", 0d);
-        map.put("emergencyCall",  "110");
-        map.put("orders", JSON.toJSONString(orders));
-        return map;*/
-        Map<String,Object> map = orderPrivateCarMapper.queryOrderInfo2(orderId);
-        OrderPrivateCar orderPrivateCar = this.baseMapper.selectById(orderId);
-        Integer canOperation=1;
-        if(orderPrivateCar.getState()<5){
-            if(orderPrivateCar.getPid()==null) {
-                List<Map<String, Object>> order = this.baseMapper.queryOrderInfo(orderId, 4, null, null);
-                if (order != null && order.size()>0) {
-                    if(!order.get(0).get("orderId").equals(orderId)){
-                        canOperation=0;
-                    }
-                }
-            }else {
-                List<Map<String, Object>> order = this.baseMapper.queryOrderInfo(orderPrivateCar.getPid(),4,null,null);
-                if(order!=null && order.size()>0){
-                    if(!order.get(0).get("orderId").equals(orderId)){
-                        canOperation=0;
-                    }
-                }
-            }
-        }
-        map.put("canOperation",canOperation);
-        return map;
-    }
 
     /**
      * 走订单流程操作
@@ -381,37 +288,16 @@
     @Override
     public ResultUtil process(Integer orderId, Integer state, Double lon, Double lat, String address) throws Exception {
         OrderPrivateCar orderPrivateCar = this.selectById(orderId);
-        Integer canOperation=1;
-        if(state<5){
-            if(orderPrivateCar.getPid()==null) {
-                List<Map<String, Object>> order = this.baseMapper.queryOrderInfo(orderId, 4, null, null);
-                if (order != null && order.size()>0) {
-                    if(!order.get(0).get("orderId").equals(orderId)){
-                        canOperation=0;
-                    }
-                }
-            }else {
-                List<Map<String, Object>> order = this.baseMapper.queryOrderInfo(orderPrivateCar.getPid(),4,null,null);
-                if(order!=null && order.size()>0){
-                    if(!order.get(0).get("orderId").equals(orderId)){
-                        canOperation=0;
-                    }
-                }
-            }
-            if(canOperation==0){
-                return ResultUtil.error("当前订单不能操作");
-            }
-        }
         switch (state){
             case 3://出发前往预约点
                 orderPrivateCar.setState(3);
                 orderPrivateCar.setSetOutTime(new Date());
-                systemNoticeService.addSystemNotice(1, "司机已出发,请耐心等待", orderPrivateCar.getUserId(), 1);
+                systemNoticeService.addSystemNotice(1, "司机已出发,请耐心等待", orderPrivateCar.getUserId());
                 break;
             case 4://到达预约点,等待客户上车
                 orderPrivateCar.setState(4);
                 orderPrivateCar.setArriveTime(new Date());
-                systemNoticeService.addSystemNotice(1, "司机已到达您设置的预约地点,请及时上车", orderPrivateCar.getUserId(), 1);
+                systemNoticeService.addSystemNotice(1, "司机已到达您设置的预约地点,请及时上车", orderPrivateCar.getUserId());
                 break;
             case 5://开始服务
                 orderPrivateCar.setBoardingLon(lon);
@@ -422,7 +308,6 @@
                 orderPrivateCar.setStartServiceTime(new Date());
 
                 pushUtil.pushDriverPosition(orderPrivateCar.getId(), 1);//主动推送司机定位
-
                 break;
             case 6://结束服务(专车可以返回继续服务)不修改状态
                 orderPrivateCar.setGetoffLon(lon);
@@ -443,23 +328,6 @@
                 pushUtil.pushOrderState(2, finalOrderPrivateCar.getDriverId(), finalOrderPrivateCar.getId(), 1, finalOrderPrivateCar.getState());
                 if(finalOrderPrivateCar.getState() == 5 && pushMinistryOfTransport){//上传数据
                     pushMinistryOfTransportUtil.operateDepart(orderId);
-                }
-                if(finalOrderPrivateCar.getState()==5 || finalOrderPrivateCar.getState()==6){
-                    if(finalOrderPrivateCar.getSpellSuccess()==1){
-                        if(finalOrderPrivateCar.getPid()==null){
-                            List<OrderPrivateCar> orderList1 = orderPrivateCarMapper.selectList(new EntityWrapper<OrderPrivateCar>().eq("pid",finalOrderPrivateCar.getId()));
-                            for(OrderPrivateCar orderPrivateCar3:orderList1){
-                                pushUtil.pushOrderState(1, orderPrivateCar3.getUserId(), orderPrivateCar3.getId(), 1, 13);
-                            }
-                        }else{
-                            List<OrderPrivateCar> orderList1 = orderPrivateCarMapper.selectList(new EntityWrapper<OrderPrivateCar>().eq("pid",finalOrderPrivateCar.getPid()));
-                            for(OrderPrivateCar orderPrivateCar3:orderList1){
-                                pushUtil.pushOrderState(1, orderPrivateCar3.getUserId(), orderPrivateCar3.getId(), 1, 13);
-                            }
-                            OrderPrivateCar orderPrivateCar3 = orderPrivateCarMapper.selectById(finalOrderPrivateCar.getPid());
-                            pushUtil.pushOrderState(1, orderPrivateCar3.getUserId(), orderPrivateCar3.getId(), 1, 13);
-                        }
-                    }
                 }
             }
         }).start();
@@ -489,189 +357,7 @@
         this.updateById(orderPrivateCar);
 
         pushUtil.removeTask(orderId, 1);//删除定时任务,结束推送数据
-        systemNoticeService.addSystemNotice(1, "司机已结束本次行程,谢谢使用", orderPrivateCar.getUserId(), 1);
-
-        //回滚司机状态为空闲
-        if(orderPrivateCar.getSpellSuccess()==0){
-            Driver driver = driverService.selectById(orderPrivateCar.getDriverId());
-            driver.setState(2);
-            driverService.updateById(driver);
-        }else{
-            if(orderPrivateCar.getPid()==null){
-                Integer number = this.selectCount(new EntityWrapper<OrderPrivateCar>().eq("pid",orderPrivateCar.getPid()==null?orderPrivateCar.getId():orderPrivateCar.getPid()).lt("state",6));
-                if(number<=0){
-                    Driver driver = driverService.selectById(orderPrivateCar.getDriverId());
-                    driver.setState(2);
-                    driverService.updateById(driver);
-                }
-            }else{
-                Integer number = this.selectCount(new EntityWrapper<OrderPrivateCar>().eq("pid",orderPrivateCar.getPid()==null?orderPrivateCar.getId():orderPrivateCar.getPid()).lt("state",6));
-                Integer number1 = this.selectCount(new EntityWrapper<OrderPrivateCar>().eq("id",orderPrivateCar.getPid()).lt("state",6));
-                if(number<=0 && number1<=0){
-                    Driver driver = driverService.selectById(orderPrivateCar.getDriverId());
-                    driver.setState(2);
-                    driverService.updateById(driver);
-                }
-            }
-        }
-
-        //修改总订单人数
-        OrderPrivateCar orderPrivateCar2 = new OrderPrivateCar();
-        orderPrivateCar2.setTotalPeopleNum(orderPrivateCar.getTotalPeopleNum()-orderPrivateCar.getPeopleNum());
-        this.update(orderPrivateCar2,new EntityWrapper<OrderPrivateCar>().eq("pid",orderPrivateCar.getPid()==null?orderPrivateCar.getId():orderPrivateCar.getPid()).lt("state",6));
-        this.update(orderPrivateCar2,new EntityWrapper<OrderPrivateCar>().eq("id",orderPrivateCar.getPid()==null?orderPrivateCar.getId():orderPrivateCar.getPid()).lt("state",6));
-//
-        OrderPrivateCar finalOrderTaxi = orderPrivateCar;
-        new Thread(new Runnable() {
-            @Override
-            public void run() {
-                pushUtil.pushOrderState(1, finalOrderTaxi.getUserId(), finalOrderTaxi.getId(), 1, finalOrderTaxi.getState());
-                pushUtil.pushOrderState(2, finalOrderTaxi.getDriverId(), finalOrderTaxi.getId(), 1, finalOrderTaxi.getState());
-            }
-        }).start();
-        if(orderPrivateCar.getSpellSuccess()==1){
-            List<OrderPrivateCar> orderList1 = this.selectList(new EntityWrapper<OrderPrivateCar>().eq("pid",orderPrivateCar.getPid()));
-            for(OrderPrivateCar orderPrivateCar3:orderList1){
-                pushUtil.pushOrderState(1, orderPrivateCar3.getUserId(), orderPrivateCar3.getId(), 1, 13);
-            }
-            OrderPrivateCar orderPrivateCar3 = this.selectById(orderPrivateCar.getPid());
-            pushUtil.pushOrderState(1, orderPrivateCar3.getUserId(), orderPrivateCar3.getId(), 1, 13);
-        }
-        OrderPrivateCar finalOrderPrivateCar = orderPrivateCar;
-        new Thread(new Runnable() {
-            @Override
-            public void run() {
-                if(pushMinistryOfTransport){//上传交通数据
-                    pushMinistryOfTransportUtil.baseInfoVehicleTotalMile(finalOrderPrivateCar.getCarId());
-                    pushMinistryOfTransportUtil.operateArrive(orderId);
-                }
-            }
-        }).start();
-
-
-        return ResultUtil.success();
-    }
-
-    @Override
-    public ResultUtil cancleOrder(Integer orderId) throws Exception {
-        OrderPrivateCar orderPrivateCar = this.selectById(orderId);
-        orderPrivateCar.setState(10);
-        orderPrivateCar.setDriverCancle(1);
-        this.updateById(orderPrivateCar);
-
-        pushUtil.removeTask(orderId, 1);//删除定时任务,结束推送数据
-        systemNoticeService.addSystemNotice(1, "司机已结束本次行程,谢谢使用", orderPrivateCar.getUserId(), 1);
-
-        //回滚司机状态为空闲
-        if(orderPrivateCar.getSpellSuccess()==0){
-            Driver driver = driverService.selectById(orderPrivateCar.getDriverId());
-            driver.setState(2);
-            driverService.updateById(driver);
-        }else{
-            if(orderPrivateCar.getPid()==null){
-                Integer number = this.selectCount(new EntityWrapper<OrderPrivateCar>().eq("pid",orderPrivateCar.getPid()==null?orderPrivateCar.getId():orderPrivateCar.getPid()).lt("state",6));
-                if(number<=0){
-                    Driver driver = driverService.selectById(orderPrivateCar.getDriverId());
-                    driver.setState(2);
-                    driverService.updateById(driver);
-                }
-            }else{
-                Integer number = this.selectCount(new EntityWrapper<OrderPrivateCar>().eq("pid",orderPrivateCar.getPid()==null?orderPrivateCar.getId():orderPrivateCar.getPid()).lt("state",6));
-                Integer number1 = this.selectCount(new EntityWrapper<OrderPrivateCar>().eq("id",orderPrivateCar.getPid()).lt("state",6));
-                if(number<=0 && number1<=0){
-                    Driver driver = driverService.selectById(orderPrivateCar.getDriverId());
-                    driver.setState(2);
-                    driverService.updateById(driver);
-                }
-            }
-        }
-
-        Integer number1 = this.selectCount(new EntityWrapper<OrderPrivateCar>().eq("pid",orderPrivateCar.getPid()==null?orderPrivateCar.getId():orderPrivateCar.getPid()).lt("state",6));
-        Integer number2 = this.selectCount(new EntityWrapper<OrderPrivateCar>().eq("id",orderPrivateCar.getPid()==null?orderPrivateCar.getId():orderPrivateCar.getPid()).lt("state",6));
-        if(number1+number2==1){
-            OrderPrivateCar orderPrivateCar2 = new OrderPrivateCar();
-            orderPrivateCar2.setTotalPeopleNum(orderPrivateCar.getTotalPeopleNum()-orderPrivateCar.getPeopleNum());
-            orderPrivateCar2.setSpellSuccess(0);
-            this.update(orderPrivateCar2,new EntityWrapper<OrderPrivateCar>().eq("pid",orderPrivateCar.getPid()==null?orderPrivateCar.getId():orderPrivateCar.getPid()).lt("state",6));
-            this.update(orderPrivateCar2,new EntityWrapper<OrderPrivateCar>().eq("id",orderPrivateCar.getPid()==null?orderPrivateCar.getId():orderPrivateCar.getPid()).lt("state",6));
-
-        }else{
-            OrderPrivateCar orderPrivateCar2 = new OrderPrivateCar();
-            orderPrivateCar2.setTotalPeopleNum(orderPrivateCar.getTotalPeopleNum()-orderPrivateCar.getPeopleNum());
-            this.update(orderPrivateCar2,new EntityWrapper<OrderPrivateCar>().eq("pid",orderPrivateCar.getPid()==null?orderPrivateCar.getId():orderPrivateCar.getPid()).lt("state",6));
-            this.update(orderPrivateCar2,new EntityWrapper<OrderPrivateCar>().eq("id",orderPrivateCar.getPid()==null?orderPrivateCar.getId():orderPrivateCar.getPid()).lt("state",6));
-        }
-        OrderPrivateCar finalOrderTaxi = orderPrivateCar;
-        new Thread(new Runnable() {
-            @Override
-            public void run() {
-                pushUtil.pushOrderState(1, finalOrderTaxi.getUserId(), finalOrderTaxi.getId(), 1, finalOrderTaxi.getState());
-                //pushUtil.pushOrderState(2, finalOrderTaxi.getDriverId(), finalOrderTaxi.getId(), 1, finalOrderTaxi.getState());
-            }
-        }).start();
-        if(orderPrivateCar.getSpellSuccess()==1){
-            if(orderPrivateCar.getPid()==null){
-                List<OrderPrivateCar> orderList1 = this.selectList(new EntityWrapper<OrderPrivateCar>().eq("pid",orderPrivateCar.getId()));
-                for(OrderPrivateCar orderPrivateCar3:orderList1){
-                    pushUtil.pushOrderState(1, orderPrivateCar3.getUserId(), orderPrivateCar3.getId(), 1, 13);
-                }
-                // pushUtil.pushOrderState(1, orderPrivateCar.getUserId(), orderPrivateCar.getId(), 1, 13);
-            }else{
-                List<OrderPrivateCar> orderList1 = this.selectList(new EntityWrapper<OrderPrivateCar>().eq("pid",orderPrivateCar.getPid()));
-                for(OrderPrivateCar orderPrivateCar3:orderList1){
-                    pushUtil.pushOrderState(1, orderPrivateCar3.getUserId(), orderPrivateCar3.getId(), 1, 13);
-                }
-                OrderPrivateCar orderPrivateCar3 = this.selectById(orderPrivateCar.getPid());
-                pushUtil.pushOrderState(1, orderPrivateCar3.getUserId(), orderPrivateCar3.getId(), 1, 13);
-            }
-        }
-        return ResultUtil.success();
-    }
-
-
-    @Override
-    public ResultUtil updatePeopleNum(Integer orderId, Integer peopleNum) throws Exception {
-        OrderPrivateCar orderPrivateCar = this.selectById(orderId);
-        orderPrivateCar.setPeopleNum(peopleNum);
-        if(peopleNum==4){
-            orderPrivateCar.setRideType(1);
-        }
-        this.updateById(orderPrivateCar);
-        return ResultUtil.success();
-    }
-
-    @Override
-    public ResultUtil confirmFees1(Integer orderId, Integer type, String additionalFee) throws Exception {
-        OrderPrivateCar orderPrivateCar = this.selectById(orderId);
-        orderPrivateCar = this.setMoney(orderPrivateCar, 0D, 0D);//计算费用
-        orderPrivateCar.setPayManner(type);
-        orderPrivateCar.setParkMoney(0D);
-        orderPrivateCar.setRoadTollMoney(0D);
-        Company company = companyService.selectById(orderPrivateCar.getCompanyId());
-        orderPrivateCar.setHolidayFee(null == company.getHolidayFee() ? 0D : company.getHolidayFee());
-
-        Double t = 0D;
-        if(ToolUtil.isNotEmpty(additionalFee)){//附加费
-            JSONArray jsonArray = JSON.parseArray(additionalFee);
-            for(int i = 0; i < jsonArray.size(); i++){
-                JSONObject jsonObject = jsonArray.getJSONObject(i);
-                Integer id = jsonObject.getInteger("id");
-                Double amount = jsonObject.getDouble("amount");
-                OrderAdditionalFee orderAdditionalFee = new OrderAdditionalFee();
-                orderAdditionalFee.setOrderType(1);
-                orderAdditionalFee.setOrderId(orderId);
-                orderAdditionalFee.setAdditionalFeeId(id);
-                orderAdditionalFee.setAmount(amount);
-                orderAdditionalFeeService.insert(orderAdditionalFee);
-                t += amount;
-            }
-        }
-        orderPrivateCar.setOrderMoney(orderPrivateCar.getOrderMoney() + orderPrivateCar.getParkMoney() + orderPrivateCar.getRoadTollMoney() + orderPrivateCar.getHolidayFee() + t);
-        orderPrivateCar.setState(7);
-        this.updateById(orderPrivateCar);
-
-        pushUtil.removeTask(orderId, 1);//删除定时任务,结束推送数据
-        systemNoticeService.addSystemNotice(1, "司机已结束本次行程,谢谢使用", orderPrivateCar.getUserId(), 1);
+        systemNoticeService.addSystemNotice(1, "司机已结束本次行程,谢谢使用", orderPrivateCar.getUserId());
 
         //回滚司机状态为空闲
         Driver driver = driverService.selectById(orderPrivateCar.getDriverId());
@@ -703,7 +389,6 @@
     }
 
 
-
     /**
      * 获取订单费用明细
      * @param orderId
@@ -714,7 +399,7 @@
     public Map<String, Object> queryMoneyInfo(Integer orderId) throws Exception {
         OrderPrivateCar orderPrivateCar = this.selectById(orderId);
         if(orderPrivateCar.getState() == 5){//服务中的时候获取实时费用数据
-            orderPrivateCar=this.setMoney(orderPrivateCar, 0D, 0D);
+            this.setMoney(orderPrivateCar, 0D, 0D);
         }
 
         Map<String, Object> map = new HashMap<>();
@@ -735,18 +420,6 @@
         map.put("couponMoney", orderPrivateCar.getCouponMoney());//优惠券抵扣金额
         map.put("discountMoney", orderPrivateCar.getDiscountMoney());//折扣抵扣金额
         map.put("discount", orderPrivateCar.getDiscount());//折扣
-        map.put("holidayFee", orderPrivateCar.getHolidayFee());//节假日费
-
-        List<OrderAdditionalFee> orderAdditionalFees = orderAdditionalFeeService.selectList(new EntityWrapper<OrderAdditionalFee>().eq("orderType", 1).eq("orderId", orderId));
-        List<Map<String, Object>> list = new ArrayList<>();
-        orderAdditionalFees.forEach(orderAdditionalFee -> {
-            AdditionalFee additionalFee = additionalFeeService.selectById(orderAdditionalFee.getAdditionalFeeId());
-            Map<String, Object> map1 = new HashMap<>();
-            map1.put("name", additionalFee.getName());
-            map1.put("amount", orderAdditionalFee.getAmount());
-            list.add(map1);
-        });
-        map.put("additionalFee", list);
         return map;
     }
 
@@ -801,12 +474,6 @@
         return orderPrivateCarMapper.queryMaturity();
     }
 
-
-    @Override
-    public List<OrderPrivateCar> taskMidAxbUnBindSend() throws Exception {
-        return this.baseMapper.taskMidAxbUnBindSend();
-    }
-
     /**
      * 计算价格
      * @param orderPrivateCar
@@ -816,102 +483,48 @@
      * @throws Exception
      */
     public OrderPrivateCar setMoney(OrderPrivateCar orderPrivateCar, Double parkingFee, Double crossingFee) throws Exception {
-
         Map<String, Object> query1 = systemPriceMapper.query(orderPrivateCar.getCompanyId(), 1, orderPrivateCar.getServerCarModelId());
         //开始根据不同的方式计算金额
         double amount = 0;
         JSONObject jsonObject = JSON.parseObject(query1.get("content").toString());
+        Double num1 = jsonObject.getDouble("num1");//起步价(元)
+        Double num2 = jsonObject.getDouble("num2");//起步公里(公里)
+        Double num3 = jsonObject.getDouble("num3");//起步时间(分钟)
+        Double num4 = jsonObject.getDouble("num4");//里程费(元)
+        Double num5 = jsonObject.getDouble("num5");//时长费(分钟)
+        Double num6 = jsonObject.getDouble("num6");//等待费(分钟)
+        Double num7 = jsonObject.getDouble("num7");//等待费(元)
+        Double num8 = jsonObject.getDouble("num8");//远途费(公里)
+        Double num9 = jsonObject.getDouble("num9");//远途费(公里)
+        Double num10 = jsonObject.getDouble("num10");//远途费(元)
+        Double num11 = jsonObject.getDouble("num11");//远途费(公里)
+        Double num12 = jsonObject.getDouble("num12");//远途费(公里)
+        Double num13 = jsonObject.getDouble("num13");//远途费(元)
+        Double num14 = jsonObject.getDouble("num14");//远途费(公里)
+        Double num15 = jsonObject.getDouble("num15");//远途费(元)
+        String num16 = jsonObject.getString("num16");//夜间费(开始时间)
+        Double num17 = jsonObject.getDouble("num17");//夜间费(元)
+        Double num18 = jsonObject.getDouble("num18");//夜间费(元)
+        Double num19 = jsonObject.getDouble("num19");//夜间费(元)
+        Double num20 = jsonObject.getDouble("num20");//夜间费(元)
+        Double num21 = jsonObject.getDouble("num21");//夜间费(元)
+        Double num22 = jsonObject.getDouble("num22");//夜间费(元)
+        String num23 = jsonObject.getString("num23");//高峰费(开始时间)
+        String num24 = jsonObject.getString("num24");//高峰费(开始时间)
+        Double num25 = jsonObject.getDouble("num25");//高峰费(元)
+        Double num26 = jsonObject.getDouble("num26");//高峰费(元)
+        Double num27 = jsonObject.getDouble("num27");//高峰费(元)
+        Double num28 = jsonObject.getDouble("num28");//高峰费(元)
+        Double num29 = jsonObject.getDouble("num29");//高峰费(元)
+        Double num30 = jsonObject.getDouble("num30");//高峰费(元)
 
-        JSONObject contentPutOne = JSON.parseObject(query1.get("contentPutOne").toString());//一人拼成
-        JSONObject contentNotOne = JSON.parseObject(query1.get("contentNotOne").toString());//一人未拼成
-        JSONObject contentPutTwo = JSON.parseObject(query1.get("contentPutTwo").toString());//2人拼成
-        JSONObject contentNotTwo = JSON.parseObject(query1.get("contentNotTwo").toString());//2人未拼成
-        JSONObject contentPutThree = JSON.parseObject(query1.get("contentPutThree").toString());//3人拼成
-        JSONObject contentNotThree = JSON.parseObject(query1.get("contentNotThree").toString());//3人未拼成
-        JSONObject contentExclusive = JSON.parseObject(query1.get("contentExclusive").toString());//独享
-        JSONObject contentPrice = JSON.parseObject(query1.get("contentPrice").toString());//一口价
-        //乘车类型(1=独享,2=一口价,3=拼车)
-        orderPrivateCar.setWaitRule(jsonObject.toJSONString());
-        if(orderPrivateCar.getRideType()==1){
-            orderPrivateCar = calculationPrice(orderPrivateCar,contentExclusive,jsonObject.getLongValue("num1"),jsonObject.getDouble("num2"),parkingFee,crossingFee);
-        }else if(orderPrivateCar.getRideType()==2){
-            double d = (null == orderPrivateCar.getMileage() ? 0D : orderPrivateCar.getMileage());
-            double estimateMileage = (null == orderPrivateCar.getEstimateMileage() ? 0D : orderPrivateCar.getEstimateMileage());
-            //在价格区间按照一口价算,不在区间按实时价格算
-            if(d<estimateMileage+contentPrice.getDouble("num29")*1000 && d>estimateMileage-contentPrice.getDouble("num32")*1000){
-                orderPrivateCar = calculationPrice1(orderPrivateCar,contentPrice,jsonObject.getLongValue("num1"),jsonObject.getDouble("num2"),parkingFee,crossingFee);
-            }else{
-                orderPrivateCar = calculationPrice(orderPrivateCar,contentExclusive,jsonObject.getLongValue("num1"),jsonObject.getDouble("num2"),parkingFee,crossingFee);
-            }
-        }else{
-            //判断是否是拼单
-            if(orderPrivateCar.getSpellSuccess()==0){
-                if(orderPrivateCar.getPeopleNum()==1){
-                    orderPrivateCar = calculationPrice(orderPrivateCar,contentNotOne,jsonObject.getLongValue("num1"),jsonObject.getDouble("num2"),parkingFee,crossingFee);
-                    orderPrivateCar.setChargeRules(contentPutOne.toJSONString());
-                }else if(orderPrivateCar.getPeopleNum()==2){
-                    orderPrivateCar = calculationPrice(orderPrivateCar,contentNotTwo,jsonObject.getLongValue("num1"),jsonObject.getDouble("num2"),parkingFee,crossingFee);
-                    orderPrivateCar.setChargeRules(contentPutTwo.toJSONString());
-                }else{
-                    orderPrivateCar = calculationPrice(orderPrivateCar,contentNotThree,jsonObject.getLongValue("num1"),jsonObject.getDouble("num2"),parkingFee,crossingFee);
-                    orderPrivateCar.setChargeRules(contentPutThree.toJSONString());
-                }
-            }else{
-                if(orderPrivateCar.getPeopleNum()==1){
-                    orderPrivateCar = calculationPrice(orderPrivateCar,contentPutOne,jsonObject.getLongValue("num1"),jsonObject.getDouble("num2"),parkingFee,crossingFee);
-                    orderPrivateCar.setChargeRules(contentNotOne.toJSONString());
-                }else if(orderPrivateCar.getPeopleNum()==2){
-                    orderPrivateCar = calculationPrice(orderPrivateCar,contentPutTwo,jsonObject.getLongValue("num1"),jsonObject.getDouble("num2"),parkingFee,crossingFee);
-                    orderPrivateCar.setChargeRules(contentNotTwo.toJSONString());
-                }else{
-                    orderPrivateCar = calculationPrice(orderPrivateCar,contentPutThree,jsonObject.getLongValue("num1"),jsonObject.getDouble("num2"),parkingFee,crossingFee);
-                    orderPrivateCar.setChargeRules(contentNotThree.toJSONString());
-                }
-            }
-            /*if(orderPrivateCar.getPid()==null){
-                Integer number = orderPrivateCarMapper.selectCount(new EntityWrapper<OrderPrivateCar>().eq("pid",orderPrivateCar.getId()).ne("state",10).ne("state",12));
-                if(number<=0){
-                  if(orderPrivateCar.getPeopleNum()==1){
-                      orderPrivateCar = calculationPrice(orderPrivateCar,contentNotOne,jsonObject.getLongValue("num1"),jsonObject.getDouble("num2"),parkingFee,crossingFee);
-                  }else if(orderPrivateCar.getPeopleNum()==2){
-                      orderPrivateCar = calculationPrice(orderPrivateCar,contentNotTwo,jsonObject.getLongValue("num1"),jsonObject.getDouble("num2"),parkingFee,crossingFee);
-                  }else{
-                      orderPrivateCar = calculationPrice(orderPrivateCar,contentNotThree,jsonObject.getLongValue("num1"),jsonObject.getDouble("num2"),parkingFee,crossingFee);
-                  }
-                }else{
-                    if(orderPrivateCar.getPeopleNum()==1){
-                        orderPrivateCar = calculationPrice(orderPrivateCar,contentPutOne,jsonObject.getLongValue("num1"),jsonObject.getDouble("num2"),parkingFee,crossingFee);
-                    }else if(orderPrivateCar.getPeopleNum()==2){
-                        orderPrivateCar = calculationPrice(orderPrivateCar,contentPutTwo,jsonObject.getLongValue("num1"),jsonObject.getDouble("num2"),parkingFee,crossingFee);
-                    }else{
-                        orderPrivateCar = calculationPrice(orderPrivateCar,contentPutThree,jsonObject.getLongValue("num1"),jsonObject.getDouble("num2"),parkingFee,crossingFee);
-                    }
-                }
-            }else{
-                if(orderPrivateCar.getPeopleNum()==1){
-                    orderPrivateCar = calculationPrice(orderPrivateCar,contentPutOne,jsonObject.getLongValue("num1"),jsonObject.getDouble("num2"),parkingFee,crossingFee);
-                }else if(orderPrivateCar.getPeopleNum()==2){
-                    orderPrivateCar = calculationPrice(orderPrivateCar,contentPutTwo,jsonObject.getLongValue("num1"),jsonObject.getDouble("num2"),parkingFee,crossingFee);
-                }else{
-                    orderPrivateCar = calculationPrice(orderPrivateCar,contentPutThree,jsonObject.getLongValue("num1"),jsonObject.getDouble("num2"),parkingFee,crossingFee);
-                }
-            }*/
-        }
-        return orderPrivateCar;
-    }
-
-    public OrderPrivateCar  calculationPrice(OrderPrivateCar orderPrivateCar,JSONObject rule, long wait,Double waitMoney, Double parkingFee, Double crossingFee) throws Exception {
-        orderPrivateCar.setChargeRule(rule.toJSONString());
-        double amount = 0;
-        //等待费
         Date date = new Date();
-        if(orderPrivateCar.getEndServiceTime()==null)orderPrivateCar.setEndServiceTime(date);
         double d = (null == orderPrivateCar.getMileage() ? 0D : orderPrivateCar.getMileage()) / 1000;//实际公里
         double t = ((orderPrivateCar.getEndServiceTime().getTime() - orderPrivateCar.getStartServiceTime().getTime()) / 60000) + 1;//实际时间(不满一分钟按一分钟算)
-        double d1 = (d - rule.getDouble("num2")) < 0 ? 0 : d - rule.getDouble("num2");//超出起步里程的公里
-        double t1 = (t - rule.getDouble("num3")) < 0 ? 0 : t - rule.getDouble("num3");//超过起步分钟数的时间
         double w = ((orderPrivateCar.getStartServiceTime().getTime() - orderPrivateCar.getArriveTime().getTime()) / 60000) + 1;//等待分钟(不满一分钟按一分钟算)
-        double w1 = (w - wait) < 0 ? 0 : new BigDecimal(w - wait).setScale(0, BigDecimal.ROUND_UP).doubleValue();//超出等待时间的时间
+        double d1 = (d - num2) < 0 ? 0 : d - num2;//超出起步里程的公里
+        double t1 = (t - num3) < 0 ? 0 : new BigDecimal(t - num3).setScale(0, BigDecimal.ROUND_UP).doubleValue();//超过起步分钟数的时间
+        double w1 = (w - num6) < 0 ? 0 : new BigDecimal(w - num6).setScale(0, BigDecimal.ROUND_UP).doubleValue();//超出等待时间的时间
         double yt1 = 0;//远途1段
         double yt2 = 0;//远途2段
         double yt3 = 0;//远途3段
@@ -920,34 +533,40 @@
         //夜间服务处理逻辑
         Calendar s = Calendar.getInstance();
         s.setTime(date);
-        s.set(Calendar.HOUR_OF_DAY, Integer.valueOf(rule.getString("num14").split(" - ")[0].split(":")[0]));
-        s.set(Calendar.MINUTE, Integer.valueOf(rule.getString("num14").split(" - ")[0].split(":")[1]));
+        s.set(Calendar.HOUR_OF_DAY, Integer.valueOf(num16.split(" - ")[0].split(":")[0]));
+        s.set(Calendar.MINUTE, Integer.valueOf(num16.split(" - ")[0].split(":")[1]));
 
         Calendar e = Calendar.getInstance();
         e.setTime(date);
-        e.set(Calendar.HOUR_OF_DAY, Integer.valueOf(rule.getString("num14").split(" - ")[1].split(":")[0]));
-        e.set(Calendar.MINUTE, Integer.valueOf(rule.getString("num14").split(" - ")[1].split(":")[1]));
+        e.set(Calendar.HOUR_OF_DAY, Integer.valueOf(num16.split(" - ")[1].split(":")[0]));
+        e.set(Calendar.MINUTE, Integer.valueOf(num16.split(" - ")[1].split(":")[1]));
 
         if(date.getTime() > s.getTimeInMillis() && date.getTime() < e.getTimeInMillis()){
-            if(d > rule.getDouble("num6")){
-                yt1 = rule.getDouble("num18") * (rule.getDouble("num7") - rule.getDouble("num6"));
+            if(d > num8.doubleValue() && d <= num9.doubleValue()){
+                yt1 = num20 * (d - num8);
             }
-            if(d >  rule.getDouble("num9")){
-                yt2 = rule.getDouble("num19") * (rule.getDouble("num10") - rule.getDouble("num9"));
+            if(d > num9.doubleValue()){
+                yt1 = num20 * (num9 - num8);
             }
-            if(d > rule.getDouble("num12")){
-                yt3 = rule.getDouble("num20") * (d - rule.getDouble("num12"));
+            if(d > num11.doubleValue() && d <= num12.doubleValue()){
+                yt2 = num21 * (d - num11);
             }
-            amount = rule.getDouble("num15") + (d1 * rule.getDouble("num16")) + (t1 * rule.getDouble("num17")) + (w1 * waitMoney) + yt1 + yt2 + yt3;
-            orderPrivateCar.setStartMileage(rule.getDouble("num2"));
-            orderPrivateCar.setStartMoney(rule.getDouble("num15"));//起步价
+            if(d > num12.doubleValue()){
+                yt2 = num21 * (num12 - num11);
+            }
+            if(d > num14.doubleValue()){
+                yt3 = num22 * (d - num14);
+            }
+            amount = num17 + (d1 * num18) + (t1 * num19) + (w1 * num7) + yt1 + yt2 + yt3;
+            orderPrivateCar.setStartMileage(num2);
+            orderPrivateCar.setStartMoney(num17);//起步价
             orderPrivateCar.setMileageKilometers(new BigDecimal(d1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-            orderPrivateCar.setMileageMoney(new BigDecimal(d1 * rule.getDouble("num16")).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//里程费
+            orderPrivateCar.setMileageMoney(new BigDecimal(d1 * num18).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//里程费
             orderPrivateCar.setDuration(new BigDecimal(t1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-            orderPrivateCar.setDurationMoney(new BigDecimal(t1 * rule.getDouble("num17")).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//时长费
+            orderPrivateCar.setDurationMoney(new BigDecimal(t1 * num19).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//时长费
             orderPrivateCar.setWait(new BigDecimal(w1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-            orderPrivateCar.setWaitMoney(new BigDecimal(w1 * waitMoney).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//等待费
-            orderPrivateCar.setLongDistance(new BigDecimal((d > rule.getDouble("num6")) ? d - rule.getDouble("num6") : 0).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
+            orderPrivateCar.setWaitMoney(new BigDecimal(w1 * num7).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//等待费
+            orderPrivateCar.setLongDistance(new BigDecimal((d > num8) ? d - num8 : 0).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
             orderPrivateCar.setLongDistanceMoney(new BigDecimal(yt1 + yt2 + yt3).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//远途费
             orderPrivateCar.setParkMoney(parkingFee);//停车费
             orderPrivateCar.setRoadTollMoney(crossingFee);//过路费
@@ -956,137 +575,57 @@
             orderPrivateCar.setDiscount(0D);//优惠抵扣
             orderPrivateCar.setPayMoney(0D);//支付金额
             orderPrivateCar.setOrderMoney(new BigDecimal(amount + parkingFee + crossingFee).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-        }else{
-            Calendar s1 = Calendar.getInstance();
-            s1.setTime(date);
-            s1.set(Calendar.HOUR_OF_DAY, Integer.valueOf(rule.getString("num21").split(" - ")[0].split(":")[0]));
-            s1.set(Calendar.MINUTE, Integer.valueOf(rule.getString("num21").split(" - ")[0].split(":")[1]));
-
-            Calendar e1 = Calendar.getInstance();
-            e1.setTime(date);
-            e1.set(Calendar.HOUR_OF_DAY, Integer.valueOf(rule.getString("num21").split(" - ")[1].split(":")[0]));
-            e1.set(Calendar.MINUTE, Integer.valueOf(rule.getString("num21").split(" - ")[1].split(":")[1]));
-
-            Calendar s2 = Calendar.getInstance();
-            s2.setTime(date);
-            s2.set(Calendar.HOUR_OF_DAY, Integer.valueOf(rule.getString("num22").split(" - ")[0].split(":")[0]));
-            s2.set(Calendar.MINUTE, Integer.valueOf(rule.getString("num22").split(" - ")[0].split(":")[1]));
-
-            Calendar e2 = Calendar.getInstance();
-            e2.setTime(date);
-            e2.set(Calendar.HOUR_OF_DAY, Integer.valueOf(rule.getString("num22").split(" - ")[1].split(":")[0]));
-            e2.set(Calendar.MINUTE, Integer.valueOf(rule.getString("num22").split(" - ")[1].split(":")[1]));
-            //高峰时段处理逻辑
-            if((date.getTime() > s1.getTimeInMillis() && date.getTime() < e1.getTimeInMillis()) || (date.getTime() > s2.getTimeInMillis() && date.getTime() < e2.getTimeInMillis())){
-                if(d > rule.getDouble("num6")){
-                    yt1 = rule.getDouble("num26") * (rule.getDouble("num7") - rule.getDouble("num6"));
-                }
-                if(d >  rule.getDouble("num9")){
-                    yt2 = rule.getDouble("num27") * (rule.getDouble("num10") - rule.getDouble("num9"));
-                }
-                if(d > rule.getDouble("num12")){
-                    yt3 = rule.getDouble("num28") * (d - rule.getDouble("num12"));
-                }
-                amount = rule.getDouble("num23") + (d1 * rule.getDouble("num24")) + (t1 * rule.getDouble("num25")) + (w1 * waitMoney) + yt1 + yt2 + yt3;
-                orderPrivateCar.setStartMileage(rule.getDouble("num2"));
-                orderPrivateCar.setStartMoney(rule.getDouble("num23"));//起步价
-                orderPrivateCar.setMileageKilometers(new BigDecimal(d1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                orderPrivateCar.setMileageMoney(new BigDecimal(d1 * rule.getDouble("num24")).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//里程费
-                orderPrivateCar.setDuration(new BigDecimal(t1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                orderPrivateCar.setDurationMoney(new BigDecimal(t1 * rule.getDouble("num25")).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//时长费
-                orderPrivateCar.setWait(new BigDecimal(w1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                orderPrivateCar.setWaitMoney(new BigDecimal(w1 * waitMoney).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//等待费
-                orderPrivateCar.setLongDistance(new BigDecimal((d > rule.getDouble("num6")) ? d - rule.getDouble("num6") : 0).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                orderPrivateCar.setLongDistanceMoney(new BigDecimal(yt1 + yt2 + yt3).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//远途费
-                orderPrivateCar.setParkMoney(parkingFee);//停车费
-                orderPrivateCar.setRoadTollMoney(crossingFee);//过路费
-                orderPrivateCar.setRedPacketMoney(0D);//红包抵扣
-                orderPrivateCar.setCouponMoney(0D);//优惠券抵扣
-                orderPrivateCar.setDiscount(0D);//优惠抵扣
-                orderPrivateCar.setPayMoney(0D);//支付金额
-                orderPrivateCar.setOrderMoney(new BigDecimal(amount + parkingFee + crossingFee).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-            }else{
-                //其他时间段的计算
-                if(d > rule.getDouble("num6")){
-                    yt1 = rule.getDouble("num8") * (rule.getDouble("num7") - rule.getDouble("num6"));
-                }
-                if(d >  rule.getDouble("num9")){
-                    yt2 = rule.getDouble("num11") * (rule.getDouble("num10") - rule.getDouble("num9"));
-                }
-                if(d > rule.getDouble("num12")){
-                    yt3 = rule.getDouble("num13") * (d - rule.getDouble("num12"));
-                }
-                amount = rule.getDouble("num1") + (d1 * rule.getDouble("num4")) + (t1 * rule.getDouble("num5")) + (w1 * waitMoney) + yt1 + yt2 + yt3;
-                orderPrivateCar.setStartMileage(rule.getDouble("num2"));
-                orderPrivateCar.setStartMoney(rule.getDouble("num1"));//起步价
-                orderPrivateCar.setMileageKilometers(new BigDecimal(d1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                orderPrivateCar.setMileageMoney(new BigDecimal(d1 * rule.getDouble("num4")).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//里程费
-                orderPrivateCar.setDuration(new BigDecimal(t1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                orderPrivateCar.setDurationMoney(new BigDecimal(t1 * rule.getDouble("num5")).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//时长费
-                orderPrivateCar.setWait(new BigDecimal(w1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                orderPrivateCar.setWaitMoney(new BigDecimal(w1 * waitMoney).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//等待费
-                orderPrivateCar.setLongDistance(new BigDecimal((d > rule.getDouble("num6")) ? d - rule.getDouble("num6") : 0).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                orderPrivateCar.setLongDistanceMoney(new BigDecimal(yt1 + yt2 + yt3).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//远途费
-                orderPrivateCar.setParkMoney(parkingFee);//停车费
-                orderPrivateCar.setRoadTollMoney(crossingFee);//过路费
-                orderPrivateCar.setRedPacketMoney(0D);//红包抵扣
-                orderPrivateCar.setCouponMoney(0D);//优惠券抵扣
-                orderPrivateCar.setDiscount(0D);//优惠抵扣
-                orderPrivateCar.setPayMoney(0D);//支付金额
-                orderPrivateCar.setOrderMoney(new BigDecimal(amount + parkingFee + crossingFee).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-            }
+            return orderPrivateCar;
         }
-        return orderPrivateCar;
-    }
 
 
+        //高峰时段处理逻辑
+        Calendar s1 = Calendar.getInstance();
+        s1.setTime(date);
+        s1.set(Calendar.HOUR_OF_DAY, Integer.valueOf(num23.split(" - ")[0].split(":")[0]));
+        s1.set(Calendar.MINUTE, Integer.valueOf(num23.split(" - ")[0].split(":")[1]));
 
-    public OrderPrivateCar  calculationPrice1(OrderPrivateCar orderPrivateCar,JSONObject rule, long wait,Double waitMoney, Double parkingFee, Double crossingFee) throws Exception {
-        double amount = 0;
-        //等待费
-        Date date = new Date();
-        double d = (null == orderPrivateCar.getEstimateMileage() ? 0D : orderPrivateCar.getEstimateMileage()) / 1000;//实际公里
-        double t = orderPrivateCar.getEstimateTime();//实际时间(不满一分钟按一分钟算)
-        double d1 = (d - rule.getDouble("num1")) < 0 ? 0 : d - rule.getDouble("num1");//超出起步里程的公里
-        double t1 = (t - rule.getDouble("num2")) < 0 ? 0 : t - rule.getDouble("num2");//超过起步分钟数的时间
-        double w = ((orderPrivateCar.getStartServiceTime().getTime() - orderPrivateCar.getArriveTime().getTime()) / 60000) + 1;//等待分钟(不满一分钟按一分钟算)
-        double w1 = (w - wait) < 0 ? 0 : new BigDecimal(w - wait).setScale(0, BigDecimal.ROUND_UP).doubleValue();//超出等待时间的时间
-        double yt1 = 0;//远途1段
-        double yt2 = 0;//远途2段
-        double yt3 = 0;//远途3段
+        Calendar e1 = Calendar.getInstance();
+        e1.setTime(date);
+        e1.set(Calendar.HOUR_OF_DAY, Integer.valueOf(num23.split(" - ")[1].split(":")[0]));
+        e1.set(Calendar.MINUTE, Integer.valueOf(num23.split(" - ")[1].split(":")[1]));
 
+        Calendar s2 = Calendar.getInstance();
+        s2.setTime(date);
+        s2.set(Calendar.HOUR_OF_DAY, Integer.valueOf(num24.split(" - ")[0].split(":")[0]));
+        s2.set(Calendar.MINUTE, Integer.valueOf(num24.split(" - ")[0].split(":")[1]));
 
-        //夜间服务处理逻辑
-        Calendar s = Calendar.getInstance();
-        s.setTime(date);
-        s.set(Calendar.HOUR_OF_DAY, Integer.valueOf(rule.getString("num14").split(" - ")[0].split(":")[0]));
-        s.set(Calendar.MINUTE, Integer.valueOf(rule.getString("num14").split(" - ")[0].split(":")[1]));
+        Calendar e2 = Calendar.getInstance();
+        e2.setTime(date);
+        e2.set(Calendar.HOUR_OF_DAY, Integer.valueOf(num24.split(" - ")[1].split(":")[0]));
+        e2.set(Calendar.MINUTE, Integer.valueOf(num24.split(" - ")[1].split(":")[1]));
 
-        Calendar e = Calendar.getInstance();
-        e.setTime(date);
-        e.set(Calendar.HOUR_OF_DAY, Integer.valueOf(rule.getString("num14").split(" - ")[1].split(":")[0]));
-        e.set(Calendar.MINUTE, Integer.valueOf(rule.getString("num14").split(" - ")[1].split(":")[1]));
-
-        if(date.getTime() > s.getTimeInMillis() && date.getTime() < e.getTimeInMillis()){
-            if(d > rule.getDouble("num6")){
-                yt1 = rule.getDouble("num18") * (rule.getDouble("num7") - rule.getDouble("num6"));
+        if((date.getTime() > s1.getTimeInMillis() && date.getTime() < e1.getTimeInMillis()) || (date.getTime() > s2.getTimeInMillis() && date.getTime() < e2.getTimeInMillis())){
+            if(d > num8.doubleValue() && d <= num9.doubleValue()){
+                yt1 = num28 * (d - num8);
             }
-            if(d >  rule.getDouble("num9")){
-                yt2 = rule.getDouble("num19") * (rule.getDouble("num10") - rule.getDouble("num9"));
+            if(d > num9.doubleValue()){
+                yt1 = num28 * (num9 - num8);
             }
-            if(d > rule.getDouble("num12")){
-                yt3 = rule.getDouble("num20") * (d - rule.getDouble("num12"));
+            if(d > num11.doubleValue() && d <= num12.doubleValue()){
+                yt2 = num29 * (d - num11);
             }
-            amount = rule.getDouble("num15") + (d1 * rule.getDouble("num16")) + (t1 * rule.getDouble("num17")) + (w1 * waitMoney) + yt1 + yt2 + yt3;
-            orderPrivateCar.setStartMileage(rule.getDouble("num2"));
-            orderPrivateCar.setStartMoney(rule.getDouble("num15"));//起步价
+            if(d > num12.doubleValue()){
+                yt2 = num29 * (num12 - num11);
+            }
+            if(d > num14.doubleValue()){
+                yt3 = num30 * (d - num14);
+            }
+            amount = num25 + (d1 * num26) + (t1 * num27) + (w1 * num7) + yt1 + yt2 + yt3;
+            orderPrivateCar.setStartMileage(num2);
+            orderPrivateCar.setStartMoney(num25);//起步价
             orderPrivateCar.setMileageKilometers(new BigDecimal(d1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-            orderPrivateCar.setMileageMoney(new BigDecimal(d1 * rule.getDouble("num16")).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//里程费
+            orderPrivateCar.setMileageMoney(new BigDecimal(d1 * num26).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//里程费
             orderPrivateCar.setDuration(new BigDecimal(t1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-            orderPrivateCar.setDurationMoney(new BigDecimal(t1 * rule.getDouble("num17")).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//时长费
+            orderPrivateCar.setDurationMoney(new BigDecimal(t1 * num27).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//时长费
             orderPrivateCar.setWait(new BigDecimal(w1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-            orderPrivateCar.setWaitMoney(new BigDecimal(w1 * waitMoney).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//等待费
-            orderPrivateCar.setLongDistance(new BigDecimal((d > rule.getDouble("num6")) ? d - rule.getDouble("num6") : 0).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
+            orderPrivateCar.setWaitMoney(new BigDecimal(w1 * num7).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//等待费
+            orderPrivateCar.setLongDistance(new BigDecimal((d > num8) ? d - num8 : 0).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
             orderPrivateCar.setLongDistanceMoney(new BigDecimal(yt1 + yt2 + yt3).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//远途费
             orderPrivateCar.setParkMoney(parkingFee);//停车费
             orderPrivateCar.setRoadTollMoney(crossingFee);//过路费
@@ -1095,86 +634,43 @@
             orderPrivateCar.setDiscount(0D);//优惠抵扣
             orderPrivateCar.setPayMoney(0D);//支付金额
             orderPrivateCar.setOrderMoney(new BigDecimal(amount + parkingFee + crossingFee).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-        }else{
-            Calendar s1 = Calendar.getInstance();
-            s1.setTime(date);
-            s1.set(Calendar.HOUR_OF_DAY, Integer.valueOf(rule.getString("num21").split(" - ")[0].split(":")[0]));
-            s1.set(Calendar.MINUTE, Integer.valueOf(rule.getString("num21").split(" - ")[0].split(":")[1]));
-
-            Calendar e1 = Calendar.getInstance();
-            e1.setTime(date);
-            e1.set(Calendar.HOUR_OF_DAY, Integer.valueOf(rule.getString("num21").split(" - ")[1].split(":")[0]));
-            e1.set(Calendar.MINUTE, Integer.valueOf(rule.getString("num21").split(" - ")[1].split(":")[1]));
-
-            Calendar s2 = Calendar.getInstance();
-            s2.setTime(date);
-            s2.set(Calendar.HOUR_OF_DAY, Integer.valueOf(rule.getString("num22").split(" - ")[0].split(":")[0]));
-            s2.set(Calendar.MINUTE, Integer.valueOf(rule.getString("num22").split(" - ")[0].split(":")[1]));
-
-            Calendar e2 = Calendar.getInstance();
-            e2.setTime(date);
-            e2.set(Calendar.HOUR_OF_DAY, Integer.valueOf(rule.getString("num22").split(" - ")[1].split(":")[0]));
-            e2.set(Calendar.MINUTE, Integer.valueOf(rule.getString("num22").split(" - ")[1].split(":")[1]));
-            //高峰时段处理逻辑
-            if((date.getTime() > s1.getTimeInMillis() && date.getTime() < e1.getTimeInMillis()) || (date.getTime() > s2.getTimeInMillis() && date.getTime() < e2.getTimeInMillis())){
-                if(d > rule.getDouble("num6")){
-                    yt1 = rule.getDouble("num26") * (rule.getDouble("num7") - rule.getDouble("num6"));
-                }
-                if(d >  rule.getDouble("num9")){
-                    yt2 = rule.getDouble("num27") * (rule.getDouble("num10") - rule.getDouble("num9"));
-                }
-                if(d > rule.getDouble("num12")){
-                    yt3 = rule.getDouble("num28") * (d - rule.getDouble("num12"));
-                }
-                amount = rule.getDouble("num23") + (d1 * rule.getDouble("num24")) + (t1 * rule.getDouble("num25")) + (w1 * waitMoney) + yt1 + yt2 + yt3;
-                orderPrivateCar.setStartMileage(rule.getDouble("num2"));
-                orderPrivateCar.setStartMoney(rule.getDouble("num23"));//起步价
-                orderPrivateCar.setMileageKilometers(new BigDecimal(d1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                orderPrivateCar.setMileageMoney(new BigDecimal(d1 * rule.getDouble("num24")).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//里程费
-                orderPrivateCar.setDuration(new BigDecimal(t1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                orderPrivateCar.setDurationMoney(new BigDecimal(t1 * rule.getDouble("num25")).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//时长费
-                orderPrivateCar.setWait(new BigDecimal(w1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                orderPrivateCar.setWaitMoney(new BigDecimal(w1 * waitMoney).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//等待费
-                orderPrivateCar.setLongDistance(new BigDecimal((d > rule.getDouble("num6")) ? d - rule.getDouble("num6") : 0).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                orderPrivateCar.setLongDistanceMoney(new BigDecimal(yt1 + yt2 + yt3).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//远途费
-                orderPrivateCar.setParkMoney(parkingFee);//停车费
-                orderPrivateCar.setRoadTollMoney(crossingFee);//过路费
-                orderPrivateCar.setRedPacketMoney(0D);//红包抵扣
-                orderPrivateCar.setCouponMoney(0D);//优惠券抵扣
-                orderPrivateCar.setDiscount(0D);//优惠抵扣
-                orderPrivateCar.setPayMoney(0D);//支付金额
-                orderPrivateCar.setOrderMoney(new BigDecimal(amount + parkingFee + crossingFee).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-            }else{
-                //其他时间段的计算
-                if(d > rule.getDouble("num6")){
-                    yt1 = rule.getDouble("num8") * (rule.getDouble("num7") - rule.getDouble("num6"));
-                }
-                if(d >  rule.getDouble("num9")){
-                    yt2 = rule.getDouble("num11") * (rule.getDouble("num10") - rule.getDouble("num9"));
-                }
-                if(d > rule.getDouble("num12")){
-                    yt3 = rule.getDouble("num13") * (d - rule.getDouble("num12"));
-                }
-                amount = rule.getDouble("num1") + (d1 * rule.getDouble("num4")) + (t1 * rule.getDouble("num5")) + (w1 * waitMoney) + yt1 + yt2 + yt3;
-                orderPrivateCar.setStartMileage(rule.getDouble("num2"));
-                orderPrivateCar.setStartMoney(rule.getDouble("num1"));//起步价
-                orderPrivateCar.setMileageKilometers(new BigDecimal(d1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                orderPrivateCar.setMileageMoney(new BigDecimal(d1 * rule.getDouble("num4")).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//里程费
-                orderPrivateCar.setDuration(new BigDecimal(t1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                orderPrivateCar.setDurationMoney(new BigDecimal(t1 * rule.getDouble("num5")).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//时长费
-                orderPrivateCar.setWait(new BigDecimal(w1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                orderPrivateCar.setWaitMoney(new BigDecimal(w1 * waitMoney).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//等待费
-                orderPrivateCar.setLongDistance(new BigDecimal((d > rule.getDouble("num6")) ? d - rule.getDouble("num6") : 0).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                orderPrivateCar.setLongDistanceMoney(new BigDecimal(yt1 + yt2 + yt3).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//远途费
-                orderPrivateCar.setParkMoney(parkingFee);//停车费
-                orderPrivateCar.setRoadTollMoney(crossingFee);//过路费
-                orderPrivateCar.setRedPacketMoney(0D);//红包抵扣
-                orderPrivateCar.setCouponMoney(0D);//优惠券抵扣
-                orderPrivateCar.setDiscount(0D);//优惠抵扣
-                orderPrivateCar.setPayMoney(0D);//支付金额
-                orderPrivateCar.setOrderMoney(new BigDecimal(amount + parkingFee + crossingFee).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-            }
+            return orderPrivateCar;
         }
+
+        //其他时间段的计算
+        if(d > num8.doubleValue() && d <= num9.doubleValue()){
+            yt1 = num10 * (d - num8);
+        }
+        if(d > num9.doubleValue()){
+            yt1 = num10 * (num9 - num8);
+        }
+        if(d > num11.doubleValue() && d <= num12.doubleValue()){
+            yt2 = num13 * (d - num11);
+        }
+        if(d > num12.doubleValue()){
+            yt2 = num13 * (num12 - num11);
+        }
+        if(d > num14.doubleValue()){
+            yt3 = num15 * (d - num14);
+        }
+        amount = num1 + (d1 * num4) + (t1 * num5) + (w1 * num7) + yt1 + yt2 + yt3;
+        orderPrivateCar.setStartMileage(num2);
+        orderPrivateCar.setStartMoney(num1);//起步价
+        orderPrivateCar.setMileageKilometers(new BigDecimal(d1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
+        orderPrivateCar.setMileageMoney(new BigDecimal(d1 * num4).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//里程费
+        orderPrivateCar.setDuration(new BigDecimal(t1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
+        orderPrivateCar.setDurationMoney(new BigDecimal(t1 * num5).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//时长费
+        orderPrivateCar.setWait(new BigDecimal(w1).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
+        orderPrivateCar.setWaitMoney(new BigDecimal(w1 * num7).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//等待费
+        orderPrivateCar.setLongDistance(new BigDecimal((d > num8) ? d - num8 : 0).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
+        orderPrivateCar.setLongDistanceMoney(new BigDecimal(yt1 + yt2 + yt3).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());//远途费
+        orderPrivateCar.setParkMoney(parkingFee);//停车费
+        orderPrivateCar.setRoadTollMoney(crossingFee);//过路费
+        orderPrivateCar.setRedPacketMoney(0D);//红包抵扣
+        orderPrivateCar.setCouponMoney(0D);//优惠券抵扣
+        orderPrivateCar.setDiscount(0D);//优惠抵扣
+        orderPrivateCar.setPayMoney(0D);//支付金额
+        orderPrivateCar.setOrderMoney(new BigDecimal(amount + parkingFee + crossingFee).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
         return orderPrivateCar;
     }
 }

--
Gitblit v1.7.1