ffmpeg 简单功能描述

 

1 概述

ffmpeg [global_options]{[input_file_option] –i input_file}…{[output_file_options] output_file}算法

ffmpeg [全局选项]{[输入文件设置]  -i  输入文件}…{[输出文件设置] 输出文件}服务器

2 描述说明

ffmpeg 是一个很是快速的视频音频转换器,还能够抓取实时的音频/视频流。它能够在任意的采样率之间转换调整视频,也能够用高质量的多相滤波器动态的调整视频的大小。网络

ffmpeg能够从任意数量的输入“文件”(它能够是常规文件,管道,网络数据流,抓取设备等)中读取,由-i 选项指定,能够写入任意数量的输出文件,这些文件由普通的输出文件名字指定。任何在命令行里不能被解释为一个选项的都会被认为是一个输出文件名称。ide

原则上,每一个输入或者输出文件都包含任意数量不一样类型(视频/音频/字幕/附件/数据)数据的流。这些输入/输出的流的数量和类型被容器格式限制。输入流和输出流识别映射会自动完成或者用-map选项给定。工具

   在选项中引入输入文件,你必须用这样的索引(基于0),这个第一个输入的文件是0,第二个输入文件是1等等。文件中的流是由它们的索引引用的。例2 3指的是第三个输入文件中的第4个流。oop

   作为通常的原则,选项会被用到下一个指定的文件。所以,顺序很重要,你能够屡次在命令行上拥有相同的选项。而后每个事件应用到下一个输入或输出文件中。这个规则例外的是全局选项(例如 verbosity 级别),应该被首先指定。性能

  不要混淆输入和输出文件。首先指定全部输入文件,而后是全部的输出文件。也不要混淆属于不一样文件的选项。全部的选项应用仅仅在它后面的输入输出文件并且在文件之间能够从新设置。测试

l   将输出文件的视频比特率设置成64kbit/s:编码

ffmpeg -i input.avi -b :v 64k –bufsize 64k output.avispa

l   强制将输出文件的帧率设置成24fps:

ffmpeg -i input.avi –r 24 output.avi

l   强制将输入文件(仅仅对原始格式有效)的帧率设置成1fps,输出文件帧率设置成24fps:

ffmpeg -r 1 –I input.m2v -r 24 output.avi

 

  对于原始的输入文件可能须要格式设置选项。

 

3 详细描述

Ffmpeg 的每一个输出的转换过程均可以经过下图来描述:

 

_______              ______________

|       |            |              |

| input |  demuxer   | encoded data |   decoder

| file  | ---------> | packets      | -----+

|_______|            |______________|      |

                                           v

                                       _________

                                      |         |

                                      | decoded |

                                      | frames  |

                                      |_________|

 ________             ______________       |

|        |           |              |      |

| output | <-------- | encoded data | <----+

| file   |   muxer   | packets      |   encoder

|________|           |______________|

 

ffmpeg 经过libavformat库(包含demuxers)来读取输入文件而后获取包含数据编码的数据包。当有多个输入文件时,ffmpeg会经过跟踪全部输入流经过跟踪最低的时间戳来实现同步。

 

 编码后的包被传递给解码器(除非是数据流拷贝)。解码器产生未压缩的数据帧(原始视频/pcm音频/…)。而后能够经过过滤器进一步处理。滤波后,帧被传递给编码器,编码器输出编码包。最终触底给muxer,而后将编码包写入到输出文件中。

3.1 滤波

在编码前,ffmpeg会经过libavfilter库处理原始的音频和视频帧。几个滤波器经过链接造成滤波器图。ffmpeg能够区分简单和复杂的滤波器图。

3.1.1 简单滤波器

 

简单的过滤器是只有一路相同类型的输入和输出。在上面的图表中,能够通关过插入一个简单的额外的步骤来讲明编码和解码:

 _________                        ______________
|         |                      |              |
| decoded |                      | encoded data |
| frames  |\                   _ | packets      |
|_________| \                  /||______________|
             \   __________   /
  simple     _\||          | /  encoder
  filtergraph   | filtered |/
                | frames   |
                |__________|
 
简单滤波器试着每一个数据流的滤波选项(视频和音频分别用-vf和-af的别名)。一个简单的视频滤波过程能够看下面的例子:
 _______        _____________        _______        ________
