• ffmpeg 安装和参数介绍


    0.说明:

      1)、configure,这一步一般用来生成 Makefile,为下一步的编译做准备,你可以通过在 configure 后加上参数来对安装进行控制,比如代码:./configure –prefix=/usr 意思是将该软件安装在 /usr 下面,执行文件就会安装在 /usr/bin (而不是默认的 /usr/local/bin),资源文件就会安装在 /usr/share(而不是默认的/usr/local/share)。同时一些软件的配置文件你可以通过指定 –sys-config= 参数进行设定。有一些软件还可以加上 –with、–enable、–without、–disable 等等参数对编译加以控制,你可以通过允许 ./configure –help 察看详细的说明帮助。

      2)、make,这一步就是编译,大多数的源代码包都经过这一步进行编译(当然有些perl或python编写的软件需要调用perl或python 来进行编译)。如果 在 make 过程中出现 error ,你就要记下错误代码(注意不仅仅是最后一行),然后你可以向开发者提交 bugreport(一般在 INSTALL 里有提交地址),或者你的系统少了一些依赖库等,这些需要自己仔细研究错误代码。

      3)、make insatll,这条命令来进行安装(当然有些软件需要先运行 make check 或 make test 来进行一些测试),这一步一般需要你有 root 权限(因为要向系统写入文件)。

    1. mac  os系统下编译安装

    官网:https://trac.ffmpeg.org/wiki/CompilationGuide/MacOSX

    廖雪峰: http://www.liaoxuefeng.com/article/0013738927837699a7f3407ea5f4b5caf8e1ab47997d7c5000

    http://blog.csdn.net/luka2008/article/details/21243499  (有问题,可以直接用brew安装编码器)

    重点:安装 xcode   ,安装homebrew(mac os 包管理工具),第三方编码器

    ----------------------------------------------------------------------------

    2.ffmpeg介绍:

    http://www.360doc.com/content/10/0428/15/474846_25293076.shtml

      ffmpeg是音视频的分离,转换,编码解码及流媒体的完全解决方案,其中最重要的就是libavcodec库。它被mplayer或者xine使用作为解码器。还有,国内比较流行的播放器影音风暴或MyMPC的后端ffdshow也是使用ffmpeg的解码库的。
      ffmpeg软件包经编译过后将生成三个可执行文件,ffmpeg,ffserver,ffplay。其中ffmpeg用于对媒体文件进行处理,ffserver是一个http的流媒体服务器,ffplay是一个基于SDL的简单播放器。

      ffmpeg 中有五个库文件,libavcodec,libavformat,libavutil,libswscale,libpostproc,其中库 libavcodec,libavformat用于对媒体文件进行处理,如格式的转换;libavutil是一个通用的小型函数库,该库中实现了CRC校 验码的产生,128位整数数学,最大公约数,整数开方,整数取对数,内存分配,大端小端格式的转换等功能;libswscale,libpostproc 暂时不知道何用。

    ----------------------------------------------------------------------------

    3.使用及参数介绍

    3.1 简单使用

    http://blog.csdn.net/hsg1040175759/article/details/18715249

    命令格式:ffmpeg -i [输入文件名] [参数选项] -f [格式] [输出文件]

    参数选项:

           (1) -an: 去掉音频

           (2) -acodec: 音频选项, 一般后面加copy表示拷贝

           (3) -vcodec:视频选项,一般后面加copy表示拷贝

    格式转换

         H264视频转ts视频流 :fmpeg -i test.h264 -vcodec copy -f mpegts test.ts   (mpegts: 表示ts视频流)

         H264视频转mp4:      ffmpeg -i test.h264 -vcodec copy -f mp4 test.mp4 

         ts视频转mp4:         ffmpeg -i test.ts -acodec copy -vcodec copy -f mp4 test.mp4 

    视频拼接:

         ffmpeg -i "concat:test1.h264|test2.h264" -vcodec copy -f h264 out12.h264 

     

    3.2 例子:

    例子: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"

    输入输出文件通常就是待处理的多媒体文件了。可以是纯粹的音频文件,纯粹的视频文件,或者混合的。大部分常见的格式都能够“通杀”。象常见的各种 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

    3.3 参数介绍

    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测试

  • 相关阅读:
    Jmeter之CSV文件读取
    性能计数器及性能分析方法
    性能测试的应用领域
    动态加载JS文件方法总结
    handler method 参数绑定常用注解
    A4纸网页打印
    page-break-before和page-break-after 实现分页打印
    $.ajax 中的contentType
    @Controller和@RestController的区别?
    web页面内容打印总结
  • 原文地址:https://www.cnblogs.com/zxqstrong/p/4555506.html
Copyright © 2020-2023  润新知