Android FFmpeg Unrecognized option

狂风中的少年 提交于 2021-02-10 16:41:36

问题


I am trying to compresses a video in android using ffmepg. Here is my code:

  String[] cmd = {"-y -i" ,myVideo.getAbsolutePath().replaceAll(" ", "%20"),"-vf","-s 640x480","-threads 5","-preset ultrafast","-strict -2", (local_paths.getLocal_images() + File.separator + "test.mp4")};
            FFmpeg ffmpeg = FFmpeg.getInstance(context);
            try {
                //Load the binary
                ffmpeg.loadBinary(new LoadBinaryResponseHandler() {

                    @Override
                    public void onStart() {
                    }

                    @Override
                    public void onFailure() {
                    }

                    @Override
                    public void onSuccess() {
                    }

                    @Override
                    public void onFinish() {
                    }
                });
            } catch (FFmpegNotSupportedException e) {
                // Handle if FFmpeg is not supported by device
            }
            try {
                // to execute "ffmpeg -version" command you just need to pass "-version"
                ffmpeg.execute(cmd, new ExecuteBinaryResponseHandler() {

                    @Override
                    public void onStart() {
                        Log.e("FFmpeg", "onStart");
                    }

                    @Override
                    public void onProgress(String message) {
                        Log.e("FFmpeg", message);
                    }

                    @Override
                    public void onFailure(String message) {
                        Log.e("FFmpeg", message);
                    }

                    @Override
                    public void onSuccess(String message) {
                        Log.e("FFmpeg", message);
                    }


                    @Override
                    public void onFinish() {
                        Log.e("FFmpeg", "onFinish");
                    }
                });
            } catch (FFmpegCommandAlreadyRunningException e) {
                e.printStackTrace();
                // Handle if FFmpeg is already running
            } 

The problem is that almost all commands that I use cause Unrecognized option error:

> 07-04 11:31:21.471 24610-25450/com.network.imyth.network E/FFmpeg:
> onStart 07-04 11:31:22.091 24610-25460/com.network.imyth.network
> D/FFmpeg: Running publishing updates method 07-04 11:31:22.101
> 24610-24610/com.network.imyth.network E/FFmpeg: ffmpeg version n3.0.1
> Copyright (c) 2000-2016 the FFmpeg developers 07-04 11:31:22.101
> 24610-24610/com.network.imyth.network E/FFmpeg:   built with gcc 4.8
> (GCC) 07-04 11:31:22.101 24610-24610/com.network.imyth.network
> E/FFmpeg:   configuration: --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,now -pie' --extra-libs='-lpng -lexpat -lm' --extra-cxxflags= 07-04 11:31:22.101 24610-24610/com.network.imyth.network E/FFmpeg:   libavutil      55.
> 17.103 / 55. 17.103 07-04 11:31:22.101 24610-24610/com.network.imyth.network E/FFmpeg:   libavcodec     57.
> 24.102 / 57. 24.102 07-04 11:31:22.101 24610-24610/com.network.imyth.network E/FFmpeg:   libavformat    57.
> 25.100 / 57. 25.100 07-04 11:31:22.101 24610-24610/com.network.imyth.network E/FFmpeg:   libavdevice    57. 
> 0.101 / 57.  0.101 07-04 11:31:22.101 24610-24610/com.network.imyth.network E/FFmpeg:   libavfilter     6.
> 31.100 /  6. 31.100 07-04 11:31:22.101 24610-24610/com.network.imyth.network E/FFmpeg:   libswscale      4. 
> 0.100 /  4.  0.100 07-04 11:31:22.101 24610-24610/com.network.imyth.network E/FFmpeg:   libswresample   2. 
> 0.101 /  2.  0.101 07-04 11:31:22.101 24610-24610/com.network.imyth.network E/FFmpeg:   libpostproc    54. 
> 0.100 / 54.  0.100 07-04 11:31:22.101 24610-24610/com.network.imyth.network E/FFmpeg: Unrecognized option 'y
> -i'. 07-04 11:31:22.101 24610-24610/com.network.imyth.network E/FFmpeg: Error splitting the argument list: Option not found 07-04
> 11:31:22.101 24610-24610/com.network.imyth.network E/FFmpeg: ffmpeg
> version n3.0.1 Copyright (c) 2000-2016 the FFmpeg developers
>                                                                      built with gcc 4.8 (GCC)
>                                                                      configuration: --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,now -pie' --extra-libs='-lpng -lexpat -lm' --extra-cxxflags=
>                                                                      libavutil      55. 17.103 / 55. 17.103
>                                                                      libavcodec     57. 24.102 / 57. 24.102
>                                                                      libavformat    57. 25.100 / 57. 25.100
>                                                                      libavdevice    57.  0.101 / 57.  0.101
>                                                                      libavfilter     6. 31.100 /  6. 31.100
>                                                                      libswscale      4.  0.100 /  4.  0.100
>                                                                      libswresample   2.  0.101 /  2.  0.101
>                                                                      libpostproc    54.  0.100 / 54.  0.100
>                                                                    Unrecognized option 'y -i'.
>                                                                    Error splitting the argument list: Option not found 07-04 11:31:22.101
> 24610-24610/com.network.imyth.network E/FFmpeg: onFinish

so what the problem i get this Unrecognized option Error splitting the argument list: Option not found

im using this LIB ffmpeg-android-java


回答1:


Try splitting your arguments. This should work:

String[] command = {"-y", "-i", "/path/to/your/video.mp4", "-vf", "-s", "640x480", "-threads", "5", "-preset", "ultrafast", "-strict", "-2", "/path/to/your/video_out.mp4"};


来源:https://stackoverflow.com/questions/44900985/android-ffmpeg-unrecognized-option

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!