打开输出流#0:0的编码器时淡出视频错误-可能是不正确的参数,例如bit_rate,rate,width或height

时间:2018-09-23 10:50:03

标签: android ffmpeg android-ffmpeg video-editing

我正在使用以下命令将淡入淡出效果添加到我的视频中

{"-y", "-ss", "" + startMs / 1000, "-t", "" + (endMs - startMs) / 1000, "-i", inputPath, "-acodec", "copy", "-vf", "fade=t=in:st=0:d=5,fade=t=out:st=" + String.valueOf((endMs - startMs) / 1000 - 5) + ":d=5", outputPath};

我收到以下错误-

  

“ Failure3.3 5 .3gpffmpeg版本n3.0.1版权所有(c)2000-2016   FFmpeg开发人员\ n使用gcc 4.8(GCC)配置\ n:   --target-os = linux --cross-prefix = / home / vagrant / SourceCode / ffmpeg-android / toolchain-android / bin / arm-linux-androideabi-   --arch = arm --cpu = cortex-a8 --enable-runtime-cpudetect --sysroot = / home / vagrant / SourceCode / ffmpeg-android / toolchain-android / sysroot   --enable-pic --enable-libx264 --enable-libass --enable-libfreetype --enable-libfribidi --enable-libmp3lame --enable-fontconfig --enable-pthreads --disable-debug --disable-ffserver --enable-version3 --enable-hardcoded-tables --disable-ffplay --disable-ffprobe --enable-gpl --enable-yasm --disable-doc --disable-shared --enable-static --pkg -config = / home / vagrant / SourceCode / ffmpeg-android / ffmpeg-pkg-config --prefix = / home / vagrant / SourceCode / ffmpeg-android / build / armeabi-v7a --extra-cflags ='-I / home / vagrant / SourceCode / ffmpeg-android / toolchain-android / include   -U_FORTIFY_SOURCE -D_FORTIFY_SOURCE = 2 -fno-strict-overflow -fstack-protector-all'--extra-ldflags ='-L / home / vagrant / SourceCode / ffmpeg-android / toolchain-android / lib   -Wl,-z,relro -Wl,-z,现在-pie'--extra-libs ='-lpng -lexpat -lm'--extra-cxxflags = \ n libavutil 55. 17.103 / 55. 17.103 \ n libavcodec 57. 24.102 / 57. 24.102 \ n libavformat 57. 25.100 /   57. 25.100 \ n libavdevice 57. 0.101 / 57. 0.101 \ n libavfilter 6. 31.100 / 6. 31.100 \ n libswscale 4. 0.100 / 4. 0.100 \ n libswresample 2. 0.101 / 2. 0.101 \ n libpostproc 54. 0.100 /   54. 0.100 \ n输入#0,mov,mp4,m4a,3gp,3g2,mj2,来自“ /storage/emulated/0/DCIM/Camera/VID_20180825_071734915.3gp”:\n   元数据:\ n major_brand:3gp4 \ nminor_version:0 \ n
  compatible_brands:isom3gp4 \ n创建时间:2018-08-25   01:47:47 \ n com.android.version:8.0.0 \ n持续时间:00:00:10.83,   开始:0.000000,比特率:17217 kb / s \ n流#0:0(eng):视频:   h264(高)(avc1 / 0x31637661),yuv420p(电视,未知/ bt470bg /未知),   1920x1080、16756 kb / s,SAR 1:1 DAR 16:9、29.49 fps,29.58 tbr,90k   tbn,180k tbc(默认)\ n元数据:\ n旋转:90 \ n
  creation_time:2018-08-25 01:47:47 \ n handler_name:   VideoHandle \ n辅助数据:\ n displaymatrix:旋转-90.00   度\ n流#0:1(eng):音频:aac(LC)(mp4a / 0x6134706D),   48000 Hz,单声道,fltp,128 kb / s(默认)\ n元数据:\ n
  creation_time:2018-08-25 01:47:47 \ n handler_name:   SoundHandle \ n [h263 @ 0xf49ff400] H.263不支持分辨率   大于2048x1152 \ n输出#0、3gp,   '/storage/emulated/0/Movies/fade_video.3gp':\n元数据:\ n
  major_brand:3gp4 \ nminor_version:0 \ n
  compatible_brands:isom3gp4 \ n com.android.version:8.0.0 \ n
  流#0:0(eng):视频:h263,无,q = 2-31,128 kb / s,SAR 1:1 DAR   0:0,29.58 fps(默认)\ n元数据:\ n handler_name:   VideoHandle \ n creation_time:2018-08-25 01:47:47 \ n
  编码器:Lavc57.24.102 h263 \ n流#0:1(eng):音频:aac   (LC)(mp4a / 0x6134706D),48000 Hz,单声道,128 kb / s(默认)\ n
  元数据:\ n creation_time:2018-08-25 01:47:47 \ n
  handler_name:SoundHandle \ n流映射:\ n流#0:0->#0:0   (h264(本机)-> h263(本机))\ n流#0:1->#0:1(复制)\ n错误   打开输出流#0:0的编码器时-可能不正确   参数,例如bit_rate,rate,width或height \ n“

为什么在上述命令中导致此错误?欢迎任何帮助。

1 个答案:

答案 0 :(得分:1)

如日志所述,H.263不支持2048x1152以上的分辨率。您的源流是1920x1080,但已90度旋转,因此ffm​​peg会将其自动旋转到不符合限制的1080x1920。您可以在淡入淡出之后添加比例过滤器,以有条件地缩小尺寸。

scale='if(lte(iw,2048)*lte(ih,1152),iw,if(gt(dar,2048/1152),2048,2*trunc(oh*dar/2)))':'if(lte(iw,2048)*lte(ih,1152),ih,if(gt(dar,2048/1152),2*trunc(ow/dar/2),1152))'

x和y exprs的作用是首先检查输入是否大于2048x1152。如果否,请保持原始分辨率。如果是,请检查输入的显示比例。如果大于2048:1152,则将宽度减小到2048,并按比例调整高度,否则,将高度减小到1152,并按比例调整宽度。 dar代表显示宽高比。