ffmpeg播放音视频流程

文章目录

    • [🎬 FFmpeg 解码播放流程概览(以音视频文件为例)](#🎬 FFmpeg 解码播放流程概览(以音视频文件为例))
      • [1️⃣ 创建结构体](#1️⃣ 创建结构体)
      • [2️⃣ 打开音视频文件](#2️⃣ 打开音视频文件)
      • [3️⃣ 查找解码器并打开解码器](#3️⃣ 查找解码器并打开解码器)
      • [4️⃣ 循环读取数据包(Packet)](#4️⃣ 循环读取数据包(Packet))
      • [5️⃣ 解码成帧(Frame)](#5️⃣ 解码成帧(Frame))
      • [6️⃣ 播放 / 显示 / 播放音频](#6️⃣ 播放 / 显示 / 播放音频)
      • [7️⃣ 清理资源](#7️⃣ 清理资源)
    • [✅ 总结一句话流程:](#✅ 总结一句话流程:)

🎬 FFmpeg 解码播放流程概览(以音视频文件为例)

1️⃣ 创建结构体

准备容器结构体,用于打开媒体文件并读取信息

  • 创建 AVFormatContext

    c 复制代码
    AVFormatContext *fmt_ctx = NULL;
  • 【可选】使用 avformat_alloc_context 手动分配(很多时候由 avformat_open_input 自动完成)


2️⃣ 打开音视频文件

打开媒体文件并读取格式头部信息

  • 使用 avformat_open_input() 打开文件
  • 使用 avformat_find_stream_info() 读取流信息(视频流、音频流)

3️⃣ 查找解码器并打开解码器

  • 遍历 fmt_ctx->streams[i],找到视频流和音频流的索引
  • 获取 AVCodecParameters
  • 使用 avcodec_find_decoder() 找到对应的解码器
  • 使用 avcodec_alloc_context3() 创建解码器上下文 AVCodecContext
  • 使用 avcodec_parameters_to_context() 拷贝参数
  • 使用 avcodec_open2() 打开解码器

4️⃣ 循环读取数据包(Packet)

将原始的压缩音视频数据读取出来

  • 使用 av_read_frame() 读取 AVPacket
  • 判断 packet.stream_index 来区分是视频包还是音频包

5️⃣ 解码成帧(Frame)

将压缩包解码成原始帧

  • 使用 avcodec_send_packet()AVPacket 发送给解码器
  • 使用 avcodec_receive_frame() 获取解码后的 AVFrame

6️⃣ 播放 / 显示 / 播放音频

这一步跟平台相关:

  • 视频帧可以用 SDL、OpenGL、Qt 等显示
  • 音频帧可以送给音频设备播放(如 SDL、PortAudio、ALSA)

7️⃣ 清理资源

  • av_packet_unref()av_frame_unref() 用于复用
  • avcodec_free_context() 释放解码器上下文
  • avformat_close_input()avformat_free_context() 释放格式上下文

✅ 总结一句话流程:

创建结构体 → 打开文件 → 查找流 → 找解码器 → 解码成帧 → 播放 → 释放资源


相关推荐
REDcker5 天前
WebCodecs VideoDecoder 的 hardwareAcceleration 使用
前端·音视频·实时音视频·直播·webcodecs·videodecoder
gihigo19985 天前
基于TCP协议实现视频采集与通信
网络协议·tcp/ip·音视频
山河君5 天前
四麦克风声源定位实战:基于 GCC-PHAT + 最小二乘法实现 DOA
算法·音视频·语音识别·信号处理·最小二乘法·tdoa
音视频牛哥5 天前
Android平台RTMP/RTSP超低延迟直播播放器开发详解——基于SmartMediaKit深度实践
android·人工智能·计算机视觉·音视频·rtmp播放器·安卓rtmp播放器·rtmp直播播放器
qq_416276425 天前
通用音频表征的对比学习
学习·音视频
美狐美颜sdk5 天前
Android全局美颜sdk实现方案详解
人工智能·音视频·美颜sdk·视频美颜sdk·美狐美颜sdk
EasyDSS5 天前
私有化部署EasyDSS视频点播能力:全链路视频技术赋能,打造企业级视听新体验
音视频·hls·m3u8·点播技术·智能转码
qq_416276425 天前
DeLoRes——一种通用的音频表征学习新方法(DeLoRes(基于 Barlow Twins 的冗余最小化方法)
学习·音视频
Q_4582838685 天前
从定位到视频:808 + 1078 在各行业的落地实践
音视频
山顶望月川5 天前
实测MiniMax-Hailuo-02:当“开工大吉“变成“无字天书“,国产AI视频模型的能与之不能
人工智能·音视频