Ffmpeg使用语法以及参数说明
1.Ffmpeg使用语法
ffmpeg[[options][`-i’input_file]]...{[options]output_file}...
如果没有输入文件,那么视音频捕捉就会起作用。
作为通用的规则,选项一般用于下一个特定的文件。如果你给?b64选项,改选会设置下一个视频速率。对于原始输入文件,格式选项可能是需要的。
缺省情况下,ffmpeg试图尽可能的无损转换,采用和输入同样的音频视频参数来输出。
2.例子:ffmpeg-y-i"1.avi"-title"Test"-vcodecxvid-s368x208-r29.97-b1500-acodecaac-ac2-ar24000-ab128-vol200-fpsp-muxvb768"output.wmv"
解释:以上命令可以在Dos命令行中输入,也可以创建到批处理文件中运行。不过,前提是:要在ffmpeg所在的目录中执行(转换君所在目录下面的cores子目录)。
参数:
-y覆盖输出文件,即如果output.wmv文件已经存在的话,不经提示就覆盖掉
-i"1.avi"输入文件是和ffmpeg在同一目录下的1.avi文件,可以自己加路径,改名字
-title"Test"在PSP中显示的影片的标题
-vcodecxvid使用XVID编码压缩视频,不能改的
-s368x208输出的分辨率为368x208,注意片源一定要是16:9的不然会变形
-r29.97帧数,一般就用这个吧
-b1500视频数据流量,用-bxxxx的指令则使用固定码率,数字随便改,1500以上没效果;还可以用动态码率如:-qscale4和-qscale6,4的质量比6高
-acodecaac音频编码用AAC
-ac2声道数1或2
-ar24000声音的采样频率,好像PSP只能支持24000Hz
-ab128音频数据流量,一般选择32、64、96、128
-vol200200%的音量,自己改
-muxvb768好像是给PSP机器识别的码率,一般选择384、512和768,我改成1500,PSP就说文件损坏了
-fpsp输出psp专用格式
"output.wmv"输出文件名,也可以加路径改文件名
示例1:
截取一张352x240尺寸大小的,格式为jpg的图片:
ffmpeg-itest.asf-y-fimage2-t0.001-s352x240a.jpg
示例2:
把视频的前30帧转换成一个AnimatedGif:
ffmpeg-itest.asf-vframes30-y-fgifa.gif
示例3:
在视频的第8.01秒处截取352*240的缩略图
ffmpeg-itest2.asf-y-fimage2-ss08.010-t0.001-s352x240b.jpg
**************************************************************************************
a)通用选项
-Llicense
-h帮助
-fromats显示可用的格式,编解码的,协议的。。。
-ffmt强迫采用格式fmt
-Ifilename输入文件
-y覆盖输出文件
-tduration设置纪录时间hh:mm:ss[.xxx]格式的记录时间也支持
-ssposition搜索到指定的时间[-]hh:mm:ss[.xxx]的格式也支持
-titlestring设置标题
-authorstring设置作者
-copyrightstring设置版权
-commentstring设置评论
-targettype设置目标文件类型(vcd,svcd,dvd)所有的格式选项(比特率,编解码以及缓冲区大小)自动设置,只需要输入如下的就可以了:
ffmpeg-imyfile.avi-targetvcd/tmp/vcd.mpg
-hq激活高质量设置
-itsoffsetoffset设置以秒为基准的时间偏移,该选项影响所有后面的输入文件。该偏移被加到输入文件的时戳,定义一个正偏移意味着相应的流被延迟了offset秒。[-]hh:mm:ss[.xxx]的格式也支持
b)视频选项
-bbitrate设置比特率,缺省200kb/s
-rfps设置帧频缺省25
-ssize设置帧大小格式为WXH缺省160X128.下面的简写也可以直接使用:
Sqcif128X96qcif176X144cif252X2884cif704X576
-aspectaspect设置横纵比4:316:9或1.33331.7777
-croptopsize设置顶部切除带大小像素单位
-cropbottomsize–cropleftsize–croprightsize
-padtopsize设置顶部补齐的大小像素单位
-padbottomsize–padleftsize–padrightsize–padcolorcolor设置补齐条颜色(hex,6个16进制的数,红:绿:兰排列,比如000000代表黑色)
-vn不做视频记录
-bttolerance设置视频码率容忍度kbit/s
-maxratebitrate设置最大视频码率容忍度
-minratebitreate设置最小视频码率容忍度
-bufsizesize设置码率控制缓冲区大小
-vcodeccodec强制使用codec编解码方式。如果用copy表示原始编解码数据必须被拷贝。
-sameq使用同样视频质量作为源(VBR)
-passn选择处理遍数(1或者2)。两遍编码非常有用。第一遍生成统计信息,第二遍生成精确的请求的码率
-passlogfilefile选择两遍的纪录文件名为file
c)高级视频选项
-ggop_size设置图像组大小
-intra仅适用帧内编码
-qscaleq使用固定的视频量化标度(VBR)
-qminq最小视频量化标度(VBR)
-qmaxq最大视频量化标度(VBR)
-qdiffq量化标度间最大偏差(VBR)
-qblurblur视频量化标度柔化(VBR)
-qcompcompression视频量化标度压缩(VBR)
-rc_init_cplxcomplexity一遍编码的初始复杂度
-b_qfactorfactor在p和b帧间的qp因子
-i_qfactorfactor在p和i帧间的qp因子
-b_qoffsetoffset在p和b帧间的qp偏差
-i_qoffsetoffset在p和i帧间的qp偏差
-rc_eqequation设置码率控制方程默认tex^qComp
-rc_overrideoverride特定间隔下的速率控制重载
-memethod设置运动估计的方法可用方法有zerophodslogx1epzs(缺省)full
-dct_algoalgo设置dct的算法可用的有0FF_DCT_AUTO缺省的DCT1FF_DCT_FASTINT2FF_DCT_INT3FF_DCT_MMX4FF_DCT_MLIB5FF_DCT_ALTIVEC
-idct_algoalgo设置idct算法。可用的有0FF_IDCT_AUTO缺省的IDCT1FF_IDCT_INT2FF_IDCT_SIMPLE3FF_IDCT_SIMPLEMMX4FF_IDCT_LIBMPEG2MMX5FF_IDCT_PS26FF_IDCT_MLIB7FF_IDCT_ARM8FF_IDCT_ALTIVEC9FF_IDCT_SH410FF_IDCT_SIMPLEARM
-ern设置错误残留为n1FF_ER_CAREFULL缺省2FF_ER_COMPLIANT3FF_ER_AGGRESSIVE4FF_ER_VERY_AGGRESSIVE
-ecbit_mask设置错误掩蔽为bit_mask,该值为如下值的位掩码1FF_EC_GUESS_MVS(default=enabled)2FF_EC_DEBLOCK(default=enabled)
-bfframes使用framesB帧,支持mpeg1,mpeg2,mpeg4
-mbdmode宏块决策0FF_MB_DECISION_SIMPLE使用mb_cmp1FF_MB_DECISION_BITS2FF_MB_DECISION_RD
-4mv使用4个运动矢量仅用于mpeg4
-part使用数据划分仅用于mpeg4
-bugparam绕过没有被自动监测到编码器的问题
-strictstrictness跟标准的严格性
-aic使能高级帧内编码h263+
-umv使能无限运动矢量h263+
-deinterlace不采用交织方法
-interlace强迫交织法编码仅对mpeg2和mpeg4有效。当你的输入是交织的并且你想要保持交织以最小图像损失的时候采用该选项。可选的方法是不交织,但是损失更大
-psnr计算压缩帧的psnr
-vstats输出视频编码统计到vstats_hhmmss.log
-vhookmodule插入视频处理模块module包括了模块名和参数,用空格分开
d)音频选项
-abbitrate设置音频码率
-arfreq设置音频采样率
-acchannels设置通道缺省为1
-an不使能音频纪录
-acodeccodec使用codec编解码
e)音频/视频捕获选项
-vddevice设置视频捕获设备。比如/dev/video0
-vcchannel设置视频捕获通道DV1394专用
-tvstdstandard设置电视标准NTSCPAL(SECAM)
-dv1394设置DV1394捕获
-avdevice设置音频设备比如/dev/dsp
f)高级选项
-mapfile:stream设置输入流映射
-debug打印特定调试信息
-benchmark为基准测试加入时间
-hex倾倒每一个输入包
-bitexact仅使用位精确算法用于编解码测试
-pssize设置包大小,以bits为单位
-re以本地帧频读数据,主要用于模拟捕获设备
-loop循环输入流。只工作于图像流,用于ffserver测试
www.nijieyan.info