ffmpeg 简单功能描述

 

1 概述

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

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

2 描述说明

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

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

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

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

   做为一般的原则,选项会被用到下一个指定的文件。因此,顺序很重要,你可以多次在命令行上拥有相同的选项。然后每一个事件应用到下一个输入或输出文件中。这个规则例外的是全局选项(例如 verbosity 级别),应该被首先指定。

  不要混淆输入和输出文件。首先指定所有输入文件,然后是所有的输出文件。也不要混淆属于不同文件的选项。所有的选项应用仅仅在它后面的输入输出文件而且在文件之间可以重新设置。

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

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

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 音频数据流量,一般选择32、64、96、128 
-vol 200 200%的音量,自己改 
-muxvb 768 好像是给PSP机器识别的码率,一般选择384、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测试

 

转载于:https://my.oschina.net/u/567830/blog/1558913

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值