|       |      |             |      |       |      |        |
| input | ---> | deinterlace | ---> | scale | ---> | output |
|_______|      |_____________|      |_______|      |________|
 
须要注意的是一些滤波器改变帧的属性可是不会改变帧的内容。例如在上面的例子中fps滤波器只改变了帧数可是没有改变帧的内容。另外的例子setpts滤波器只是设置了时间戳并无改变经过的帧内容。

3.1.2 复杂滤波器

复杂的滤波器不能描述成简单的线性处理链应用在一个数据流上。状况是这样的,例如,下面这个图有多个输入或者输出,或者当输入流和输出流的类型不一样。能够下图来表示。

_________
|         |
| input 0 |\                    __________
|_________| \                  |          |
             \   _________    /| output 0 |
              \ |         |  / |__________|
_________     \| complex | /
|         |     |         |/
| input 1 |---->| filter  |\
|_________|     |         | \   __________
               /| graph   |  \ |          |
              / |         |   \| output 1 |
_________   /  |_________|    |__________|
|         | /
| input 2 |/
|_________|
 
复杂的滤波器经过 –filter 设置复杂选项注意那是全局的选项。所以复杂的滤波器对流的性质不能简单的与单个的流或者文件相关。
-lavfi 选项等价于 –filter_complex
一个复杂的过滤图的一个简单例子是叠加过滤器,它有两个视频输入和一个视频输出,包含一个重叠在另外一个视频上的视频。它的音频对应的是amix滤波器。

3.2 数据流拷贝

流复制是经过向-codec选项提供复制参数而选择的模式。它使ffmpeg省略了指定流的解码和编码步骤,所以它只进行了删除和muxing。它对于更改容器格式或修改容器级别的元数据很是有用。上面的图表,在这个例子中,简化为:
_______              ______________            ________
|       |            |              |          |        |
| input |  demuxer   | encoded data |  muxer   | output |
| file  | ---------> | packets      | -------> | file   |
|_______|            |______________|          |________|
 
因为没有解码或编码,因此速度很是快,没有质量损失。然而,在某些状况下,它可能不会起做用,由于有许多因素。显然,应用过滤器也是不可能的,由于过滤器能够处理未压缩的数据。

4 数据流选择

 

默认状况下,ffmpeg只包含输入文件中的每一个类型(视频、音频、字幕)的一个流,并将它们添加到每一个输出文件中。它根据如下标准选择“最佳”:对于视频来讲,它是具备最高分辨率的流,对于音频来讲,它是拥有最多频道的流,对于字幕来讲,它是第一个字幕流。在相同类型的几个流相同的状况下,选择了最低索引的流。
 
您可使用-vn/-an/-sn选项来禁用某些默认值。对于完整的手动控制,使用-map选项,它禁用刚刚描述的默认值。
 

5 FFMPEG 经常使用命令详解:

FFmpeg是一个开源免费跨平台的视频和音频流方案,属于自由软件,采用LGPL或GPL许可证(依据你选择的组件)。它提供了录制、转换以及流化音视频的完整解决方案。它包含了很是先进的音频/视频编解码库libavcodec,为了保证高可移植性和编解码质量,libavcodec里不少codec都是从头开发的。

      FFmpeg在Linux平台下开发,但它一样也能够在其它操做系统环境中编译运行,包括Windows、Mac OS X等。

      FFmpeg项目由如下几部分组成:
      FFMpeg 视频文件转换命令行工具,也支持通过实时电视卡抓取和编码成视频文件。
      FFServer 基于HTTP(RTSP正在开发中)用于实时广播的多媒体服务器,也支持时间平移.
      FFplay 用SDL和FFmpeg库开发的一个简单的媒体播放器.
      libavcodec  一个包含了全部FFmpeg音视频编解码器的库.为了保证最优性能和高可复用性,大多数编解码器从头开发的.
      libavformat  一个包含了全部的普通音视格式的解析器和产生器的库.

 

例子:ffmpeg -y -i "1.avi" -title "Test" -vcodec xvid -s 368x208 -r 29.97 -b 1500 -acodec aac -ac 2 -ar 24000 -ab 128 -vol 200 -f psp -muxvb 768 "output.wmv"

解释:以上命令能够在Dos命令行中输入,也能够建立到批处理文件中运行。不过,前提是:要在ffmpeg所在的目录中执行(转换君所在目录下面的cores子目录)。

 

