Какие настройки кодирования FFmpeg необходимы для веб-воспроизведения?

Вопрос или проблема

Я пытаюсь конвертировать видео, записанные на iPhone (в частности, на 15 Pro Max, который, как я полагаю, работал на версии 17.6.1, судя по метаданным), чтобы они воспроизводились в браузерах, особенно в Safari на этом iPhone, но так и не смог найти подходящее сочетание настроек, чтобы это работало. Ранее клиент использовал iPhone 13, и все сработало хорошо с libx264, но это больше не работает с новой версией.

Вот команда FFmpeg:

ffmpeg -y -i {source_path} -vcodec libx264 -acodec aac -refs 6 -coder 1 -sc_threshold 40 -flags +loop -me_range 16 -subq 7 -i_qfactor 0.71 -qcomp 0.6 -qdiff 4 -trellis 1 -b:a 256k -ac 2 {output_path}

Я пробовал собирать много разных опций, но безуспешно. Я попробовал установить профиль на baseline и уровень 4.0 (и 3.1), что привело к ошибке кодирования, потому что источник был 10-битным, поэтому я добавил pix_fmt yuv420p, и это привело к кодированию, но iOS Safari выдал ошибку “медиа не поддерживается”. Я пробовал разные уровни (4.0 и 3.1), разные профили (baseline, main, high и high10) и множество других случайных копипастов, которые нашел в интернете, но ничего не сработало до сих пор.

Вот вывод FFprobe для исходного видео:

ffprobe version 4.2.7-0ubuntu0.1+esm6 Copyright (c) 2007-2022 the FFmpeg developers
  built with gcc 9 (Ubuntu 9.4.0-1ubuntu1~20.04.2)
  configuration: --prefix=/usr --extra-version=0ubuntu0.1+esm6 --toolchain=hardened --libdir=/usr/lib/x86_64-linux-gnu --incdir=/usr/include/x86_64-linux-gnu --arch=amd64 --enable-gpl --disable-stripping --enable-avresample --disable-filter=resample --enable-avisynth --enable-gnutls --enable-ladspa --enable-libaom --enable-libass --enable-libbluray --enable-libbs2b --enable-libcaca --enable-libcdio --enable-libcodec2 --enable-libflite --enable-libfontconfig --enable-libfreetype --enable-libfribidi --enable-libgme --enable-libgsm --enable-libjack --enable-libmp3lame --enable-libmysofa --enable-libopenjpeg --enable-libopenmpt --enable-libopus --enable-libpulse --enable-librsvg --enable-librubberband --enable-libshine --enable-libsnappy --enable-libsoxr --enable-libspeex --enable-libssh --enable-libtheora --enable-libtwolame --enable-libvidstab --enable-libvorbis --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx265 --enable-libxml2 --enable-libxvid --enable-libzmq --enable-libzvbi --enable-lv2 --enable-omx --enable-openal --enable-opencl --enable-opengl --enable-sdl2 --enable-libdc1394 --enable-libdrm --enable-libiec61883 --enable-nvenc --enable-chromaprint --enable-frei0r --enable-libx264 --enable-shared
  libavutil      56. 31.100 / 56. 31.100
  libavcodec     58. 54.100 / 58. 54.100
  libavformat    58. 29.100 / 58. 29.100
  libavdevice    58.  8.100 / 58.  8.100
  libavfilter     7. 57.100 /  7. 57.100
  libavresample   4.  0.  0 /  4.  0.  0
  libswscale      5.  5.100 /  5.  5.100
  libswresample   3.  5.100 /  3.  5.100
  libpostproc    55.  5.100 / 55.  5.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from '_20240924010655_66f2f1af2362a_file_path':
  Metadata:
    major_brand     : qt
    minor_version   : 0
    compatible_brands: qt
    creation_time   : 2024-09-19T23:01:19.000000Z
    com.apple.quicktime.location.accuracy.horizontal: [скрыто]
    com.apple.quicktime.location.ISO6709: [скрыто]
    com.apple.quicktime.make: Apple
    com.apple.quicktime.model: iPhone 15 Pro Max
    com.apple.quicktime.software: 17.6.1
    com.apple.quicktime.creationdate: 2024-09-19T18:01:19-0500
  Duration: 00:00:30.95, start: 0.000000, bitrate: 9467 kb/s
    Stream #0:0(und): Video: hevc (Main 10) (hvc1 / 0x31637668), yuv420p10le(tv, bt2020nc/bt2020/arib-std-b67), 1920x1080, 9251 kb/s, 29.98 fps, 29.97 tbr, 600 tbn, 600 tbc (default)
    Metadata:
      rotate          : 90
      creation_time   : 2024-09-19T23:01:19.000000Z
      handler_name    : Core Media Video
      encoder         : HEVC
    Side data:
      displaymatrix: rotation of -90.00 degrees
    Stream #0:1(und): Audio: aac (LC) (mp4a / 0x6134706D), 44100 Hz, stereo, fltp, 167 kb/s (default)
    Metadata:
      creation_time   : 2024-09-19T23:01:19.000000Z
      handler_name    : Core Media Audio
    Stream #0:2(und): Data: none (mebx / 0x7862656D), 0 kb/s (default)
    Metadata:
      creation_time   : 2024-09-19T23:01:19.000000Z
      handler_name    : Core Media Metadata
    Stream #0:3(und): Data: none (mebx / 0x7862656D), 0 kb/s (default)
    Metadata:
      creation_time   : 2024-09-19T23:01:19.000000Z
      handler_name    : Core Media Metadata
    Stream #0:4(und): Data: none (mebx / 0x7862656D), 34 kb/s (default)
    Metadata:
      creation_time   : 2024-09-19T23:01:19.000000Z
      handler_name    : Core Media Metadata
