Nodejs - ffmpeg - невозможно преобразовать веб-камеру в файл hls в реальном времени - PullRequest
0 голосов
/ 26 мая 2020

Хорошо, короче говоря: мне нужно иметь возможность принимать видеопоток с моего USB-порта и предлагать его моему интерфейсу (React) с использованием HLS / RTMP / WebRT C. Я выбрал HLS, потому что он, кажется, имеет наименьшее количество зависимостей, и он может в конечном итоге работать на Pi, поэтому простота - это хорошо. кодировать в hls. К сожалению, в результате я получаю это.

stderr: ffmpeg version 4.2.3
stderr:  Copyright (c) 2000-2020 the FFmpeg developers
  built with Apple clang version 11.0.3 (clang-1103.0.32.59)
  configuration: --prefix=/usr/local/Cellar/ffmpeg/4.2.3 --enable-shared --enable-pthreads --enable-version3 --enable-avresample --cc=clang --host-cflags=-fno-stack-check --host-ldflags= --enable-ffplay --enable-gnutls --enable-gpl --enable-libaom --enable-libbluray --enable-libdav1d --enable-libmp3lame --enable-libopus --enable-librubberband --enable-libsnappy --enable-libsrt --enable-libtesseract --enable-libtheora --enable-libvidstab --enable-libvorbis --enable-libvpx --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxvid --enable-lzma --enable-libfontconfig --enable-libfreetype --enable-frei0r --enable-libass --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-librtmp --enable-libspeex --enable-libsoxr --enable-videotoolbox --disable-libjack --disable-indev=jack
  libavutil      56. 31.100 / 56. 31.100
  libavcodec     58. 54.100 / 58. 54.100
  libavformat    58. 29.100 / 58. 29.100
  libavdevice    58.  8.100 / 58.  8.100
  libavfilter     7. 57.100 /  7. 57.100
  libavresample   4.  0.  0 /  4.  0.  0
  libswscale      5.  5.100 /  5.  5.100
  libswresample   3.  5.100 /  3.  5.100
  libpostproc    55.  5.100 / 55.  5.100

stderr: [AVFoundation input device @ 0x7fcac2604600] Configuration of video device failed, falling back to default.

child process exited with signal SIGABRT

Я понятия не имею, почему я получаю сигнал SIGABRT, но когда я вручную ввожу устройство (-i «FaceTime HD Camera»), я не понимаю 'не получаю ошибку конфигурации, но процесс завершается без выполнения обычного frame= 38 fps=0.0 q=27.0 size=N/A time=00:00:00.46 bitrate=N/A speed=0.869x, он просто завершается с SIGABRT.

Если я набираю точную команду (ffmpeg -f avfoundation -framerate 30 -i "0" -c:v libx264 -crf 21 -preset veryfast -f hls -hls_time 4 -hls_playlist_type event out/test.m3u8), все работает, как ожидалось, и я получаю вывод.

Я читал здесь , что это могло быть из-за сборки c stati, но я не совсем уверен, почему это может вызвать проблему. Для справки, это на MacOS и, скорее всего, со временем перейдет на Ubuntu.

И идея, почему это происходит? Спасибо.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...