From b8a3a680f3e6720a8329bfaae571b09659aace52 Mon Sep 17 00:00:00 2001 From: Pu Zhibing <393733352@qq.com> Date: 星期三, 09 四月 2025 19:47:55 +0800 Subject: [PATCH] 开发推流拉流工具类 --- ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/controller/CarController.java | 92 ++++++++++++++++++++++++++++++++++++++-------- 1 files changed, 76 insertions(+), 16 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 570f7e6..b0f5363 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 @@ -7,6 +7,7 @@ import com.ruoyi.dataInterchange.api.feignClient.PlaybackMsgClient; import com.ruoyi.dataInterchange.api.feignClient.RealVideoMsgClient; import com.ruoyi.dataInterchange.api.feignClient.UPExgMsgRealLocationClient; +import com.ruoyi.dataInterchange.api.vo.GnssDataVo; import com.ruoyi.dataInterchange.api.vo.OrderTravelVo; import com.ruoyi.dataInterchange.api.vo.UPPlaybackMsgStartupAckVo; import com.ruoyi.dataInterchange.api.vo.UPRealvideoMsgStartupAckVo; @@ -19,18 +20,25 @@ import com.ruoyi.system.service.ICarTypeService; import com.ruoyi.system.service.IDriverService; import com.ruoyi.system.service.IEnterpriseService; +import com.ruoyi.system.util.JavaCVStreamUtil; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; +import org.springframework.data.redis.core.RedisTemplate; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; 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; +import java.util.concurrent.ExecutorService; +import java.util.concurrent.LinkedBlockingQueue; +import java.util.concurrent.ThreadPoolExecutor; +import java.util.concurrent.TimeUnit; /** * @author zhibing.pu @@ -40,27 +48,23 @@ @RequestMapping("/car") public class CarController { + private String outputUrl = "F:\\nginx 1.7.11.3 Gryphon\\html\\"; @Resource private ICarService carService; - @Resource private IDriverService driverService; - @Resource private IEnterpriseService enterpriseService; - @Resource private RealVideoMsgClient realVideoMsgClient; - @Resource private PlaybackMsgClient playbackMsgClient; - @Resource private UPExgMsgRealLocationClient upExgMsgRealLocationClient; - @Resource private ICarTypeService carTypeService; - + @Resource + private RedisTemplate redisTemplate; @GetMapping("/getCarList") @ApiOperation(value = "获取车辆列表", tags = {"车辆管理"}) @@ -83,7 +87,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); } @@ -103,12 +111,37 @@ if (200 == msgStartupAckVoR.getCode()) { UPRealvideoMsgStartupAckVo data = msgStartupAckVoR.getData(); RealVideoResp resp = new RealVideoResp(); - resp.setServerIp(data.getServerIP()); - resp.setServerPort(data.getServerPort()); + String url = "rtmp://192.168.110.85:1935/flv-live/" + car.getVehicleNumber(); + //执行拉流和推流 + ExecutorService executorService = new ThreadPoolExecutor(1, 1, + 0L, TimeUnit.MILLISECONDS, + new LinkedBlockingQueue<Runnable>()); + executorService.execute(new Runnable() { + @Override + public void run() { + JavaCVStreamUtil.push_flv(data.getUrl(), url, id); + } + }); + resp.setUrl(url); return R.ok(resp); } + return R.fail(msgStartupAckVoR.getMsg()); } + + + @GetMapping("/closeRealVideo/{id}") + @ApiOperation(value = "关闭实时音视频", tags = {"车辆管理"}) + @ApiImplicitParams({ + @ApiImplicitParam(value = "车辆id", name = "id", required = true) + }) + public R closeRealVideo(@PathVariable("id") Integer id){ + JavaCVStreamUtil.close(id); + return R.ok(); + } + + + @GetMapping("/getPlaybackVideo") @@ -124,8 +157,18 @@ if (200 == startupAckVoR.getCode()) { UPPlaybackMsgStartupAckVo data = startupAckVoR.getData(); RealVideoResp resp = new RealVideoResp(); - resp.setServerIp(data.getServerIP()); - resp.setServerPort(data.getServerPort()); + String url = "rtmp://192.168.110.85:1935/flv-live/" + car.getVehicleNumber(); + //执行拉流和推流 + ExecutorService executorService = new ThreadPoolExecutor(1, 1, + 0L, TimeUnit.MILLISECONDS, + new LinkedBlockingQueue<Runnable>()); + executorService.execute(new Runnable() { + @Override + public void run() { + JavaCVStreamUtil.push_flv(data.getUrl(), url, req.getId()); + } + }); + resp.setUrl(url); return R.ok(resp); } return R.fail(startupAckVoR.getMsg()); @@ -184,10 +227,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); @@ -201,4 +244,21 @@ return R.ok(carStatusCount); } + + @GetMapping("/getMapCarList") + @ApiOperation(value = "获取地图司机数据", tags = {"首页"}) + 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); + GnssDataVo gnssDataVo = (GnssDataVo) redisTemplate.opsForValue().get("location:" + car.getVehicleNumber()); + 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()); + car.setSpeed(gnssDataVo.getVec1()); + } + } + return R.ok(list); + } } -- Gitblit v1.7.1