使用FFMPEG命令时出现Android错误 - 打开输出流编码器时出错 - 可能是错误的参数,如bit_rate等

时间:2015-03-05 14:49:00

标签: java android command-line ffmpeg libx264

我在linux上用libx264编译了ffmpeg,现在当我运行这个命令时

String[] ffmpegCommandImages = {
                    "/data/data/uk.org.humanfocus.hfi/ffmpeg",
                    "-i", videoPath,
                    "-b:v", "1000k",
                    "-vf", "scale=-1:576",
                    "-c:a", "copy",
                     "-c:v", "libx264", 
                    "-threads", "12",
                    "-b:a", "196k",
                    to };

这是我得到的错误,发布日志...
请帮帮我。

***Starting FFMPEG***
***ffmpeg version 2.5.4 Copyright (c) 2000-2015 the FFmpeg developers***   ***  built on Mar  5 2015 19:02:01 with gcc 4.8 (GCC)***   V/asd(26115): ***  configuration:
--prefix=/home/hfi/Downloads/android-ndk-r10d/sources/ffmpeg-2.5.4/android/arm --enable-shared --disable-static --disable-doc --enable-ffmpeg --disable-ffplay --disable-ffprobe --disable-ffserver --disable-avdevice --disable-doc --disable-symver --cross-prefix=/home/hfi/Downloads/android-ndk-r10d/toolchains/arm-linux-androideabi-4.8/prebuilt/linux-x86_64/bin/arm-linux-androideabi-
--target-os=linux --arch=arm --enable-cross-compile --enable-libx264 --enable-gpl --sysroot=/home/hfi/Downloads/android-ndk-r10d/platforms/android-9/arch-arm
--extra-cflags='-Os -fpic -I /usr/local/include -marm' --extra-ldflags=' -L /usr/local/lib '***
***  libavutil      54. 15.100 / 54. 15.100***
***  libavcodec     56. 13.100 / 56. 13.100***
***  libavformat    56. 15.102 / 56. 15.102***
***  libavfilter     5.  2.103 /  5.  2.103***
***  libswscale      3.  1.101 /  3.  1.101***
***  libswresample   1.  1.100 /  1.  1.100***
***  libpostproc    53.  3.100 / 53.  3.100*** E/Runnable(26115): CAlled V/asd(26115): ***Input #0, image2, from '/storage/emulated/0/HumanFocus/MarkerFrame/frame%05d.jpg':*** V/asd(26115): ***  Duration: 00:00:01.76, start: 0.000000, bitrate: N/A*** V/asd(26115): ***    Stream #0:0: Video: mjpeg, yuvj420p(pc, bt470bg/unknown/unknown), 1279x719 [SAR 1:1 DAR 1279:719], 25 fps, 25 tbr, 25 tbn, 25 tbc*** V/asd(26115): ***Please use -q:a or -q:v,
-qscale is ambiguous*** V/asd(26115): ***No pixel format specified, yuvj420p for H.264 encoding chosen.*** V/asd(26115): ***Use -pix_fmt yuv420p for compatibility with outdated media players.*** V/asd(26115): ***[libx264 @ 0x52e80] width not divisible by 2 (1279x719)*** V/asd(26115): ***Output #0, mp4, to '/storage/emulated/0/HumanFocus/WPOvideos/TEMP/20150305144005.mp4':*** V/asd(26115): ***    Stream #0:0: Video: h264, none, q=2-31, 128 kb/s, SAR 1:1 DAR 0:0, 11 fps*** V/asd(26115): ***    Metadata:*** V/asd(26115): ***      encoder         : Lavc56.13.100 libx264*** V/asd(26115): ***Stream mapping:*** V/asd(26115): ***  Stream #0:0 ->
#0:0 (mjpeg (native) -> h264 (libx264))*** V/asd(26115): ***Error while opening encoder for output stream #0:0 - maybe incorrect parameters such as bit_rate, rate, width or height*** V/asdas(26115):
***Ending FFMPEG***

1 个答案:

答案 0 :(得分:6)

解决方案

改变这个:

scale=-1:576

对此:

scale=-2:576

为什么

这是控制台输出中的相关消息:

[libx264 @ 0x52e80] width not divisible by 2 (1279x719)

使用libx264进行编码时,输出使用YUV 4:2:0色度子采样,宽度和高度必须可被2整除。

对于scale filter

    宽度或高度的
  • -1将自动计算相对于其他维度的值,该值将保留纵横比。

  • -2将与-1执行相同操作,但此外还会确保输出可被2整除。

附加说明

  • 通常不建议使用-b:v一次通过。使用-b:v使用两次传递,或者只使用-crf执行一次传递。通常仅在您定位特定输出文件大小时才使用-b:v两次传递;否则使用-crf的单次传递。请参阅FFmpeg Wiki: H.264 Encoding Guide

  • 您应该明确添加-pix_fmt yuv420p作为输出选项,以确保非基于FFmpeg的播放器的兼容性。现在,您依赖于ffmpeg版本之间不一致的默认行为,并且可能无法生成蹩脚玩家可以播放的输出。

  • 考虑删除"-threads", "12",。 libx264通常知道什么是最好的,并默认自动选择适当数量的线程。

  • 如果您的观看者将通过渐进式下载观看,请添加-movflags +faststart作为输出选项。否则,视频必须完全下载才能开始播放。