audio - 使用 FFMPEG 将 16 channel 音频输入源拆分为 4 个单独的 4 channel 音频源以进行流式传输

标签 audio ffmpeg streaming audio-streaming rtmp

我希望有人能帮帮忙

我目前正在尝试将来自单独机器的 16ch Dante 音频输入拆分为 4 个不同的音频流,然后我可以使用这些音频流通过 RTMP TX 到 Wowza 进行 MPEG-DASH 编码,目前我只是想将它们拆分成文件,我稍后将添加 RTMP 流。

我目前遇到的最大问题是 FFMPEG 从我的输入字符串中返回了这个错误

Filter channelsplit:WR has an unconnected output

这是我当前的输入字符串
ffmpeg -f dshow -i audio="Dante Via Receive (Dante Via)" -filter_complex "[0:a]channelsplit=channel_layout=hexadecagonal[FL][FR][FC][BL][BR][BC][SL][SR][TFL][TFC][TFR][TBL][TBC][TBR][WL][WR]" -map "[FL][FR][FC][BL]" 1-4.wav -map "[BR][BC][SL][SR]" 5-8.wav -map "[TFL][TFC][TFR][TBL]" 9-12.wav -map "[TBC][TBR][WL][WR]" 13-16.wav

这是完整的 FFMPEG 输出
ffmpeg version git-2019-12-26-b0d0d7e Copyright (c) 2000-2019 the FFmpeg developers
  built with gcc 9.2.1 (GCC) 20191125
  configuration: --enable-gpl --enable-version3 --enable-sdl2 --enable-fontconfig --enable-gnutls --enable-iconv --enable-libass --enable-libdav1d --enable-libbluray --enable-libfreetype --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-libopus --enable-libshine --enable-libsnappy --enable-libsoxr --enable-libtheora --enable-libtwolame --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxml2 --enable-libzimg --enable-lzma --enable-zlib --enable-gmp --enable-libvidstab --enable-libvorbis --enable-libvo-amrwbenc --enable-libmysofa --enable-libspeex --enable-libxvid --enable-libaom --enable-libmfx --enable-ffnvcodec --enable-cuvid --enable-d3d11va --enable-nvenc --enable-nvdec --enable-dxva2 --enable-avisynth --enable-libopenmpt --enable-amf
  libavutil      56. 37.100 / 56. 37.100
  libavcodec     58. 65.100 / 58. 65.100
  libavformat    58. 35.101 / 58. 35.101
  libavdevice    58.  9.101 / 58.  9.101
  libavfilter     7. 69.101 /  7. 69.101
  libswscale      5.  6.100 /  5.  6.100
  libswresample   3.  6.100 /  3.  6.100
  libpostproc    55.  6.100 / 55.  6.100
Guessed Channel Layout for Input Stream #0.0 : stereo
Input #0, dshow, from 'audio=Dante Via Receive (Dante Via)':
  Duration: N/A, start: 103082.790000, bitrate: 1411 kb/s
    Stream #0:0: Audio: pcm_s16le, 44100 Hz, stereo, s16, 1411 kb/s
File '1-4.wav' already exists. Overwrite? [y/N] y
File '5-8.wav' already exists. Overwrite? [y/N] y
File '9-12.wav' already exists. Overwrite? [y/N] y
File '13-16.wav' already exists. Overwrite? [y/N] y
Filter channelsplit:WR has an unconnected output 

我也遇到了 FFMPEG 猜测声道数是立体声的问题,这是不正确的,但我在弄清楚如何将输入流定义为 16 声道音频时遇到了问题

对此的任何帮助都会受到极大的欢迎

干杯

最佳答案

ffmpeg -f dshow -channels 16 -i audio="Dante Via Receive (Dante Via)" -filter_complex "[0:a]channelmap=0|1|2|3[1-4];[0:a]channelmap=4|5|6|7[5-8];[0:a]channelmap=8|9|10|11[9-12];[0:a]channelmap=12|13|14|15[13-16]" -map "[1-4]" 1-4.wav -map "[5-8]" 5-8.wav -map "[9-12]" 9-12.wav -map "[13-16]" 13-16.wav
  • 尝试添加 -channels 16 dshow 输入选项。
  • 过滤器输出标签不能在 -map 中组合, 所以所有的混合过滤器和给每个 -map一个标签。
  • channelsplit仅将 channel 作为单独的流输出,并且不会将多个 channel 混合为单个流,因此 channelmap改为使用。
  • 我没有 dshow 所以我无法测试这个。
  • 关于audio - 使用 FFMPEG 将 16 channel 音频输入源拆分为 4 个单独的 4 channel 音频源以进行流式传输,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59532755/

    相关文章:

    video - GPS信息在视频帧中丢失

    sql - Apache Calcite 是否提供添加自定义子句或语句的方法?

    video - H.264 (.mp4) 视频流的 MPEG-TS 和 RTP 之间的区别?

    wcf - 在 Biztalk WCF 适配器中启用流式处理

    java - 在java中读取wav文件

    c++ - SFML 声音不播放

    java - 使用java jdbc从mysql下载blob(音频)。一切顺利,但我无法播放音频

    java - AudioPlayer无法在使用Java 1.6的Mac上播放声音

    swift - 在构建另一个数组的函数中使用字符串数组作为函数参数

    ffmpeg - 静止图像到视频以供存储 - 但返回静止图像以供查看