当前位置: 首页 > news >正文

FFmpeg在python里推流被处理过的视频流

链式算法处理视频流

 视频源是本地摄像头

# coding=gbk
# 本地摄像头直接推流到 RTMP 服务器
import cv2
import mediapipe as mp
import subprocess as sp# 初始化 Mediapipe
mp_drawing = mp.solutions.drawing_utils
mp_drawing_styles = mp.solutions.drawing_styles
mp_holistic = mp.solutions.holisticholistic = mp_holistic.Holistic(min_detection_confidence=0.7,min_tracking_confidence=0.7
)# AI 算法处理帧
def frame_handler(image):image.flags.writeable = Falseimage_rgb = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)results = holistic.process(image_rgb)if results.pose_world_landmarks is not None:image.flags.writeable = Truemp_drawing.draw_landmarks(image,results.pose_landmarks,mp_holistic.POSE_CONNECTIONS,landmark_drawing_spec=mp_drawing_styles.get_default_pose_landmarks_style())return image# 设置摄像头
camera_index = 0
cap = cv2.VideoCapture(camera_index)
if not cap.isOpened():raise IOError("无法打开本地摄像头")# 设置分辨率和帧率
width, height = 640, 360  # 分辨率
fps = 15                 # 帧率
cap.set(cv2.CAP_PROP_FRAME_WIDTH, width)
cap.set(cv2.CAP_PROP_FRAME_HEIGHT, height)
cap.set(cv2.CAP_PROP_FPS, fps)# FFmpeg 推流地址
dst = "rtmp://localhost:1935/live/dest-local"# FFmpeg 推流命令
command = ['ffmpeg','-y',                  # 覆盖输出文件'-f', 'rawvideo',      # 输入原始视频流格式'-vcodec', 'rawvideo','-pix_fmt', 'bgr24',   # 像素格式'-s', f"{width}x{height}",  # 分辨率'-r', str(fps),        # 帧率'-i', '-',             # 从标准输入读取视频流'-c:v', 'libx264',     # 视频编码格式'-preset', 'ultrafast',  # 超快编码模式'-tune', 'zerolatency',  # 优化零延迟'-bufsize', '64k',       # 缓冲区设置较小'-maxrate', '1M',        # 最大码率控制'-g', '15',              # GOP(关键帧间隔,降低到 15 帧)'-f', 'flv',            # 输出格式dst
]# 启动 FFmpeg 子进程
pipe = sp.Popen(command, stdin=sp.PIPE)# 视频处理和推流
try:while True:ret, frame = cap.read()if not ret:print("无法读取摄像头数据,程序退出")break# 使用 Mediapipe 算法处理帧processed_frame = frame_handler(frame)# 将帧写入 FFmpeg 输入管道pipe.stdin.write(processed_frame.tobytes())# 显示处理结果cv2.imshow('Video', processed_frame)# 按 'q' 键退出if cv2.waitKey(1) & 0xFF == ord('q'):break
finally:# 释放资源cap.release()cv2.destroyAllWindows()pipe.stdin.close()pipe.wait()print("程序结束")

视频流是网络流 :

