5

我想使用Peer.js在 WebRTC 上制作一个简单的纯音频流。我在本地运行简单的 PeerServer。

以下在 Firefox 30 中运行良好,但我无法在Chrome 35中运行。我预计 PeerJS 设置有问题,但 Chrome -> Firefox 工作得非常好,而 Chrome -> Chrome 似乎发送流,但不会通过扬声器播放。

设置 getUserMedia 注意:取消注释下面的这些行会让我听到 Chrome 和 Firefox 中的环回。

navigator.getUserMedia = (navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia);
window.AudioContext = window.AudioContext || window.webkitAudioContext;

if(navigator.getUserMedia) {
    navigator.getUserMedia({video: false, audio: true}, getMediaSuccess, getMediaError);
} else {
    alert('getUserMedia not supported.');
}

var localMediaStream;
//var audioContext = new AudioContext();

function getMediaSuccess(mediaStream) {
    //var microphone = audioContext.createMediaStreamSource(mediaStream);
    //microphone.connect(audioContext.destination);
    localMediaStream = mediaStream;
}

function getMediaError(err) {
    alert('getUserMedia error. See console.');
    console.error(err);
}

建立连接

var peer = new Peer({host: '192.168.1.129', port: 9000});

peer.on('open', function(id) {
    console.log('My ID:', id);
});

peer.on('call', function(call) {
    console.log('answering call with', localMediaStream);
    call.answer(localMediaStream);
    //THIS WORKS IN CHROME, localMediaStream exists

    call.on('stream', function(stream) {
        console.log('streamRecieved', stream);
        //THIS WORKS IN CHROME, the stream has come through

        var audioContext = new AudioContext();
        var audioStream = audioContext.createMediaStreamSource(stream);
        audioStream.connect(audioContext.destination);
        //I HEAR AUDIO IN FIREFOX, BUT NOT CHROME

    });

    call.on('error', function(err) {
        console.log(err);
        //LOGS NO ERRORS
    });
});

function connect(id) {
    var voiceStream = peer.call(id, localMediaStream);
}
4

3 回答 3

7

即使在 Chrome 73 中,这似乎仍然是一个问题。

现在拯救我的解决方案是将媒体流连接到静音的 HTML 音频元素。这似乎使流工作并且音频开始流入 WebAudio 节点。

这看起来像:

let a = new Audio();
a.muted = true;
a.srcObject = stream;
a.addEventListener('canplaythrough', () => {
    a = null;
});

let audioStream = audioContext.createMediaStreamSource(stream);
audioStream.connect(audioContext.destination);

JSFiddle:https ://jsfiddle.net/jmcker/4naq5ozc/


原始 Chromium 问题和解决方法: https ://bugs.chromium.org/p/chromium/issues/detail?id=121673#c121

新的 Chromium 问题:https ://bugs.chromium.org/p/chromium/issues/detail?id=687574 https://bugs.chromium.org/p/chromium/issues/detail?id=933677

于 2019-04-12T05:24:46.687 回答
6

在 Chrome 中,当前存在一个已知错误,即无法通过 AudioAPI 访问从对等连接收集的远程音频流。

关于该错误的最新评论:

我们正在努力实现该功能。这需要很长时间的原因是我们需要先将APM移动到chrome,实现一个渲染混合器从WebRtc获取未混合的数据,然后我们可以将远程音频流连接到webaudio。

它最近在 Firefox 中进行了修补,因为我记得这在过去也是一个问题。

于 2014-06-20T13:31:55.307 回答
-1

我无法使用网络音频播放流,但我确实设法使用基本音频元素播放它:

 var audio = new Audio();                                                  
 audio.src = (URL || webkitURL || mozURL).createObjectURL(remoteStream);
 audio.play();
于 2015-08-21T09:09:20.893 回答