输入输出文件一般就是待处理的多媒体文件了。能够是纯粹的音频文件,纯粹的视频文件,或者混合的。大部分常见的格式都可以“通杀”。象常见的各类mpeg,AVI封装的DIVX和Xvid等等,具体的格式支持列表可使用ffmpeg -formats查看或直接查阅文档。
另:因为Linux把设备视为文件,所以-i选项后能够跟设备名。好比DV,视频卡,光驱或者其它的各种设备。


参数:

-y 覆盖输出文件,即若是 output.wmv 文件已经存在的话,不经提示就覆盖掉 
-i "1.avi" 输入文件是和ffmpeg在同一目录下的1.avi文件,能够本身加路径,更名字 
-title "Test" 在PSP中显示的影片的标题 
-vcodec xvid 使用XVID编码压缩视频,不能改的,对应的库为libxvid
-s 368x208 输出的分辨率为368x208,注意片源必定要是16:9的否则会变形 
-r 29.97 帧数,通常就用这个吧 
-b 1500 视频数据流量,用-b xxxx的指令则使用固定码率,数字随便改,1500以上没效果;还能够用动态码率如:-qscale 4和-qscale 6,4的质量比6高 
-acodec aac 音频编码用AAC 对应的库为libfaac
-ac 2  声道数1或2 
-ar 24000 声音的采样频率,好像PSP只能支持24000Hz 
-ab 128 音频数据流量,通常选择3二、6四、9六、128 
-vol 200 200%的音量,本身改 
-muxvb 768 好像是给PSP机器识别的码率,通常选择38四、512和768,我改为1500,PSP就说文件损坏了 
-f psp 输出psp专用格式 
"output.wmv" 输出文件名,也能够加路径改文件名


示例1:
截取一张352x240尺寸大小的,格式为jpg的图片: 
ffmpeg -i test.asf -y -f image2 -t 0.001 -s 352x240 a.jpg

示例2:
把视频的前30帧转换成一个Animated Gif : 
ffmpeg -i test.asf -vframes 30 -y -f gif a.gif

示例3:
在视频的第8.01秒处截取 352*240 的缩略图
ffmpeg -i test2.asf -y -f image2 -ss 08.010 -t 0.001 -s 352x240 b.jpg

 

 

 

a) 通用选项

-L license

-h 帮助

-fromats 显示可用的格式,编解码的,协议的。。。

-f fmt 强迫采用格式fmt

-i filename 输入文件

-y 覆盖输出文件

-t duration 设置纪录时间 hh:mm:ss[.xxx]格式的记录时间也支持

-ss position 搜索到指定的时间 [-]hh:mm:ss[.xxx]的格式也支持

-title string 设置标题

-author string 设置做者

-copyright string 设置版权

-comment string 设置评论

-target type 设置目标文件类型(vcd,svcd,dvd) 全部的格式选项(比特率,编解码以及缓冲区大小)自动设置 ,只须要输入以下的就能够了:
ffmpeg -i myfile.avi -target vcd /tmp/vcd.mpg

-hq 激活高质量设置

-itsoffset offset 设置以秒为基准的时间偏移,该选项影响全部后面的输入文件。该偏移被加到输入文件的时戳,定义一个正偏移意味着相应的流被延迟了 offset秒。 [-]hh:mm:ss[.xxx]的格式也支持

b) 视频选项

-b bitrate 设置比特率,缺省200kb/s

-r fps 设置帧频 缺省25

-s size 设置帧大小 格式为WXH 缺省160X128.下面的简写也能够直接使用:
Sqcif 128X96 qcif 176X144 cif 252X288 4cif 704X576

-aspect aspect 设置横纵比 4:3 16:9 或 1.3333 1.7777

-croptop size 设置顶部切除带大小 像素单位

-cropbottom size –cropleft size –cropright size

-padtop size 设置顶部补齐的大小 像素单位

-padbottom size –padleft size –padright size –padcolor color 设置补齐条颜色(hex,6个16进制的数,红:绿:兰排列,好比 000000表明黑色)

-vn 不作视频记录

-bt tolerance 设置视频码率容忍度kbit/s

-maxrate bitrate设置最大视频码率容忍度

-minrate bitreate 设置最小视频码率容忍度

-bufsize size 设置码率控制缓冲区大小

-vcodec codec 强制使用codec编解码方式。 若是用copy表示原始编解码数据必须被拷贝。

-sameq 使用一样视频质量做为源(VBR)