Неподдерживаемый кодек с id 0 для входного потока 2
Неподдерживаемый кодек с id 0 для входного потока 3
Неподдерживаемый кодек с id 0 для входного потока 4

Вывод FFprobe показывает следующее:

encoder         : HEVC

HEVC — это более современный кодек, который iOS использует в настоящее время вместо libx264. Учитывая это, изменение на libx265 должно сработать.

Ответ или решение

Чтобы обеспечить совместимость видео с воспроизведением на веб-сайтах, особенно в Safari на iPhone, необходимо использовать правильные настройки кодирования с помощью FFmpeg. Учитывая, что исходное видео записано с использованием видеокодека HEVC (h265), вы можете воспользоваться кодеком libx265 для конвертации.

Ваша задача состоит в том, чтобы создать видеофайл, совместимый с веб-плеерами, включая Safari, и поддерживающий стандартные параметры кодирования. Вот пример команды FFmpeg, которую вы можете использовать:

ffmpeg -y -i {source_path} -vcodec libx265 -preset fast -pix_fmt yuv420p -crf 23 -profile:v main -level 4.0 -bf 2 -b:a 256k -ac 2 -ar 44100 {output_path}

Объяснение параметров:

  • -y: Перезаписывает выходной файл без запроса подтверждения.
  • -i {source_path}: Указывает путь к исходному видеофайлу.
  • -vcodec libx265: Указывает кодек для сжатия видео (HEVC, х265).
  • -preset fast: Устанавливает скорость кодирования. Вы можете выбрать medium, slow, и т. д., в зависимости от ваших требований к качеству и времени кодирования.
  • -pix_fmt yuv420p: Указывает формат пикселей. Это важно для совместимости, так как большинство веб-браузеров поддерживают только yuv420p.
  • -crf 23: Задает фиксированный параметр качества. Значения от 18 до 28 считаются нормальными (меньшее значение = лучше качество, больший значение = меньший размер файла).
  • -profile:v main: Устанавливает профиль видеокодека, что улучшает совместимость.
  • -level 4.0: Задает уровень кодирования. Уровень 4.0 подходит для большинства современных приложений.
  • -bf 2: Указывает количество B-кадров. Это может помочь улучшить качество, но увеличивает время кодирования.
  • -b:a 256k: Устанавливает битрейт для аудио на 256 кбит/с, что обеспечивает хорошее качество звука.
  • -ac 2: Устанавливает число аудиоканалов на стерео (2 канала).
  • -ar 44100: Устанавливает частоту дискретизации аудиопотока на 44,1 кГц, что является стандартом.

Дополнительные рекомендации:

  1. Проверка превью: Перед началом массовой конвертации рекомендуется протестировать полученное видео на различных устройствах и браузерах.
  2. Метаданные: Не забудьте добавить метаданные (если требуется) с помощью параметров -metadata, чтобы ваше видео правильно отображалось в плеерах.
  3. Совместимость с HEVC: Убедитесь, что устройства, на которых планируется воспроизведение видео, поддерживают HEVC. Некоторые более старые устройства могут не воспроизводить такие видео.

Следуя данным рекомендациям, вы должны получить видео, которое будет корректно воспроизводиться в Safari и других браузерах.

Оцените материал
Добавить комментарий

Капча загружается...