# coding=gbk
# 网络摄像头直接推流到 RTMP 服务器
import subprocess as spimport cv2
import mediapipe as mp# 初始化 Mediapipe
mp_drawing = mp.solutions.drawing_utils
mp_drawing_styles = mp.solutions.drawing_styles
mp_holistic = mp.solutions.holisticholistic = mp_holistic.Holistic(min_detection_confidence=0.7,min_tracking_confidence=0.7
)# AI 算法处理帧
def frame_handler(image):image.flags.writeable = Falseimage_rgb = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)results = holistic.process(image_rgb)if results.pose_world_landmarks is not None:image.flags.writeable = Truemp_drawing.draw_landmarks(image,results.pose_landmarks,mp_holistic.POSE_CONNECTIONS,landmark_drawing_spec=mp_drawing_styles.get_default_pose_landmarks_style())return image# 设置网络摄像头地址
camera_index = "rtsp://admin:@xxzx@192.168.1.64:554/Streaming/Channels/101"  # 替换为你的网络摄像头地址
cap = cv2.VideoCapture(camera_index)
if not cap.isOpened():raise IOError(f"无法打开网络摄像头流:{camera_index}")# 设置分辨率和帧率
width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))  # 自动获取分辨率宽度
height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))  # 自动获取分辨率高度
fps = int(cap.get(cv2.CAP_PROP_FPS))  # 自动获取帧率# 如果获取失败,设置默认值
if fps == 0:fps = 15
if width == 0 or height == 0:width, height = 640, 360  # 设置默认分辨率# RTMP 推流地址
dst = "rtmp://localhost:1935/live/dest-net"# FFmpeg 推流命令
command = ['ffmpeg','-y',  # 覆盖输出文件'-f', 'rawvideo',  # 输入原始视频流格式'-vcodec', 'rawvideo','-pix_fmt', 'bgr24',  # 像素格式'-s', f"{width}x{height}",  # 分辨率'-r', str(fps),  # 帧率'-i', '-',  # 从标准输入读取视频流'-c:v', 'libx264',  # 视频编码格式'-preset', 'ultrafast',  # 超快编码模式'-tune', 'zerolatency',  # 优化零延迟'-bufsize', '64k',  # 缓冲区设置较小'-maxrate', '1M',  # 最大码率控制'-g', '15',  # GOP(关键帧间隔,降低到 15 帧)'-f', 'flv',  # 输出格式dst
]# 启动 FFmpeg 子进程
pipe = sp.Popen(command, stdin=sp.PIPE)# 视频处理和推流
try:while True:ret, frame = cap.read()if not ret:print("无法读取网络摄像头流,程序退出")break# 使用 Mediapipe 算法处理帧processed_frame = frame_handler(frame)# 将帧写入 FFmpeg 输入管道pipe.stdin.write(processed_frame.tobytes())# 显示处理结果cv2.imshow('Video', processed_frame)# 按 'q' 键退出if cv2.waitKey(1) & 0xFF == ord('q'):break
finally:# 释放资源cap.release()cv2.destroyAllWindows()pipe.stdin.close()pipe.wait()print("程序结束")

http://www.lryc.cn/news/510565.html

相关文章:

  • 为什么推荐使用构造函数注入而非@Autowired注解进行字段注入
  • 如何卸载和升级 Angular-CLI ?
  • 在线excel编辑(luckysheet)
  • 【ES6复习笔记】Symbol 类型及其应用(9)
  • [原创](Modern C++)现代C++的第三方库的导入方式: 例如Visual Studio 2022导入GSL 4.1.0
  • 【ES6复习笔记】Class类(15)
  • 【Golang 面试题】每日 3 题(六)
  • openEuler安装OpenGauss5.0
  • 20241230 机器学习ML -(1)线性回归(scikitlearn)
  • MacOS下TestHubo安装配置指南
  • mysql性能问题排查
  • centos单机部署seata
  • YOLOv9-0.1部分代码阅读笔记-lion.py
  • 运行Zr.Admin项目(前端)
  • HarmonyOS NEXT 实战之元服务:静态多案例效果(一)
  • go下载依赖提示连接失败
  • JS 异步 ( 二、Promise 的用法、手写模拟 Promise )
  • 五分钟学会如何在GitHub上自动化部署个人博客(hugo框架 + stack主题)
  • 【ETCD】【实操篇(十五)】etcd集群成员管理:如何高效地添加、删除与更新节点
  • 灵当CRM uploadfile.php 文件上传致RCE漏洞复现
  • Linux下Java通过JNI调用C++
  • 解决:excel鼠标滚动幅度太大如何调节?
  • Git和SVN有什么区别?
  • 【深度学习基础|pip安装】pip 安装深度学习库常见错误及解决方案,附案例。
  • 【ES6复习笔记】解构赋值(2)
  • Dockerfile的用法
  • Docker 安装mysql ,redis,nacos
  • Axure RP 11 详细保姆级安装教程(附安装包)
  • Java处理视频思路
  • 攻防世界 robots