bat
start
G:\Java\ffmpeg\ffmpeg.exe -i %1 -ss 20 -vframes 1 -r 1 -ac 1 -ab 2 -s 320*240 -f image2 %2
exit
收藏
http://www.iteye.com/topic/333994
1. Ffmpeg使用语法
ffmpeg [[options][`-i’ input_file]]... {[options] output_file}...
如果没有输入文件,那么视音频捕捉就会起作用。
作为通用的规则,选项一般用于下一个特定的文件。如果你给 ?b 64选项,改选会设置下一个视频速率。对于原始输入文件,格式选项可能是需要的。
缺省情况下,ffmpeg试图尽可能的无损转换,采用和输入同样的音频视频参数来输出。
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"
解释:以上命令可以在Dos命令行中输入,也可以创建到批处理文件中运行。不过,前提是:要在ffmpeg所在的目录中执行(转换君所在目录下面的 cores子目录)。
参数:
-y 覆盖输出文件,即如果 output.wmv 文件已经存在的话,不经提示就覆盖掉
-i "1.avi" 输入文件是和ffmpeg在同一目录下的1.avi文件,可以自己加路径,改名字
-title "Test" 在PSP中显示的影片的标题
-vcodec xvid 使用XVID编码压缩视频,不能改的
-s 368x208 输出的分辨率为368x208,注意片源一定要是16:9的不然会变形
-r 29.97 帧数,一般就用这个吧
-b 1500 视频数据流量,用-b xxxx的指令则使用固定码率,数字随便改,1500以上没效果;还可以用动态码率如:-qscale 4和-qscale 6,4的质量比6高
-acodec aac 音频编码用AAC
-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测试
- 大小: 17 KB
分享到:
相关推荐
博文 http://blog.csdn.net/i_scream_/article/details/52716849 中的代码和相关资料。测试环境为ubuntu16.04.
这个"FFMPEG android实例"很可能是将FFmpeg库与Android应用相结合的一个具体项目,旨在展示如何在Android设备上操作FFmpeg进行多媒体操作。 FFmpeg 包含的主要组件有: 1. **ffmpeg**:这是一个命令行工具,可以...
本实例将重点讲解如何利用FFmpeg库从摄像头URL地址采集视频并进行播放。 首先,你需要在你的项目中引入FFmpeg的头文件和库。确保已经正确安装了FFmpeg,并将其路径添加到编译器的搜索路径中。通常,这涉及到`#...
2. **创建FFmpeg实例**:在Java代码中,首先需要创建一个`org.bytedeco.javacpp.Loader`的实例,然后加载`ffmpeg`的库。这样可以确保FFmpeg的动态链接库被正确加载。 ```java import org.bytedeco.javacpp.Loader; ...
你可以通过PHP的`new \FFMpeg\FFMpeg()`来创建一个FFmpeg实例,然后利用其提供的API进行多媒体操作,例如: ```php use FFMpeg\FFMpeg; use FFMpeg\Coordinate\TimeCode; use FFMpeg\Format\Video\X264; $ffmpeg =...
安装完成后,你可以通过以下方式创建一个 PHP-FFMpeg 实例并开始处理视频: ```php use FFMpeg\FFMpeg; use FFMpeg\FFProbe; $ffmpeg = FFMpeg::create(); $ffprobe = FFProbe::create(); $video = $ffmpeg->open...
3. **依赖库冲突**:系统可能存在其他FFmpeg实例或者其依赖库版本冲突,影响WebRTC的编译。 4. **源代码问题**:FFmpeg或WebRTC的源代码可能存在bug,导致编译时出错。 在这种情况下,"编译WebRTC时替换的ffmpeg....
2. **初始化**:在PHP代码中,创建FFMpeg实例,指定要处理的视频文件路径。 3. **定义操作**:使用提供的方法,如`FFMpeg\Video::resize()`、`FFMpeg\Video::setKiloBitrate()`等来设置处理参数。 4. **输出配置**:...
这段代码首先创建一个FFMpeg实例,打开输入的MP4文件,然后定义WebM格式,设置转换回调并在执行前输出提示信息,最后保存转换后的文件。 5. **限制与注意事项** 由于这是一个旧版的扩展,可能不支持最新的FFmpeg...
它可能包含初始化FFmpeg实例、设置输入流、配置输出格式以及处理解码后的数据等功能。 4. **性能优化**:由于WebAssembly运行在JavaScript引擎上,可能会受到性能限制,特别是在处理高分辨率和高帧率视频时。因此,...
在Java开发中,通过调用FFmpeg的命令行工具,可以方便地集成到应用程序中进行视频处理,例如本实例中的视频压缩。在百度AI和腾讯AI的活体验证场景中,高质量、低大小的视频文件是必要的,因此使用FFmpeg进行视频压缩...
- 初始化FFMpeg实例,设置输入源(如本地视频文件或摄像头捕获)。 - 创建推流配置,包括目标服务器地址、端口、流媒体协议和流ID。 - 调用FFMpeg API开始推流。 - 监控推流状态,处理错误和异常。 - 完成推流...
在本实例中,我们将探讨如何在Visual Studio 2008环境下,利用FFmpeg SDK 3.2进行音频解码。 首先,安装FFmpeg SDK 3.2是开发的基础。你需要下载并解压FFmpeg源代码,然后通过configure脚本配置编译环境,生成适用...
本实例将详细介绍如何在Windows上使用Msys2环境来编译FFmpeg 4.3.1版本,并构建适用于win32和x64架构的库文件及示例程序。 首先,Msys2是一个轻量级的Unix-like环境,为Windows提供了GCC编译器和各种Unix工具。要...
在这个"FFmpeg音频编码实例"中,我们将重点探讨如何利用FFmpeg库在Visual Studio 2008环境下进行音频编码。FFmpeg 3.2是该项目的一个稳定版本,提供了丰富的API和功能,使得开发者能够方便地处理各种音频格式。 ...
在"FFmpeg的delphi实例"中,我们看到的文件列表包括`testUnit1.dfm`、`testProject.dpr`、`testProject.dproj`和`testUnit1.pas`。这些文件是Delphi工程的基本组成部分: 1. `testUnit1.dfm`:这是Delphi中的一个...
以下是对"ffmpeg编译使用实例"的具体解析: 1. **FFmpeg编译流程**: - 获取源码:首先,你需要从FFmpeg的官方网站或GitHub仓库下载源代码。 - 配置选项:根据需求配置编译选项,例如添加解码器、编码器、过滤器...
总之,FFmpeg 编译环境的建立是一项技术性的工作,但通过这个过程,你可以获得一个完全定制且适应你特定需求的 FFmpeg 实例。这对于开发自定义的多媒体应用、进行性能优化或支持特殊格式的音视频处理来说是非常有...
在这个例子中,我们通过`FFMpeg::create()` 创建FFmpeg实例,然后打开视频文件,`frame()` 方法用于获取指定时间的帧,最后保存为图片文件。 注意,生成缩略图时选择的时间点应根据实际需求调整,例如视频开头、...
使用C++封装FFmpeg,编写的播放音视频的实例,在MFC控件显示播放,可以播放本地文件,也可以播放网络流, 主要描述了ffmpeg音视频解码的详细步骤,SDL和MFC控件关联显示,音视频同步的控制,本实例使用VS2012开发。