Jedynym dotychczasowym narzędziem wiersza polecenia systemu Linux, które można wycinać z dokładną klatką (lub, z dokładnością do ramki), jest melt
( sudo apt-get install melt
).
Powiedzmy, że masz inputvid.mp4
- najpierw sprawdź ustawienia kodowania za pomocą say ffmpeg
(tutaj, po prostu mówię, że chcę go ponownie zakodować -f mp4
, ale jako plik, /dev/null
więc dane wyjściowe są odrzucane; przekierowuję stderr, dzięki czemu mogę grep przez to - uwaga na środku) , polecenie wyświetla monit i powinieneś odpowiedzieć y
klawiszem ENTER, więc proces jest kontynuowany i zrzuca użyteczne informacje; jest to wersja ffmpeg 3.3.3 na Ubuntu 14):
ffmpeg -i inputvid.mp4 -f mp4 /dev/null 2>&1 | grep 'Stream\|encoder'
Stream #0:0(und): Video: h264 (Constrained Baseline) (avc1 / 0x31637661), yuv420p(tv, bt709), 640x360 [SAR 1:1 DAR 16:9], 389 kb/s, 23.98 fps, 23.98 tbr, 24k tbn, 47.95 tbc (default)
Stream #0:1(und): Audio: aac (LC) (mp4a / 0x6134706D), 44100 Hz, stereo, fltp, 95 kb/s (default)
y
File '/dev/null' already exists. Overwrite ? [y/N] Stream mapping:
Stream #0:0 -> #0:0 (h264 (native) -> h264 (libx264))
Stream #0:1 -> #0:1 (aac (native) -> aac (native))
encoder : Lavf57.71.100
Stream #0:0(und): Video: h264 (libx264) ([33][0][0][0] / 0x0021), yuv420p(progressive), 640x360 [SAR 1:1 DAR 16:9], q=-1--1, 23.98 fps, 24k tbn, 23.98 tbc (default)
encoder : Lavc57.89.100 libx264
Stream #0:1(und): Audio: aac (LC) ([64][0][0][0] / 0x0040), 44100 Hz, stereo, fltp, 128 kb/s (default)
encoder : Lavc57.89.100 aac
Ok, więc możemy zobaczyć ffmpeg
wybory libx264
i aac
kodery tego filmu; możemy wprowadzić to dla melt
:
melt inputvid.mp4 in=7235 out=7349 -consumer avformat:cut.mp4 acodec=aac vcodec=libx264
.... i melt
będzie wyciąć z kawałka między ramkami 7235 i 7349 do nowego pliku cut.mp4
. Następnie, aby sprawdzić, czy cut.mp4
pętle działają poprawnie, użyj melt
ponownie, aby odtworzyć go dwukrotnie - i odtworzyć w oknie SDL:
melt cut.mp4 cut.mp4 -consumer sdl
... a oto, co ffmpeg
widzi ten plik:
ffmpeg -i cut.mp4 -f mp4 /dev/null 2>&1 | grep 'Stream\|encoder' encoder : Lavf54.20.4
Stream #0:0(und): Video: h264 (High) (avc1 / 0x31637661), yuv420p, 640x360 [SAR 1:1 DAR 16:9], 526 kb/s, 23.98 fps, 23.98 tbr, 24k tbn, 47.95 tbc (default)
Stream #0:1(und): Audio: aac (LC) (mp4a / 0x6134706D), 48000 Hz, stereo, fltp, 182 kb/s (default)
y
File '/dev/null' already exists. Overwrite ? [y/N] Stream mapping:
Stream #0:0 -> #0:0 (h264 (native) -> h264 (libx264))
Stream #0:1 -> #0:1 (aac (native) -> aac (native))
encoder : Lavf57.71.100
Stream #0:0(und): Video: h264 (libx264) ([33][0][0][0] / 0x0021), yuv420p, 640x360 [SAR 1:1 DAR 16:9], q=-1--1, 23.98 fps, 24k tbn, 23.98 tbc (default)
encoder : Lavc57.89.100 libx264
Stream #0:1(und): Audio: aac (LC) ([64][0][0][0] / 0x0040), 48000 Hz, stereo, fltp, 128 kb/s (default)
encoder : Lavc57.89.100 aac
Ustawienia kodowania wideo cut.mp4
wydają się być identyczne, z inputvid.mp4
wyjątkiem zmienionej przepływności wideo z 389 kb / s do 526 kb / s, a także ustawienia kodowania audio są prawie takie same, z wyjątkiem częstotliwości próbkowania zmienionej z 44100 na 48000 Hz; chociaż można to regulować za pomocą:
melt inputvid.mp4 in=7235 out=7349 -consumer avformat:cut.mp4 acodec=aac ar=44100 ab=95k vcodec=libx264 vb=389k
... jednak nawet przy tym końcowa szybkość transmisji wideo dla mnie wynosi 337 kb / s. Mimo to cięcia są w porządku (i obejmuje to dźwięk) podczas odtwarzania w pętli, więc sądzę, że jest to rzeczywiście dokładność klatek ...