From 4109495b9c51a4bbd8b0a7c3c69093909d2e33e1 Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期一, 07 四月 2025 18:55:05 +0800
Subject: [PATCH] 修改接口bug

---
 ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/CarController.java |   25 +++++++++++++++++--------
 1 files changed, 17 insertions(+), 8 deletions(-)

diff --git a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/CarController.java b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/CarController.java
index 3255d47..6389a8e 100644
--- a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/CarController.java
+++ b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/CarController.java
@@ -30,6 +30,7 @@
 import org.springframework.web.bind.annotation.RestController;
 
 import javax.annotation.Resource;
+import java.math.BigDecimal;
 import java.time.LocalDateTime;
 import java.time.ZoneOffset;
 import java.util.List;
@@ -88,7 +89,11 @@
 		Driver driver = driverService.getOne(new LambdaQueryWrapper<Driver>().eq(Driver::getVehicleNumber, car.getVehicleNumber()).eq(Driver::getStatus, 1));
 		Enterprise enterprise = enterpriseService.getById(car.getEnterpriseId());
 		car.setEnterpriseName(enterprise.getName());
-		car.setDriverName(driver.getName());
+		if (null != driver) {
+			car.setDriverName(driver.getName());
+			car.setDriverPhone(driver.getPhone());
+			car.setDrivingLicenseNumber(driver.getDrivingLicenceFile());
+		}
 		return R.ok(car);
 	}
 	
@@ -189,10 +194,10 @@
 	@ApiOperation(value = "获取车辆状态汇总数据和公司总数等", tags = {"首页"})
 	public R<CarStatusCount> getCarStatusCount() {
 		List<Car> list = carService.list();
-		long online = list.stream().filter(s -> s.getStatus() == 1).count();
-		long offline = list.stream().filter(s -> s.getStatus() == 3).count();
-		long breakdown = list.stream().filter(s -> s.getStatus() == 4).count();
-		long abnormal = list.stream().filter(s -> s.getStatus() == 2).count();
+		long online = list.isEmpty() ? 0 : list.stream().filter(s -> s.getStatus() == 1).count();
+		long offline = list.isEmpty() ? 0 : list.stream().filter(s -> s.getStatus() == 3).count();
+		long breakdown = list.isEmpty() ? 0 : list.stream().filter(s -> s.getStatus() == 4).count();
+		long abnormal = list.isEmpty() ? 0 : list.stream().filter(s -> s.getStatus() == 2).count();
 		CarStatusCount carStatusCount = new CarStatusCount();
 		carStatusCount.setOffline(offline);
 		carStatusCount.setOnline(online);
@@ -210,11 +215,15 @@
 	@GetMapping("/getMapCarList")
 	@ApiOperation(value = "获取地图司机数据", tags = {"首页"})
 	public R<List<Car>> getMapCarList() {
-		List<Car> list = carService.list();
+		List<Car> list = carService.list(new LambdaQueryWrapper<Car>().eq(Car::getStatus, 1));
 		for (Car car : list) {
+			Long s = (null == car.getDownlineTime() ? LocalDateTime.now() : car.getDownlineTime()).toEpochSecond(ZoneOffset.ofHours(8)) - car.getOnlineTime().toEpochSecond(ZoneOffset.ofHours(8));
+			car.setDrivingTime(s / 60);
 			GnssDataVo gnssDataVo = (GnssDataVo) redisTemplate.opsForValue().get("location:" + car.getVehicleNumber());
-			car.setLongitude(Double.valueOf(gnssDataVo.getLon() / 1000000).toString());
-			car.setLatitude(Double.valueOf(gnssDataVo.getLat() / 1000000).toString());
+			if (null != gnssDataVo) {
+				car.setLongitude(new BigDecimal(gnssDataVo.getLon()).divide(new BigDecimal(1000000)).toString());
+				car.setLatitude(new BigDecimal(gnssDataVo.getLat()).divide(new BigDecimal(1000000)).toString());
+			}
 		}
 		return R.ok(list);
 	}

--
Gitblit v1.7.1