1、简介
FFmpeg是一套由c语言编写的,可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序,自身采用LGPL或GPL许可证。它提供了录制、转换以及流化音视频的完整解决方案,包含了非常先进的音频/视频编解码库libavcodec,为了保证高可移植性和编解码质量,libavcodec里很多code都是从头开发的。
- FFmpeg项目由Fabrice Bellard创建于2000年,使用C语言和汇编语言编写。
- FFmpeg名称中的"FF"是“Fast Forward”的缩写,是快进的意思。“mpeg” 则是标准化组织“Moving
Pictures Experts Group”的缩写。 - 属于自由软件, 采用 LGPL 或GPL 许可证(依据你选择的组件)。
FFmpeg在Linux平台下开发,但它同样也可以在其它操作系统环境中编译运行,包括Windows、Mac OS X等。这个项目最早由Fabrice Bellard发起,2004年至2015年间由Michael Niedermayer主要负责维护。许多FFmpeg的开发人员都来自MPlayer项目,而且当前FFmpeg也是放在MPlayer项目组的服务器上。项目的名称来自MPEG视频编码标准,前面的"FF"代表"Fast Forward",FFmpeg编码库可以使用GPU加速。
Libav 和 FFmpeg 是什么关系?
答:原始FFmpeg的一群开发者不满FFmpeg的项目管理方式,所以fork了新的一个项目,叫libav。结果是增加了竞争,让FFmpeg更新的更频繁,FFmpeg经常把Libav的提交合并回FFmpeg;但是就链接作者所说,libav的开发也有很多自己的问题,所以FFmpeg与Libav哪个发展最好也很难判断。
2、功能介绍
多媒体视频处理工具FFmpeg有非常强大的功能包括视频采集功能、视频格式转换、视频抓图、给视频加水印等。下面简单介绍一些常用功能。
-
音视频播放器内核
ffmpeg可以作为核心库文件,制作音视频播放器。 -
视频采集功能
ffmpeg视频采集功能非常强大,不仅可以采集视频采集卡或 USB 摄像头的图像,还可以进行屏幕录制,同时还支持以 RTP 方式将视频流传送给支持RTSP、RTMP的流媒体服务器,支持直播应用。 -
视频格式转换功能
ffmpeg 视频格式转换功能。ffmpeg 可以轻易地实现多种视频格式之间的相互转换(wma,rm,avi,mod 等),例如可以将摄录下的视频 avi 等转成视频网站所采用的 flv 格式。 -
音视频截取功能
对于选定的音视频,截取指定时间的缩略图或者声音。
3、下载
官网下载地址:http://ffmpeg.org/download.html#build-windows下载地址
可以下载源码,也可以依据不同操作系统下载编译好的版本,编译好的版本目前分为两种,一种是静态编译 ffmpeg-6.0-full_build.7z,文件包内只包含3个exe文件,如下图所示:
另外一种带shared后缀的是开发包,包含lib和dll文件。例如ffmpeg-6.0-full_build-shared.7z。
4、SDK介绍
4.1 工具exe
四个作用不同的工具软件,分别是:ffmpeg.exe,ffplay.exe,ffserver.exe和 ffprobe.exe。其中从4.0版本移除了ffserver流媒体服务。
- ffmpeg:对视频音频和图片进行编解码、格式转换、分割和合并等。
- ffplay:简单的媒体播放器,使用了ffmpeg 和 sdl 库。
- ffprobe:简单的多媒体码流分析器。
- ffserver.exe:流媒体服务器
4.2 SDK介绍
SDK主要包含以下8个lib库,其中avresample.lib在新版本已经不存在被废弃了。所以说新版只有7个lib。
- libavcodec:包含音视频编码器和解码器。编解码库,封装了 Codec 层,但是有一些 codec 是具备自己的 License的,FFmpe 不会默认添加像 libx264、FDK-AAC、Lame 等库,但是 FFmpeg 是一个平台,可以将其他的第三方codec 以插件的方式添加进来,为开发者提供统一接口。
- libavutil:包含多媒体应用常用的简化编程的工具,如随机数生成器、数据结构、数学函数等功能。核心工具库,最基础模块之一,其他模块都会依赖该库做一些基本的音视频处理操作。
- libavformat:包含多种多媒体容器格式的封装、解封装工具。文件格式和协议库,封装了 Protocol 层和Demuxer、Muxer 层,使得协议和格式对于开者来说是透明的。
- libavfilter:包含多媒体处理常用的滤镜功能。音视频滤镜库,该模块包含了音频特效和视频特效的处理,在使用 FFmpeg 的 API进行编解码的过程中,可以使用该模块高效的为音视频数据做特效处理。
- libavdevice:用于音视频数据采集和渲染等功能的设备相关。输入输出设备库,比如需要编译出播放声音或者视频的工具 ffplay,就需要确保该模块是打开的,同事也需要 libsdl 的预先编译,该设备模块播放声音和视频都又是使用 libsdl 库。
- libswscale:用于图像缩放和色彩空间和像素格式转换功能。该模块用于图像格式转换,可以将 YUV 的数据转换为 RGB 的数据。
- libswresample:用于音频重采样和格式转换等功能。用于音频重采样,可以对数字音频进行声道数、数据格式、采样率等多种基本信息的转换。
- libpostproc:该模块用于进行后期处理,当我们使用 filter 的时候,需要打开这个模块,filter
会用到这个模块的一些基础函数。
比较老的 ffmpeg 还会编译出 avresamle 模块,也是用于对音频原始出具进行重采样的,但是已经被废弃,推荐使用 libswresample 替代。另外,库里还可以包含对 H.264/MPEG-4 AVC 视频编码的 X264 库,是最常用的有损视频编码器,支持 CBR、VBR 模式,可以在编码的过程中直接改变码率的设置,在直播的场景中非常适用!可以做码率自适应的功能。