FFmpeg解读-参数说明(一)

2020-06-03  本文已影响0人  GitArtOS

FFmpeg 参数说明

通用选项

   -L  license

   -h  帮助

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

   -f fmt   强迫采用格式 fmt

   -i filename  输入文件

   -y  覆盖输出文件

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

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

   -title string  设置标题

   -author string  设置作者

   -copyright string 设置版权

   -comment string 设置评论

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

-hq 激活高质量设置

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

视频选项

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

      -vb bitrate   set bitrate (in bits/s)

      -vframes number  设置要编码多少帧 

      -r fps 设置帧频 缺省25

      -s size 设置帧大小 格式为W*H 缺省160X128.也可以直接使用简写,也认:Sqcif<128*96>  qcif<176*144>  cif<252*288> 4cif<704*576> 等

      -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编解码方式,如-vcodec xvid 使用xvid压缩 如果用copy表示原始编解码数据必须被拷贝。

      -sameq 使用同样视频质量作为源(VBR)

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

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

高级视频选项

      -g gop_size 设置图像组大小 这里设置GOP大小,也表示两个I帧之间的间隔

      -intra 仅适用帧内编码

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

     -qmin q 最小视频量化标度(VBR) 设定最小质量,与-qmax(设定最大质量)共用

     -qmax q 最大视频量化标度(VBR) 使用了该参数,就可以不使用qscale参数

     -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的算法 可用:<br />                 0 FF_DCT_AUTO 缺省的DCT <br />                 1 FF_DCT_FASTINT<br />                 2 FF_DCT_INT<br />                 3 FF_DCT_MMX<br />                 4 FF_DCT_MLIB<br />                 5 FF_DCT_ALTIVEC

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

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

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

     -bf frames 使用frames个B 帧,支持mpeg1,mpeg2,mpeg4(即如果-bf 2的话,在两个非b帧中间隔的b帧数目为2,即IBBPBBPBBP结构)

     -mbd mode 宏块决策<br />            0 FF_MB_DECISION_SIMPLE 使用mb_cmp<br />            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 包括了模块名和参数,用空格分开

    -bitexact 使用标准比特率

    -max_qdiff  视频中所有桢(包括i/b/P)的最大Q值差距

    -b_qfactor 表示i/p与B的Q值比例因子,值越大B桢劣化越严重

   -b_qoffset 表示1/p与B的Q值比例的偏移量,值越大B桢劣化越严重.如果大于0,那么下一个B的Q=前一个P的Q乘以b_quant_factor再加上offset,如果小于0,则B的Q=负的normal_Q乘以factor加上offset.

   -i_qfactor   p和i的Q值比例因子,越接近1则P越优化.

   -i_qoffset   p和i的Q的偏移量

音频选项

   -ab bitrate 设置音频码率

   -ar freq 设置音频采样率

  -ac channels 设置通道 缺省为1,即单通道

  -an 不使能音频纪录

  -acodec codec 使用codec编解码 如:-acodec AAC 使用AAC音频编码

音视频捕获选项

     -vc device  设置视频捕获设备。比如/dev/video0

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

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

     -dv1394 设置DV1394捕获

     -av device 设置音频设置  比如/dev/dsp

高级选项

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

   -debug 打印特定调试信息

   -benchmark 为基准测试加入时间

    -hex 倾倒每一个输入板

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

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

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

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

FFmpeg 参数实例

ffmpeg -y -i /root/VideoConverter/123.avi -ab 56 -ar 22050 -b 1500 -r 15 -qscale 10 -s 480*350 /root/VideoConverter/234.flv

       -y  (覆盖输出文件,即如果1.****文件已经存在的话,不经提示就覆盖掉了)

        -i  "1.avi"(输入文件是和ffmpeg在同一目录下的1.avi文件,可以自己加路径,改名字)

       -s (输出的分辨率,注意片源一定要是16:9的不然会变形)

       -r  (帧数,一般就用这个吧)

      -b  1500 (视频数据流量,用-b xxxx的指令则使用固定码率,数字随便该,1500以上没效果;还可以用动态码率如:-qscale 4 和 -qscale 6, 4的质量比6高)

        -acodec aac (音频编码用AAC)

        -ac 2(声道数1或2)

        -ar 2400 (声音的采样频率,好像psp只能支持24000Hz)

        -ab 128 (音频数据流量,一般选择32、64、96、128)

        -vol  200 (200%的音量,自己改)

        -f psp (输出psp专用格式)

       -muxvb  768 (给PSP机器识别的码率,一般选择384,512和768)

       -ab bitrate  设置音频码率

       -ar  freq  设置音频采样率

       -ss 指定时间点开始转换任务,(time_off set the start time offset),-ss后跟的时间单位为秒

       -s  320*240  指定分辨率

       -r 29.97 帧速率

       -bitexact  使用标准比特率

       -vcode xvid 使用xvid压缩

上一篇下一篇

猜你喜欢

热点阅读