1、通用选项
-L license
-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]的格式也支持
2、视频选项
-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 代表黑色)
-bt tolerance 设置视频码率容忍度 kbit/s
-maxrate bitrate 设置最大视频码率容忍度-minrate bitreate 设置最小视频码率容忍度
-bufsize size 设置码率控制缓冲区大小
-vcodec codec 强制使用 codec 编解码方式。 如果用 copy 表示原始编解码数据必须被拷贝。-sameq 使用同样视频质量作为源(VBR)
-pass n 选择处理遍数(1 或者 2)。两遍编码非常有用。第一遍生成统计信息,第二遍生成精确的请求的码率。-passlogfile file 选择两遍的纪录文件名为 file
3、高级视频选项-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
-ec bit_mask 设置错误掩蔽为bit_mask , 该值为如下值的位掩码 1FF_EC_GUESS_MVS (default=enabled) 2 FF_EC_DEBLOCK (default=enabled)
-mbd mode 宏块决策 0 FF_MB_DECISION_SIMPLE 使用 mb_cmp 1 FF_MB_DECISION_BITS 2 FF_MB_DECISION_RD
-part 使用数据划分 仅用于 mpeg4
-bug param 绕过没有被自动监测到编码器的问题-strict strictness 跟标准的严格性
-aic 使能高级帧内编码 h263+-umv 使能无限运动矢量 h263+
-deinterlace 不采用交织方法 -interlace 强迫交织法编码 仅对 mpeg2 和 mpeg4 有效。当你的输入是交织的并且你想要保持交织以最小图像损失的时候采用该选项。可选的方法是不交织,但是损失更大
-psnr 计算压缩帧的 psnr
-vstats 输出视频编码统计到 vstats_hhmmss.log-vhook module 插入视频处理模块 module 包括了模块名和参数,用空格分开
4、音频选项-ab bitrate 设置音频码率
-ar freq 设置音频采样率-ac channels 设置通道 缺省为 1
-an 不使能音频纪录-acodec codec 使用 codec 编解码
5、音频/视频捕获选项-vd device 设置视频捕获设备。比如/dev/video0
-vc channel 设置视频捕获通道 DV1394 专用-tvstd standard 设置电视标准 NTSC PAL(SECAM)
-dv1394 设置 DV1394 捕获-av device 设置音频设备 比如/dev/dsp
6、高级选项-map file:stream 设置输入流映射
-debug 打印特定调试信息
-benchmark 为基准测试加入时间
-hex 倾倒每一个输入包
-bitexact 仅使用位精确算法 用于编解码测试
-ps size 设置包大小,以 bits 为单位
-re 以本地帧频读数据,主要用于模拟捕获设备
-loop 循环输入流。只工作于图像流,用于 ffserver 测试二、FFmpeg参数使用实例
1、格式转换
(1)简单的格式转换,将mp4文件转换成flv文件
其中,-vodec与-acodec都使用的是copy,即音频数据和视频数据采用copy的方式,不进行转码,只转换文件格式。当然也可以转换编码格式,即将copy换成相应的编码器,可以通过ffmpeg -codecs命令来查看ffmpeg支持哪些格式的编码。在转化的过程中还可以加一些参数,如-s,-r等。
(2)音频合成到视频中,且覆盖其原来的音频
方法一:
第一条命令通过使用-an参数,将音频取消掉,然后第二条命令中将test.mp3合成到test.mpg中。
方法二:
此时将会生成一个名为test2.mpg的视频,播放时其视频为test.avi的视频,音频为test.mp3。