From 35b0088fa28dab8a28758dcbcc056620c1ea5e2c Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期五, 30 五月 2025 11:02:35 +0800
Subject: [PATCH] 修改公交公司的事件订阅功能

---
 ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/CarController.java |   59 ++++++++++++++++++++++++++++++++++++++++-------------------
 1 files changed, 40 insertions(+), 19 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 7eac5d4..1111a36 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
@@ -5,6 +5,7 @@
 import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.core.utils.StringUtils;
 import com.ruoyi.common.core.web.page.PageInfo;
+import com.ruoyi.dataInterchange.api.feignClient.HaiKangClient;
 import com.ruoyi.dataInterchange.api.feignClient.PlaybackMsgClient;
 import com.ruoyi.dataInterchange.api.feignClient.RealVideoMsgClient;
 import com.ruoyi.dataInterchange.api.feignClient.UPExgMsgRealLocationClient;
@@ -86,6 +87,9 @@
 	@Resource
 	private RedisTemplate redisTemplate;
 	
+	@Resource
+	private HaiKangClient haiKangClient;
+	
 	@GetMapping("/getCarList")
 	@ApiOperation(value = "获取车辆列表", tags = {"车辆管理"})
 	public R<PageInfo<CarListResp>> getCarList(CarListReq carListReq) {
@@ -107,6 +111,7 @@
 		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.setCompanyCode(enterprise.getCode());
 		if (null != driver) {
 			car.setDriverName(driver.getName());
 			car.setDriverPhone(driver.getPhone());
@@ -124,28 +129,37 @@
 	public R<RealVideoResp> getRealVideo(@PathVariable("id") Integer id) {
 		Car car = carService.getById(id);
 		if (null == car) {
-			return R.fail("失败");
+			return R.fail("车辆信息获取失败");
 		}
 		//手动加一次状态数据,避免定时任务结束任务线程
 		redisTemplate.opsForValue().set("live:" + id, true, 1, TimeUnit.MINUTES);
 		Enterprise enterprise = enterpriseService.getById(car.getEnterpriseId());
-		R<UPRealvideoMsgStartupAckVo> msgStartupAckVoR = realVideoMsgClient.startupRealVideo(Integer.valueOf(enterprise.getCode()), car.getVehicleNumber());
-		if (200 == msgStartupAckVoR.getCode()) {
-			UPRealvideoMsgStartupAckVo data = msgStartupAckVoR.getData();
-			
-			RealVideoResp resp = new RealVideoResp();
-			//执行拉流和推流
+		//富临走协议返回flv格式视频流
+		if(enterprise.getCode().equals("17458936")){
+			R<UPRealvideoMsgStartupAckVo> msgStartupAckVoR = realVideoMsgClient.startupRealVideo(Integer.valueOf(enterprise.getCode()), car.getVehicleNumber());
+			if (200 == msgStartupAckVoR.getCode()) {
+				UPRealvideoMsgStartupAckVo data = msgStartupAckVoR.getData();
+				
+				RealVideoResp resp = new RealVideoResp();
+				resp.setCompanyCode(enterprise.getCode());
+				//执行拉流和推流
 //			live_hls(data.getUrl(), car);
 //			resp.setServerIp(hlsIp);
 //			resp.setServerPort(hlsPort);
-			
-			live_flv(data.getUrl(), car.getId());
-			resp.setServerIp(flvIp);
-			resp.setServerPort(flvHttpPort);
+				resp.setUrl(data.getUrl());
+//			live_flv(data.getUrl(), car.getId());
+				resp.setServerIp(flvIp);
+				resp.setServerPort(flvHttpPort);
+				return R.ok(resp);
+			}
+		}else if(enterprise.getCode().equals("25439966")){
+			//海康走API获取预览url,trsp格式
+			String data = haiKangClient.getCarPreviewURLs(car.getVehicleNumber()).getData();
+			RealVideoResp resp = new RealVideoResp();
+			resp.setUrl(data);
 			return R.ok(resp);
 		}
-		
-		return R.fail(msgStartupAckVoR.getMsg());
+		return R.ok();
 	}
 	
 	
@@ -195,8 +209,8 @@
 //			live_hls(data.getUrl(), car);
 //			resp.setServerIp(hlsIp);
 //			resp.setServerPort(hlsPort);
-			
-			live_flv(data.getUrl(), car.getId());
+			resp.setUrl(data.getUrl());
+//			live_flv(data.getUrl(), car.getId());
 			resp.setServerIp(flvIp);
 			resp.setServerPort(flvHttpPort);
 			return R.ok(resp);
@@ -240,7 +254,7 @@
 	@GetMapping("/getCarTypeList")
 	@ApiOperation(value = "获取车辆类型列表数据", tags = {"车辆类型"})
 	public R<List<CarType>> getCarTypeList(String name) {
-		List<CarType> list = carTypeService.list(new LambdaQueryWrapper<CarType>().like(StringUtils.isNotEmpty(name), CarType::getName, name));
+		List<CarType> list = carTypeService.list(new LambdaQueryWrapper<CarType>().like(StringUtils.isNotEmpty(name), CarType::getName, name).orderByAsc(CarType::getSort));
 		return R.ok(list);
 	}
 	
@@ -248,7 +262,7 @@
 	@GetMapping("/getCarCount")
 	@ApiOperation(value = "获取各种车辆类型车辆总数", tags = {"首页"})
 	public R<List<CarType>> getCarCount() {
-		List<CarType> list = carTypeService.list();
+		List<CarType> list = carTypeService.list(new LambdaQueryWrapper<CarType>().orderByAsc(CarType::getSort));
 		return R.ok(list);
 	}
 	
@@ -280,8 +294,11 @@
 	public R<List<Car>> getMapCarList() {
 		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);
+			car.setDrivingTime(0L);
+			if(null != car.getOnlineTime()){
+				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());
 			if (null != gnssDataVo) {
 				car.setLongitude(new BigDecimal(gnssDataVo.getLon()).divide(new BigDecimal(1000000)).toString());
@@ -333,4 +350,8 @@
 		});
 		carService.taskPlayDetection(id);
 	}
+	
+	
+	
+	
 }

--
Gitblit v1.7.1