Android FFmpeg mp41 fps drop - PullRequest
0 голосов
/ 04 мая 2020

Я использую FFmpeg для обрезки видео в моем проекте. Это хорошо работает с большинством видео. Но у меня проблемы с некоторыми видео, которые имеют формат isomiso2avc1mp41 . Я не знаком с частью обработки видео, но когда я смотрю видео, возникает проблема сброса fps.

Я пробовал некоторые методы, такие как добавление -framerate 24 или -r 24 к командам выполнения FFmpeg, чтобы установить частоту кадров в секунду и преобразование mp41 в mp42 с использованием -brand mp42, но я не смог решить эту проблему. Может ли кто-нибудь помочь мне выяснить это, пожалуйста?

Спасибо

этот фрагмент моего кода:

String[] cropCommand = {"-y", "-i", inputFile, "-ss", "" + startMs / 1000, "-t", "" + (endMs - startMs) / 1000, "-c", "copy", outputFile};

        Log.i("cropcommand", Arrays.toString(cropCommand));
        final int finalHeight = height;
        final int finalWidht = width;
        FFmpeg.getInstance(context).execute(cropCommand, new ExecuteBinaryResponseHandler() {

            @Override
            public void onFailure(String message) {
                //   callback.onCancel();

            }

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

            @Override
            public void onSuccess(String s) {

                Log.i("videosize", "output " + String.valueOf(getFileSize(outputFile)));

            }

            @Override
            public void onStart() {
                Log.i("videosize", "input " + String.valueOf(getFileSize(inputFile)));

            }
        });
    } catch (FFmpegCommandAlreadyRunningException e) {
        e.printStackTrace();
        //  callback.onCancel();
    }

и это протокол испытаний с проблемой:

    D/FFmpeg: Running publishing updates method
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
E/ffmpeg:   libpostproc    54.  0.100 / 54.  0.100
E/ffmpeg: Input #0, mov,mp4,m4a,3gp,3g2,mj2, from '/storage/emulated/0/WhatsApp/Media/WhatsApp Video/VID-20190724-WA0012.mp4':
      Metadata:
        major_brand     : isom
        minor_version   : 512
        compatible_brands: isomiso2avc1mp41
        encoder         : Lavf58.23.100
      Duration: 00:04:01.95, start: 0.000000, bitrate: 410 kb/s
        Stream #0:0(und): Video: h264 (High) (avc1 / 0x31637661), yuv420p, 1280x720 [SAR 1:1 DAR 16:9], 274 kb/s, 29.97 fps, 29.97 tbr, 30k tbn, 59.94 tbc (default)
        Metadata:
          handler_name    : ISO Media file produced by Google Inc. Created on: 07/17/2019.
E/ffmpeg:     Stream #0:1(und): Audio: aac (LC) (mp4a / 0x6134706D), 44100 Hz, stereo, fltp, 127 kb/s (default)
        Metadata:
          handler_name    : ISO Media file produced by Google Inc. Created on: 07/17/2019.
    Output #0, mp4, to '/storage/emulated/0/Spoorcu/SPOORCU20200504102627.mp4':
      Metadata:
        major_brand     : isom
        minor_version   : 512
E/ffmpeg:     compatible_brands: isomiso2avc1mp41
        encoder         : Lavf57.25.100
        Stream #0:0(und): Video: h264 ([33][0][0][0] / 0x0021), yuv420p, 1280x720 [SAR 1:1 DAR 16:9], q=2-31, 274 kb/s, 29.97 fps, 29.97 tbr, 30k tbn, 30k tbc (default)
        Metadata:
          handler_name    : ISO Media file produced by Google Inc. Created on: 07/17/2019.
        Stream #0:1(und): Audio: aac (LC) ([64][0][0][0] / 0x0040), 44100 Hz, stereo, 127 kb/s (default)
        Metadata:
E/ffmpeg:       handler_name    : ISO Media file produced by Google Inc. Created on: 07/17/2019.
    Stream mapping:
      Stream #0:0 -> #0:0 (copy)
      Stream #0:1 -> #0:1 (copy)
    Press [q] to stop, [?] for help
E/ffmpeg: frame= 1177 fps=0.0 q=-1.0 Lsize=    2089kB time=00:00:45.02 bitrate= 380.1kbits/s speed= 606x    
    video:1338kB audio:708kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 2.144393%
I/videosize: output 2089
I/tangpeng: bitrate=3000000
E/tmessages: time = 955
...