2012-02-27 39 views
5

我正尝试使用gstreamer-java构建会议解决方案。带有多个UDP接收器的GStreamer管道(包含图像)

我被困在音频部分,因为每个参与者只应该听到其他人,而不是他自己。

我构建了一个管道(请参阅包含的图像文件)。

如果我在末尾放置一个rtpmuxer和一个单独的udpsink/multiudpsink,那么整个构造都可以工作。但是在这种情况下,每个参与者都会获得所有音频流的复用(如预期的那样)。

如果我像图片一样做,就不会创建数据包(使用wireshark进行检查)。我在推理中的错误在哪里?

(你可以将图像拉到另一个选项卡可以阅读文本)

debug-image of the pipe

+1

我得到了管道在命令行工作,所以我的错误似乎是在我的Java代码。我将发布工作流程作为每个可能感兴趣的人的答案...... – 2012-02-28 10:47:58

回答

3

其管道的地狱,但它确实,有什么它应该。我添加了一个点文件转储,因此您可以为了方便而提取管道图像。

GST_DEBUG_DUMP_DOT_DIR=/tmp/ gst-launch --gst-debug-level=2 gstrtpbin name=rtpbin latency=2 sync=false udpsrc name=udpsrc0 caps="application/x-rtp, media=audio, clock-rate=8000, payload=0, encoding-name=PCMU" port=5000 ! rtpbin.recv_rtp_sink_0 rtpbin. ! rtppcmudepay ! mulawdec ! tee name=t0 ! queue max-size-buffers=150 ! liveadder name=mix1 ! mulawenc ! rtppcmupay ! udpsink name=udpsink1 host=192.168.0.101 port=5050 t0. ! queue max-size-buffers=150 ! liveadder name=mix2 ! mulawenc ! rtppcmupay ! udpsink name=udpsink2 host=192.168.0.112 port=5050 rtpbin. ! rtppcmudepay ! mulawdec ! tee name=t1 ! queue max-size-buffers=150 ! liveadder name=mix0 ! mulawenc ! rtppcmupay ! udpsink name=udpsink0 host=192.168.0.101 port=5051 t1. ! queue max-size-buffers=150 ! mix2. rtpbin. ! rtppcmudepay ! mulawdec ! tee name=t2 ! queue max-size-buffers=150 ! mix0. t2. ! queue max-size-buffers=150 ! mix1.