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/util/JavaCVStreamUtil.java |   53 ++++++++++++++++++++++++++---------------------------
 1 files changed, 26 insertions(+), 27 deletions(-)

diff --git a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/util/JavaCVStreamUtil.java b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/util/JavaCVStreamUtil.java
index ea4a44c..4356127 100644
--- a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/util/JavaCVStreamUtil.java
+++ b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/util/JavaCVStreamUtil.java
@@ -2,14 +2,11 @@
 
 import cn.hutool.core.io.FileUtil;
 import com.ruoyi.common.core.utils.StringUtils;
-import com.ruoyi.system.service.ICarService;
 import org.bytedeco.ffmpeg.global.avcodec;
 import org.bytedeco.ffmpeg.global.avutil;
 import org.bytedeco.javacv.*;
-import org.springframework.data.redis.core.RedisTemplate;
 import org.springframework.stereotype.Component;
 
-import javax.annotation.Resource;
 import java.util.Map;
 import java.util.concurrent.ConcurrentHashMap;
 
@@ -31,19 +28,21 @@
 	
 	private static Map<Integer, Boolean> statusMap = new ConcurrentHashMap<>();
 	
-	@Resource
-	private RedisTemplate redisTemplate;
 	
-	@Resource
-	private ICarService carService;
+	public static void main(String[] args) {
+		String url = "rtmp://127.0.0.1:1935/flv/test";
+		JavaCVStreamUtil.push_flv("C:\\Users\\39373\\Desktop\\图片\\trailer.mp4", url, 0);
+	}
+	
+	
 	
 	
 	/**
 	 * 视频拉流和推流
 	 */
 	public static void push_flv(String inputUrl, String outputUrl, Integer deviceNumber) {
-		OpenCVFrameGrabber grabber = null;
-//		FFmpegFrameGrabber grabber = null;
+//		OpenCVFrameGrabber grabber = null;
+		FFmpegFrameGrabber grabber = null;
 		FFmpegFrameRecorder recorder = null;
 		try {
 			//关闭上一个没有正确关闭的流
@@ -54,7 +53,6 @@
 			OpenCVFrameGrabber openCVFrameGrabber = grabberMap1.get(deviceNumber);
 			if (null != openCVFrameGrabber) {
 				openCVFrameGrabber.close();
-				;
 			}
 			FFmpegFrameRecorder fFmpegFrameRecorder = frameRecorderMap.get(deviceNumber);
 			if (null != fFmpegFrameRecorder) {
@@ -66,36 +64,34 @@
 			FFmpegLogCallback.set();
 			
 			//视频抓帧
-//			grabber = new FFmpegFrameGrabber(inputUrl);
-//			grabber.setOption("rtsp_transport", "tcp");
-//			// 正确设置超时时间
-//			grabber.setOption("timeout", "120000");
-//			grabber.start();
-//			grabberMap.put(deviceNumber, grabber);
-			
-			grabber = new OpenCVFrameGrabber(0);
+			grabber = new FFmpegFrameGrabber(inputUrl);
+			grabber.setVideoCodec(avcodec.AV_CODEC_ID_H264);
 			grabber.start();
-			grabberMap1.put(deviceNumber, grabber);
+			grabberMap.put(deviceNumber, grabber);
+
+//			grabber = new OpenCVFrameGrabber(0);
+//			grabber.start();
+//			grabberMap1.put(deviceNumber, grabber);
 			
 			//录制视频,推送到流媒体服务器(nginx)
 			recorder = new FFmpegFrameRecorder(outputUrl, grabber.getImageWidth(), grabber.getImageHeight());
 			recorder.setFormat("flv");
 			// 设置视频比特率
 			recorder.setVideoBitrate(grabber.getVideoBitrate());
-//			// 设置帧率
-//			recorder.setFrameRate(grabber.getVideoFrameRate());
-//			// 设置关键帧间隔
-//			recorder.setGopSize((int) grabber.getVideoFrameRate());
+			// 设置帧率
+			recorder.setFrameRate(grabber.getVideoFrameRate());
+			// 设置关键帧间隔
+			recorder.setGopSize((int) grabber.getVideoFrameRate());
 			// CRF 是一种用于控制视频/音频质量的参数,它允许在保持目标质量的同时动态地调整比特率。较低的CRF值表示更高的质量,但也可能导致较大的文件大小
 			recorder.setAudioOption("crf", "23");
-			
+
 			//设置音频编码为AAC
 			if (grabber.getAudioChannels() > 0) {
 				recorder.setAudioChannels(grabber.getAudioChannels());
 				recorder.setAudioBitrate(grabber.getAudioBitrate());
-				recorder.setAudioCodec(avcodec.AV_CODEC_ID_AAC);
+				recorder.setAudioCodec(grabber.getAudioCodec());
 			}
-			recorder.setVideoCodec(avcodec.AV_CODEC_ID_H264);
+			recorder.setVideoCodec(avcodec.AV_CODEC_ID_FLV1);
 			//将解码后的帧记录到输出文件中
 			//recorder.start通常用于处理已经解码成图像的视频数据
 			recorder.start();
@@ -190,7 +186,7 @@
 				recorder.setAudioCodec(avcodec.AV_CODEC_ID_AAC);
 			}
 			
-			recorder.setVideoCodec(avcodec.AV_CODEC_ID_H264);
+			recorder.setVideoCodec(avcodec.AV_CODEC_ID_FLV1);
 			//设置音频编码为AAC
 			if (grabber.getAudioChannels() > 0) {
 				recorder.setAudioChannels(grabber.getAudioChannels());
@@ -237,14 +233,17 @@
 		try {
 			fFmpegFrameGrabber = grabberMap.get(deviceNumber);
 			if (null != fFmpegFrameGrabber) {
+				fFmpegFrameGrabber.flush();
 				fFmpegFrameGrabber.close();
 			}
 			openCVFrameGrabber = grabberMap1.get(deviceNumber);
 			if (null != openCVFrameGrabber) {
+				openCVFrameGrabber.flush();
 				openCVFrameGrabber.close();
 			}
 			fFmpegFrameRecorder = frameRecorderMap.get(deviceNumber);
 			if (null != fFmpegFrameRecorder) {
+				fFmpegFrameRecorder.flush();
 				fFmpegFrameRecorder.close();
 			}
 		} catch (Exception e) {

--
Gitblit v1.7.1