-pass n 选择处理遍数(1或者2)。两遍编码很是有用。第一遍生成统计信息,第二遍生成精确的请求的码率

-passlogfile file 选择两遍的纪录文件名为file


c)高级视频选项

-g gop_size 设置图像组大小

-intra 仅适用帧内编码

-qscale q 使用固定的视频量化标度(VBR)

-qmin q 最小视频量化标度(VBR)

-qmax q 最大视频量化标度(VBR)

-qdiff q 量化标度间最大误差 (VBR)

-qblur blur 视频量化标度柔化(VBR)

-qcomp compression 视频量化标度压缩(VBR)

-rc_init_cplx complexity 一遍编码的初始复杂度

-b_qfactor factor 在p和b帧间的qp因子

-i_qfactor factor 在p和i帧间的qp因子

-b_qoffset offset 在p和b帧间的qp误差

-i_qoffset offset 在p和i帧间的qp误差

-rc_eq equation 设置码率控制方程 默认tex^qComp

-rc_override override 特定间隔下的速率控制重载

-me method 设置运动估计的方法 可用方法有 zero phods log x1 epzs(缺省) full

-dct_algo algo 设置dct的算法 可用的有 0 FF_DCT_AUTO 缺省的DCT 1 FF_DCT_FASTINT 2 FF_DCT_INT 3 FF_DCT_MMX 4 FF_DCT_MLIB 5 FF_DCT_ALTIVEC

-idct_algo algo 设置idct算法。可用的有 0 FF_IDCT_AUTO 缺省的IDCT 1 FF_IDCT_INT 2 FF_IDCT_SIMPLE 3 FF_IDCT_SIMPLEMMX 4 FF_IDCT_LIBMPEG2MMX 5 FF_IDCT_PS2 6 FF_IDCT_MLIB 7 FF_IDCT_ARM 8 FF_IDCT_ALTIVEC 9 FF_IDCT_SH4 10 FF_IDCT_SIMPLEARM

-er n 设置错误残留为n 1 FF_ER_CAREFULL 缺省 2 FF_ER_COMPLIANT 3 FF_ER_AGGRESSIVE 4 FF_ER_VERY_AGGRESSIVE

-ec bit_mask 设置错误掩蔽为bit_mask,该值为以下值的位掩码 1 FF_EC_GUESS_MVS (default=enabled) 2 FF_EC_DEBLOCK (default=enabled)

-bf frames 使用frames B 帧,支持mpeg1,mpeg2,mpeg4

-mbd mode 宏块决策 0 FF_MB_DECISION_SIMPLE 使用mb_cmp 1 FF_MB_DECISION_BITS 2 FF_MB_DECISION_RD

-4mv 使用4个运动矢量 仅用于mpeg4

-part 使用数据划分 仅用于mpeg4

-bug param 绕过没有被自动监测到编码器的问题

-strict strictness 跟标准的严格性

-aic 使能高级帧内编码 h263+

-umv 使能无限运动矢量 h263+

-deinterlace 不采用交织方法

-interlace 强迫交织法编码 仅对mpeg2和mpeg4有效。当你的输入是交织的而且你想要保持交织以最小图像损失的时候采用该选项。可选的方法是不交织,可是损失更大

-psnr 计算压缩帧的psnr

-vstats 输出视频编码统计到vstats_hhmmss.log

-vhook module 插入视频处理模块 module 包括了模块名和参数,用空格分开

d)音频选项

-ab bitrate 设置音频码率

-ar freq 设置音频采样率

-ac channels 设置通道 缺省为1

-an 不使能音频纪录

-acodec codec 使用codec编解码

e)音频/视频捕获选项

-vd device 设置视频捕获设备。好比/dev/video0

-vc channel 设置视频捕获通道 DV1394专用

-tvstd standard 设置电视标准 NTSC PAL(SECAM)

-dv1394 设置DV1394捕获

-av device 设置音频设备 好比/dev/dsp


f)高级选项

-map file:stream 设置输入流映射

-debug 打印特定调试信息

-benchmark 为基准测试加入时间

-hex 倾倒每个输入包

-bitexact 仅使用位精确算法 用于编解码测试

-ps size 设置包大小,以bits为单位

-re 以本地帧频读数据,主要用于模拟捕获设备

-loop 循环输入流。只工做于图像流,用于ffserver测试

相关文章
相关标签/搜索