7

Я пытаюсь сделать снимок с беспроводной IP-камеры H.264 с помощью ffmpeg. Я нашел похожий вопрос здесь: Как я могу извлечь хорошее качество изображения JPEG из видеофайла H264 с помощью ffmpeg?

ffmpeg -y -i rtsp://10.2.69.201:554/ch0_0.h264 -r 10 -f image2 /var/www/camera.jpg

Я реализовал это, как показано в этом примере. Вы можете увидеть образец изображения, которое я получаю здесь:

В основном проблема в том, что нижняя часть изображения всегда блочная. Если на небе больше деталей и облаков, вся нижняя половина изображения может быть размытой или размытой.

У моей камеры ограниченные возможности потоковой передачи. Одним из них является интервал I-Frame, вы можете варьировать его от 25 до 100.

У кого-нибудь есть какие-нибудь предложения о том, как я могу получить лучшее изображение? Я бы не возражал, если бы можно было на самом деле сохранить поток в видеофайл, а также извлекать кадр каждые 2 минуты. Это легко сделать?

Вот вывод ffmpeg:

ffmpeg version 1.2.4 Copyright (c) 2000-2013 the FFmpeg developers
built on Oct  3 2013 07:36:02 with gcc 4.8 (Debian 4.8.1-10)
configuration: --prefix=/usr --extra-cflags='-g -O2 -fstack-protector --param=ssp-buffer-size=4 -Wformat -Werror=format-security ' --extra-ldflags='-Wl,-z,relro' --cc='ccache cc' --enable-shared --enable-libmp3lame --enable-gpl --enable-nonfree --enable-libvorbis --enable-pthreads --enable-libfaac --enable-libxvid --enable-postproc --enable-x11grab --enable-libgsm --enable-libtheora --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libx264 --enable-libspeex --enable-nonfree --disable-stripping --enable-libvpx --enable-libschroedinger --disable-encoder=libschroedinger --enable-version3 --enable-libopenjpeg --enable-librtmp --enable-avfilter --enable-libfreetype --enable-libvo-aacenc --disable-decoder=amrnb --enable-libvo-amrwbenc --enable-libaacplus --libdir=/usr/lib/i386-linux-gnu --disable-vda --enable-libbluray --enable-libcdio --enable-gnutls --enable-frei0r --enable-openssl --enable-libass --enable-libopus --enable-fontconfig --enable-libpulse --disable-mips32r2 --disable-mipsdspr1 --disab  libavutil      52. 18.100 / 52. 18.100
libavcodec     54. 92.100 / 54. 92.100
libavformat    54. 63.104 / 54. 63.104
libavdevice    54.  3.103 / 54.  3.103
libavfilter     3. 42.103 /  3. 42.103
libswscale      2.  2.100 /  2.  2.100
libswresample   0. 17.102 /  0. 17.102
libpostproc    52.  2.100 / 52.  2.100
[h264 @ 0x867ed80] RTP: missed 1 packets
    Last message repeated 1 times
[h264 @ 0x867ed80] mb_type 34 in I slice too large at 17 18
[h264 @ 0x867ed80] error while decoding MB 17 18
[h264 @ 0x867ed80] concealing 5732 DC, 5732 AC, 5732 MV errors in I frame
[h264 @ 0x867ed80] RTP: missed 1 packets
Last message repeated 14 times
[rtsp @ 0x867c640] Stream #1: not enough frames to estimate rate; consider increasing probesize
[rtsp @ 0x867c640] Estimating duration from bitrate, this may be inaccurate
Guessed Channel Layout for  Input Stream #0.1 : mono
Input #0, rtsp, from 'rtsp://10.2.69.201:554/ch0_0.h264':
 Metadata:
title           : H.264 Program Stream, streamed by the LIVE555 Media Server
comment         : ch0_0.h264
 Duration: N/A, start: 0.065833, bitrate: 64 kb/s
Stream #0:0: Video: h264 (Constrained Baseline), yuv420p, 1600x1200, 15.19 tbr, 90k tbn, 180k tbc
Stream #0:1: Audio: pcm_alaw, 8000 Hz, mono, s16, 64 kb/s 
Output #0, image2, to '/var/www/camera.jpg':
Metadata:
title           : H.264 Program Stream, streamed by the LIVE555 Media Server
comment         : ch0_0.h264
encoder         : Lavf54.63.104
Stream #0:0: Video: mjpeg, yuvj420p, 1600x1200, q=2-31, 200 kb/s, 90k tbn, 10 tbc
Stream mapping:
Stream #0:0 -> #0:0 (h264 -> mjpeg)
Press [q] to stop, [?] for help
[h264 @ 0x8793260] mb_type 34 in I slice too large at 17 18
[h264 @ 0x8793260] error while decoding MB 17 18
[h264 @ 0x8793260] concealing 5732 DC, 5732 AC, 5732 MV errors in I frame 
[image2 @ 0x86d1640] Could not get frame filename number 2 from pattern '/var/www/camera.jpg' (either set updatefirst or use a pattern like %03d within the filename pattern)
av_interleaved_write_frame(): Invalid argument

3 ответа3

11

Проблема, на которую указывают ваши выходные данные, заключается в том, что вам не хватает пакетов RTP и, следовательно, важных частей видео. С вашей командой ffmpeg выведет ровно одно изображение - как только увидит конец первого кадра - но некоторые данные пропали. Таким образом, он пытается скрыть ошибки в макроблоках, но он может сделать это только путем копирования частей уже декодированного изображения, что приводит к появлению артефактов, которые вы видите здесь.

В FFmpeg Wiki есть пример того, как создавать миниатюру каждые x секунд:

ffmpeg -i rtsp://10.2.69.201:554/ch0_0.h264 -f image2 -vf fps=fps=1/120 img%03d.jpg

Конечно, вы можете попытаться сохранить поток в файл. В этом случае он остановится через 120 секунд:

ffmpeg -i rtsp://10.2.69.201:554/ch0_0.h264 -c:v copy -t 120 stream.mp4

Если вы можете, попробуйте загрузить или скомпилировать последнюю статическую сборку, так как ваш ffmpeg немного старше, и вы никогда не узнаете, не сталкивались ли вы с уже исправленной ошибкой.

5

Сообщение RTP: missed 1 packets является подсказкой того, что в вашем потоке отсутствуют некоторые данные.

Попробуйте добавить параметр -rtsp_transport tcp перед -y чтобы использовать TCP вместо UDP.

3

Привет у меня была та же проблема с потоком RTSP от моей IP-камеры некоторое время назад. ffmpeg версия 1.0 построена 21 ноября 2012 г. 20:41:28 с gcc 4.4.6 (GCC) 20120305

У меня был тот же результат, что и у вас, с размытой частью внизу.

команда, которую я использовал, была:

ffmpeg -i {RTSP_SOURCE} -ss 00:00:01 -f image2 -vframes 1 thumb.jpg

Моя проблема была решена, когда я добавил суффикс миллисекунды в параметр -ss:

ffmpeg -i {RTSP_SOURCE} -ss 00:00:01.500 -f image2 -vframes 1 thumb.jpg

Я нашел это в примере в официальной документации FFMPEG, и это сработало для моего случая.

https://trac.ffmpeg.org/wiki/Create%20a%20thumbnail%20image%20every%20X%20seconds%20of%20the%20video

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .