Tenho algumas imagens 4K 3840x2160 em formato MP4 que preciso reduzir para 1080p. Eu tentei correr
ffmpeg -i orig.mp4 -vf scale=1920:1080 smaller.mp4
mas o resultado é uma qualidade muito ruim, com a imagem inteira sendo composta de "ladrilhos" quadrados como se eu estivesse ampliando 4: 1.
Aqui está a saída da execução deste comando:
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'origs/P1000003.MP4':
Metadata:
major_brand : mp42
minor_version : 1
compatible_brands: mp42avc1
creation_time : 2015-02-19 17:10:38
Duration: 00:05:14.48, start: 0.000000, bitrate: 95903 kb/s
Stream #0.0(und): Video: h264 (High), yuvj420p, 3840x2160 [PAR 1:1 DAR 16:9], 95792 kb/s, 25 fps, 25 tbr, 90k tbn, 50 tbc
Metadata:
creation_time : 2015-02-19 17:10:38
Stream #0.1(und): Audio: aac, 48000 Hz, stereo, s16, 125 kb/s
Metadata:
creation_time : 2015-02-19 17:10:38
Incompatible pixel format 'yuvj420p' for codec 'mpeg4', auto-selecting format 'yuv420p'
[buffer @ 0x22a3420] w:3840 h:2160 pixfmt:yuvj420p
[scale @ 0x22a3ce0] w:3840 h:2160 fmt:yuvj420p -> w:1920 h:1080 fmt:yuv420p flags:0x4
Output #0, mp4, to '1-short.mp4':
Metadata:
major_brand : mp42
minor_version : 1
compatible_brands: mp42avc1
creation_time : 2015-02-19 17:10:38
encoder : Lavf53.21.1
Stream #0.0(und): Video: mpeg4, yuv420p, 1920x1080 [PAR 1:1 DAR 16:9], q=2-31, 200 kb/s, 25 tbn, 25 tbc
Metadata:
creation_time : 2015-02-19 17:10:38
Stream #0.1(und): Audio: libvo_aacenc, 48000 Hz, stereo, s16, 200 kb/s
Metadata:
creation_time : 2015-02-19 17:10:38
Stream mapping:
Stream #0.0 -> #0.0
Stream #0.1 -> #0.1
Press ctrl-c to stop encoding
frame= 125 fps= 6 q=31.0 Lsize= 968kB time=5.00 bitrate=1586.7kbits/s
video:842kB audio:123kB global headers:0kB muxing overhead 0.421047%
Sei por experiência que o ffmpeg é uma excelente ferramenta, por isso devo estar estragando as opções / parâmetros de alguma forma ...
Como posso fazer isso?
-c:a copy
, pois você não deseja ou precisa recodificar o fluxo de áudio. Use -map 0
para copiar qualquer metadado do capítulo ou outras coisas. (ffmpeg leva apenas 1 vid + 1 aud por padrão.)
-sws_flags lanczos+print_info
usará algo melhor em escala do que o padrão (acho que bilinear). A resposta do stlb cobre a parte de codificação de vídeo do processo.
scale=1920:-2:flags=lanczos
,. Eu também mencionaria a -2
escala for em minha resposta inexistente. Para quem não sabe, você pode colocar -2
largura ou altura, e ele fornecerá automaticamente o valor correto, preservando a proporção e tornando o valor divisível por 2 (exigido pela libx264 para saídas yuv420p).
-t 10
para fazer uma saída de 10 segundos. Por que você deseja fazer o downscale? Qual é o caso de uso para sua saída escalada? Esta informação me ajudará a fornecer uma resposta mais precisa.