День добрый, уважаемые!
Подскажите бедному юзеру как овладать захватом видео с помощью ffmpeg с камеры, подключенной по firewire?
Из того, что я нагуглил, из недавних пор для этого используется libiec61883, но инфы по ней ох как мало.
Камеру подключаю, появляется у меня /dev/fw0. После включения камеры появляется ещё /dev/fw1 с которого dvgrab захватывает видео без проблем, а вот ffmpeg никак не хочет. Кто-то имел дело с этим?
команда ffmpeg:
~# ffmpeg -threads 0 -f iec61883 -i auto -vcodec libx264 -pix_fmt yuv420p -acodec libfaac -ar 44100 -f flv rtmp://192.168.1.1/testapp/teststream
ffmpeg version git-2014-02-10-1c1bb20 Copyright (c) 2000-2014 the FFmpeg developers
built on Feb 13 2014 08:44:16 with gcc 4.6 (Ubuntu/Linaro 4.6.3-1ubuntu5)
configuration: --prefix=/home/gamber/ffmpeg_build --extra-cflags=-I/home/gamber/ffmpeg_build/include --extra-ldflags=-L/home/gamber/ffmpeg_build/lib --bindir=/home/gamber/bin --extra-libs=-ldl --enable-gpl --enable-libass --enable-libfdk-aac --enable-libmp3lame --enable-libopus --enable-libtheora --enable-libvorbis --enable-libvpx --enable-libx264 --enable-nonfree --enable-x11grab --enable-libfaac --enable-libdc1394 --enable-libiec61883
libavutil 52. 63.101 / 52. 63.101
libavcodec 55. 50.100 / 55. 50.100
libavformat 55. 31.100 / 55. 31.100
libavdevice 55. 8.100 / 55. 8.100
libavfilter 4. 1.102 / 4. 1.102
libswscale 2. 5.101 / 2. 5.101
libswresample 0. 17.104 / 0. 17.104
libpostproc 52. 3.100 / 52. 3.100
No more input data available
[iec61883 @ 0x9be7ea0] Could not find codec parameters for stream 0 (Unknown: none): unknown codec
Consider increasing the value for the 'analyzeduration' and 'probesize' options
Input #0, iec61883, from 'auto':
Duration: N/A, start: 381.543600, bitrate: 384 kb/s
Program 100
No Program
Stream #0:0: Unknown: none
Stream #0:1: Video: mpeg2video (Main), yuv420p(tv, bt709), 1440x1080 [SAR 4:3 DAR 16:9], max. 25000 kb/s, 25 tbr, 90k tbn, 50 tbc
Stream #0:2: Audio: mp2, 48000 Hz, stereo, s16p, 384 kb/s
[libx264 @ 0x9bfee20] using SAR=4/3
[libx264 @ 0x9bfee20] using cpu capabilities: MMX2 SSE2Fast SSSE3 SSE4.2 AVX
[libx264 @ 0x9bfee20] profile High, level 4.0
[libx264 @ 0x9bfee20] 264 - core 142 r2 956c8d8 - H.264/MPEG-4 AVC codec - Copyleft 2003-2014 - http://www.videolan.org/x264.html - options: cabac=1 ref=3 deblock=1:0:0 analyse=0x3:0x113 me=hex subme=7 psy=1 psy_rd=1.00:0.00 mixed_ref=1 me_range=16 chroma_me=1 trellis=1 8x8dct=1 cqm=0 deadzone=21,11 fast_pskip=1 chroma_qp_offset=-2 threads=6 lookahead_threads=1 sliced_threads=0 nr=0 decimate=1 interlaced=0 bluray_compat=0 constrained_intra=0 bframes=3 b_pyramid=2 b_adapt=1 b_bias=0 direct=1 weightb=1 open_gop=0 weightp=2 keyint=250 keyint_min=25 scenecut=40 intra_refresh=0 rc_lookahead=40 rc=crf mbtree=1 crf=23.0 qcomp=0.60 qpmin=0 qpmax=69 qpstep=4 ip_ratio=1.40 aq=1:1.00
Output #0, flv, to 'rtmp://192.168.1.1/testapp/teststream':
Metadata:
encoder : Lavf55.31.100
Stream #0:0: Video: h264 (libx264) ([7][0][0][0] / 0x0007), yuv420p, 1440x1080 [SAR 4:3 DAR 16:9], q=-1--1, 1k tbn, 25 tbc
Stream #0:1: Audio: aac (libfaac) ([10][0][0][0] / 0x000A), 44100 Hz, stereo, s16, 128 kb/s
Stream mapping:
Stream #0:1 -> #0:0 (mpeg2video -> libx264)
Stream #0:2 -> #0:1 (mp2 -> libfaac)
Press [q] to stop, [?] for help
auto: Operation not permitted
[flv @ 0x9bfe6e0] Failed to update header with correct duration.
[flv @ 0x9bfe6e0] Failed to update header with correct filesize.
frame= 1 fps=0.0 q=28.0 Lsize= 19kB time=00:00:00.32 bitrate= 482.1kbits/s
video:16kB audio:2kB subtitle:0 data:0 global headers:0kB muxing overhead 2.683706%
[libx264 @ 0x9bfee20] frame I:1 Avg QP:21.87 size: 16012
[libx264 @ 0x9bfee20] mb I I16..4: 25.3% 74.3% 0.4%
[libx264 @ 0x9bfee20] 8x8 transform intra:74.3%
[libx264 @ 0x9bfee20] coded y,uvDC,uvAC intra: 29.5% 70.8% 1.0%
[libx264 @ 0x9bfee20] i16 v,h,dc,p: 47% 29% 19% 5%
[libx264 @ 0x9bfee20] i8 v,h,dc,ddl,ddr,vr,hd,vl,hu: 45% 13% 33% 2% 1% 2% 2% 1% 1%
[libx264 @ 0x9bfee20] i4 v,h,dc,ddl,ddr,vr,hd,vl,hu: 66% 8% 19% 1% 2% 1% 2% 0% 0%
[libx264 @ 0x9bfee20] i8c dc,h,v,p: 52% 24% 23% 2%
[libx264 @ 0x9bfee20] kb/s:3202.40
Если в качестве источника подсунуть что-то другое, то все проходит нормально. С той же вебки через v4l2 захватывает без проблем.
root@gamber:~# uname -a
Linux gamber 3.8.0-29-generic #42~precise1-Ubuntu SMP Wed Aug 14 15:31:16 UTC 2013 i686 i686 i386 GNU/Linux
root@gamber:~# lsb_release -a
No LSB modules are available.
Distributor ID: Ubuntu
Description: Ubuntu 12.04.3 LTS
Release: 12.04
Codename: precise