前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >FFmpeg 音视频处理核心技术初体验

FFmpeg 音视频处理核心技术初体验

作者头像
用户1081422
发布2020-04-08 10:03:35
1.6K0
发布2020-04-08 10:03:35
举报
文章被收录于专栏:T客来了

章节

  • 视频播放器原理
  • 什么是 ffmpeg?
  • ffmpeg 音视频编/解码 流程图
  • ffmpeg 常用 struct
  • AVFormatContext
  • AVStream
  • AVCodecContext
  • AVCodec
  • AVPacket
  • AVFrame
  • ffmpeg 常用Api
  • avregisterall()
  • avformatallocoutput_context2()
  • avio_open()
  • avnewstream()
  • avcodecfindencoder()
  • avcodec_open2()
  • avformatwriteheader()
  • avcodecencodevideo2()
  • avwriteframe()
  • flush_encoder()
  • avwritetrailer()
  • ffmpeg编码视频的流程图
  • ffmpeg解码视频的流程图
  • 分享-解决问题的思路

0.视频播放器原理

编码

录像(视频)、录音(音频),实质上是一个压缩采集到的图像或者音频数据的过程,这个过程又称为编码。那为什么需要编码(压缩)呢?因为设备采集到的音视频数据太大了,如果不进行压缩,占用的空间太大,不利于传输等。 解码 播放视频或者音频文件,实质上是一个解压缩的过程,这个过程又称为解码。那为什么又要解码(解压缩)呢?因为播放器播放需要的是音频采样数据、视频像素数据,通俗一点来说就是需要的是编码之前的数据,所以需要解码来获取。

如下图展示了播放器播放视频的原理:

作者:zhang_pan 链接:https://www.jianshu.com/p/55e5da60faeb 來源:简书

1.什么是ffmpeg?

1.ffmpeg 是音视频处理核心技术,要成为音视频领域的开发高手,不可不学 ffmpeg,一个完整的跨平台解决方案,用于录制,转换和流式传输音频和视频的技术。 2.腾讯视频、爱奇艺、阿里影音、均有大量 音视频开发工程师的需求。 3.ffmpeg 源代码 采用 c++编写

2.ffmpeg 音视频编/解码 流程图

如下所示流程图:

如上图所示,音视频文件已流形式经编码 encode 之后成为 packetpacket 被解码之后成为视频帧frame

3.ffmpeg 常用 struct

AVFormatContext

AVFormatContext 主要存储视音频封装格式中包含的信息

AVStream

AVStream 存储一个视频/音频流的相关数据

AVCodecContext

流解码器容器-每个AVStream对应一个AVCodecContext,存储该视频/音频流使用解码方式的相关数据、如 codec_type 编码器类型。

AVCodec

解码器-每个AVCodecContext中对应一个AVCodec,包含该视频/音频对应的解码器。每种解码器都对应一个AVCodec结构。

AVPacket

视频,每个结构一般是存一帧;音频可能有好几帧

帧(stream)数据编码后的数据,或解码为 帧(stream) 数据前的数据存储格式为AVPacket AVFrame 包(Packet)数据解码之后以帧(frame)的结构存在。

4.ffmpeg 常用Api

av_ register_ all()

注意:av_ register_ all()其实中间没有空格,编辑器出现了问题

注册所有 ffmpeg 解码器, 如果需要使用支持特定类型音视频解码的解码器则需要使用 void av_ register_ input_ format(AVInputFormat *format);

avformat_ alloc_ output_ context2()

初始化输出码流的AVFormatContext。

avio_ open()

创建并初始化AVIOContext以访问 url 指示的资源。

av_ new_ stream()

创建新流,此新流用于添加到新的媒体文件

avcodec_ find_ encoder()

查找编码器,一般是用来将数据帧进行编码,并生成新的输出文件。

avcodec_ open2()

打开编码器

avformat_ write_ header()

写文件头(对于某些没有文件头的封装格式,不需要此函数。比如说MPEG2TS)。

avcodec_ encode_ video2()

将 frame 进行编码,并转化为 packet 进行存储

av_ write_ frame()

Write a packet to an output media file. 将编码后的视频码流写入文件

flush_encoder()

Write the stream trailer to an output media file and free the file private data。 将流预告片写入输出媒体文件并释放文件私人数据。

其实上述常用Api 是一个视频流文件进行编码并输出编码后文件常用的Api

ffmpeg编码视频的流程图

如下所示:

ffmpeg解码视频的流程图

4 分享-解决问题的思路

最近接触 ffmpeg 是因为部门业务需要,之前个人从未接触过 ffmpeg。知道自己不知道很重要,李笑来-《与时间做朋友》这本书中描述,大多数人在估算任务时间时,总会将时间估计的很少,以至于经常受到deadline的压迫,导致这个问题的原因通常是在做事情之前没有意识到这件事是自己之前做过的,还是没有做过的,面对新的领域,总有未知的事情需要解决,我们是预测不了解决未知需要花费多少时间的,现在不能,以后也不能!所以不能做到游刃有余。deadline,一个极富压抑色彩的词。

4.1 业务目标

通过调用 ffmpeg Api 实现截取视频任意一帧。

4.2 出现的问题

1.个人对视频当中某一帧获取流程不是很了解; 2.读源码过程中 有些 ffmpeg Api 看不懂;

4.3 问题的根本原因

1.对视频播放的本质不清楚,其实视频的本质是一帧一帧的图片拼接起来的结果; 2.没有耐心读 ffmpeg 源码,因为没学过c++; 3.对未知的从未尝试过的事情有些许排斥。

4.4 解决问题的方案

1.了解视频播放原理-知道了解码、编码等问题 (完成100%) 2.了解ffmpeg、解码、编码(所以解决方案的第一步是前提)、学习编码/解码相关流程,(毕竟视频的生成、播放与编解码是分不开的)、以及相关Api (完成100%) 3.尝试读前辈代码、并提取实现业务的 keycode、文档输出等。(2018-10-23日晚上下班前输出相关文档)

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-10-23,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 T客来了 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 章节
    • 0.视频播放器原理
      • 编码
    • 1.什么是ffmpeg?
      • 2.ffmpeg 音视频编/解码 流程图
        • 3.ffmpeg 常用 struct
          • AVFormatContext
          • AVStream
          • AVCodecContext
          • AVCodec
          • AVPacket
        • 4.ffmpeg 常用Api
          • av_ register_ all()
          • avformat_ alloc_ output_ context2()
          • avio_ open()
          • av_ new_ stream()
          • avcodec_ find_ encoder()
          • avcodec_ open2()
          • avformat_ write_ header()
          • avcodec_ encode_ video2()
          • av_ write_ frame()
          • flush_encoder()
          • ffmpeg编码视频的流程图
          • ffmpeg解码视频的流程图
        • 4 分享-解决问题的思路
          • 4.1 业务目标
          • 4.2 出现的问题
          • 4.3 问题的根本原因
          • 4.4 解决问题的方案
      相关产品与服务
      云点播
      面向音视频、图片等媒体,提供制作上传、存储、转码、媒体处理、媒体 AI、加速分发播放、版权保护等一体化的高品质媒体服务。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档