Eu estava tentando depurar um problema no qual meu arquivo mp4 não faz o upload para o youtube (com o erro "Falha no envio: não é possível processar o arquivo"). O vídeo é reproduzido normalmente no vlc player e pode ser carregado no Vegas Pro (na verdade, renderizá-lo novamente irá corrigir o problema de upload). A verificação de metadados usando o MediaInfo não mostra nada anormal comparado a outros arquivos mp4 da mesma fonte (e funcionou bem ao carregar para o youtube). Depois de algumas pesquisas com várias ferramentas, encontrei um problema quando segui as instruções do superusuário para transcodificar o arquivo mp4 original usando o ffmpeg. Como esse é o único problema que posso encontrar com o arquivo mp4 original, acho que pode ser a causa da falha no upload. Agora quero consertar isso.
O comando que usei é ffmpeg -i scripts/1.mp4 -pix_fmt yuv420p -crf 18 scripts/good.mp4
A saída é
ffmpeg -i scripts/1.mp4 -pix_fmt yuv420p -crf 18 scripts/good.mp4
ffmpeg version N-83577-g7e538c9 Copyright (c) 2000-2017 the FFmpeg developers
built with gcc 4.8 (Ubuntu 4.8.4-2ubuntu1~14.04.3)
configuration: --prefix=/home/________/ffmpeg_build --pkg-config-flags=--static --extra-cflags=-I/home/tianyig/ffmpeg_build/include --extra-ldflags=-L/home/tianyig/ffmpeg_build/lib --bindir=/home/tianyig/bin --enable-gpl --enable-libass --enable-libfdk-aac --enable-libfreetype --enable-libmp3lame --enable-libopus --enable-libtheora --enable-libvorbis --enable-libvpx --enable-libx264 --enable-libx265 --enable-nonfree
libavutil 55. 47.100 / 55. 47.100
libavcodec 57. 80.101 / 57. 80.101
libavformat 57. 66.102 / 57. 66.102
libavdevice 57. 2.100 / 57. 2.100
libavfilter 6. 73.100 / 6. 73.100
libswscale 4. 3.101 / 4. 3.101
libswresample 2. 4.100 / 2. 4.100
libpostproc 54. 2.100 / 54. 2.100
[mov,mp4,m4a,3gp,3g2,mj2 @ 0x25074a0] Could not find codec parameters for stream 0 (Video: h264 (avc1 / 0x31637661), none, 540x960, 950 kb/s): unspecified pixel format
Consider increasing the value for the 'analyzeduration' and 'probesize' options
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'scripts/1.mp4':
Metadata:
major_brand : isom
minor_version : 512
compatible_brands: isomiso2avc1mp41
encoder : Lavf56.25.101
copyright : @Baidu.com
Duration: 00:12:15.90, start: 0.089000, bitrate: 1027 kb/s
Stream #0:0(und): Video: h264 (avc1 / 0x31637661), none, 540x960, 950 kb/s, 22.58 fps, 25 tbr, 16k tbn, 32k tbc (default)
Metadata:
handler_name : VideoHandler
Stream #0:1(und): Audio: aac (LC) (mp4a / 0x6134706D), 44100 Hz, stereo, fltp, 77 kb/s (default)
Metadata:
handler_name : SoundHandler
[buffer @ 0x250e200] Unable to parse option value "-1" as pixel format
Last message repeated 1 times
[buffer @ 0x250e200] Error setting option pix_fmt to value -1.
[graph 0 input from stream 0:0 @ 0x262a4e0] Error applying options to the filter.
Error opening filters!
Ele está reclamando sobre pix_fmt com valor -1, mas claramente eu já tenho um -pix_fmt yuv420p
como parte do comando que não parece ser respeitado.
Alguma ideia de como consertar isso?