Конкатенация ffmpeg дает слишком длинный результат без звука и с частично неправильной скоростью

Конкатенация ffmpeg дает слишком длинный результат без звука и с частично неправильной скоростью

Я использую ffmpeg 4.2.4.

У меня есть два коротких видео, оба снятых на телефон. Я вырезал часть из первого (начинается с 18 секунды и тоже длится 18 секунд — в итоге получается 18,02 секунды):

ffmpeg -i VID_20201205_135951.mp4 -ss 00:18 -t 00:18 1.mp4

А вторую я использую целиком, ее продолжительность составляет 13,55 секунд:

cp VID_20201205_140804.mp4 2.mp4

Я написал файл concat.txt:

file '1.mp4'
file '2.mp4'

И использовал фильтр concat, чтобы объединить их вместе:

ffmpeg -f concat -i concat.txt -c copy 12.mp4

Получившееся видео не имеет звука и длится 3 минуты 2,35 секунды! Если я его смотрю, первые 18 секунд идут правильно (хотя и без звука), затем оно замирает, показывая последний кадр первой части, до 1:47, после чего начинает воспроизводиться вторая часть, но очень медленно, до конца видео.

Есть идеи, что я делаю не так? Или как это исправить?

Вот информация, которую выводит ffmpeg для первого ввода:

Input #0, mov,mp4,m4a,3gp,3g2,mj2, from '1.mp4':
  Metadata:
    major_brand     : isom
    minor_version   : 512
    compatible_brands: isomiso2avc1mp41
    encoder         : Lavf58.29.100
  Duration: 00:00:18.02, start: 0.000000, bitrate: 17735 kb/s
    Stream #0:0(eng): Video: h264 (High) (avc1 / 0x31637661), yuvj420p(pc), 3840x2160 [SAR 1:1 DAR 16:9], 17678 kb/s, 30 fps, 30 tbr, 15360 tbn, 60 tbc (default)
    Metadata:
      handler_name    : VideoHandle
    Stream #0:1(eng): Audio: aac (LC) (mp4a / 0x6134706D), 48000 Hz, mono, fltp, 69 kb/s (default)
    Metadata:
      handler_name    : SoundHandle

Второй вход:

Input #0, mov,mp4,m4a,3gp,3g2,mj2, from '2.mp4':
  Metadata:
    major_brand     : mp42
    minor_version   : 0
    compatible_brands: isommp42
    creation_time   : 2020-12-05T14:08:20.000000Z
    com.android.version: 11
  Duration: 00:00:13.55, start: 0.000000, bitrate: 40373 kb/s
    Stream #0:0(eng): Video: h264 (Baseline) (avc1 / 0x31637661), yuvj420p(pc, smpte170m), 3840x2160, 42298 kb/s, SAR 1:1 DAR 16:9, 30.02 fps, 30 tbr, 90k tbn, 180k tbc (default)
    Metadata:
      rotate          : 180
      creation_time   : 2020-12-05T14:08:20.000000Z
      handler_name    : VideoHandle
    Side data:
      displaymatrix: rotation of -180.00 degrees
    Stream #0:1(eng): Audio: aac (LC) (mp4a / 0x6134706D), 48000 Hz, mono, fltp, 96 kb/s (default)
    Metadata:
      creation_time   : 2020-12-05T14:08:20.000000Z
      handler_name    : SoundHandle

И вывод:

Input #0, mov,mp4,m4a,3gp,3g2,mj2, from '12.mp4':
  Metadata:
    major_brand     : isom
    minor_version   : 512
    compatible_brands: isomiso2avc1mp41
    encoder         : Lavf58.29.100
  Duration: 00:03:02.35, start: 0.000000, bitrate: 4734 kb/s
    Stream #0:0(eng): Video: h264 (High) (avc1 / 0x31637661), yuvj420p(pc), 3840x2160 [SAR 1:1 DAR 16:9], 4719 kb/s, 5.07 fps, 30 tbr, 15360 tbn, 60 tbc (default)
    Metadata:
      handler_name    : VideoHandle
    Stream #0:1(eng): Audio: aac (LC) (mp4a / 0x6134706D), 48000 Hz, mono, fltp, 80 kb/s (default)
    Metadata:
      handler_name    : SoundHandle

решение1

Все входы должны иметь одинаковые атрибуты. У вас разные профили H.264 (базовый и высокий) и частота кадров.

Сделайте так, чтобы одно видео совпадало с другим:

ffmpeg -i 2.mp4 -c:v libx264 -r 30 -c:a copy 2b.mp4

По умолчанию будет выбран высокий профиль, поэтому вам не нужно добавлять его вручную, но если вы хотите использовать базовый профиль, используйте -profile:v baseline.

Или преобразовать все видео в набор атрибутов комментариев независимо от входных атрибутов. СмотретьКак объединить видео в ffmpeg с разными атрибутами?

Связанный контент