我正在使用FFmpeg从视频文件的特定位置提取缩略图。使用FFmpeg创建缩略图
我在网上找到了两种方法来做到这一点:
随着
-ss
(寻求)参数之前-i
(输入)参数:ffmpeg -y -ss $SEEK_POINT -i input.ogv -vcodec mjpeg -vframes 1 -an -s 120x90 -f rawvideo output.jpg
随着
-ss
(寻求)参数-i
(输入)参数:ffmpeg -y -i input.ogv -vcodec mjpeg -ss $SEEK_POINT -vframes 1 -an -s 120x90 -f rawvideo output.jpg
第一种方法产生不好的缩略图,灰色斑点,但工程非常快。返回的错误是[theora @ 0x8097240] vp3: first frame not a keyframe
。
第二种方法总能正常工作,但显示一个错误,导致提取花费大量时间。这段时间不是固定的,它取决于我注意到的寻求点。有时需要几秒钟,其他时间需要几分钟才能提取缩略图。我得到的错误Buffering several frames is not supported. Please consume all available frames before adding a new one.
以下输出:
Input #0, ogg, from 'input.ogv':
Duration: 00:21:52.76, start: 0.000000, bitrate: 844 kb/s
Stream #0.0: Video: theora, yuv420p, 800x600 [PAR 4:3 DAR 16:9], 25 fps, 25 tbr, 25 tbn, 25 tbc
Stream #0.1: Audio: vorbis, 44100 Hz, stereo, s16, 192 kb/s
Metadata:
ENCODER : Lavf52.102.0
Incompatible pixel format 'yuv420p' for codec 'mjpeg', auto-selecting format 'yuvj420p'
[buffer @ 0x9250840] w:800 h:600 pixfmt:yuv420p
[scale @ 0x92508a0] w:800 h:600 fmt:yuv420p -> w:120 h:90 fmt:yuvj420p flags:0x4
Output #0, rawvideo, to 'output.jpg':
Metadata:
encoder : Lavf53.2.0
Stream #0.0: Video: mjpeg, yuvj420p, 120x90 [PAR 4:3 DAR 16:9], q=2-31, 200 kb/s, 90k tbn, 25 tbc
Stream mapping:
Stream #0.0 -> #0.0
Press ctrl-c to stop encoding
[buffer @ 0x9250840] Buffering several frames is not supported. Please consume all available frames before adding a new one.
frame= 0 fps= 0 q=0.0 size= 0kB time=10000000000.00 bitrate= 0.0kbit
Last message repeated 15448 times
frame= 1 fps= 0 q=3.4 Lsize= 3kB time=0.04 bitrate= 598.8kbits/s
video:3kB audio:0kB global headers:0kB muxing overhead 0.000000%
我如何可以提取缩略图,而无需使用FFmpeg的距离,而与输入格式的视频的自定义位置的任何问题?
不,它不起作用。每次运行时,无论我设置为“-itoffset”的参数如何,它都只会从视频中提取第一帧。你有什么想法,为什么? –
对于任何后来发现此问题的人的最新回复。我相信'-itsoffset'参数应该是负值。在这种情况下'-4',因为您想要及时更早地移动视频流,请不要延迟它。 – runfalk