我使用PeerJS成功建立了两个对等方之间的连接,但是每当我尝试将MediaStream对象传递给.call
函数时,都会出现此错误:
无法在“ RTCPeerConnection”上执行“ addStream”:参数1为
不是'MediaStream'类型的
一切正常,连接确实建立,两个对等方都通过'open'
事件从彼此接收消息。唯一不起作用的是peer.call()
函数。在请求许可后可以正确捕获麦克风。
我在这里犯了某种错误吗?我将不胜感激。谢谢。
这是我的代码:
var media;
jQuery(document).ready(function() {
var peer = new Peer({
key: 'xxxxxxxxxxxxx'
});
media = navigator.mediaDevices.getUserMedia({
audio: true,
video: false
});
peer.on('open', function(id) {
console.log('My peer ID is: ' + id);
});
var conn = peer.connect(callID);
conn.on('open', function() {
// Receive messages
conn.on('data', function(data) {
console.log('Received', data);
});
// Send messages
conn.send('Hello!');
});
console.log(typeof(media));
var call = peer.call(callID, media);
peer.on('error', function(err) {
console.log(err);
});
});
最佳答案
我希望看到console.log(typeof(media));
的输出。
根据MDN website,似乎以下行将返回Promise
而不是MediaStream
:
media = navigator.mediaDevices.getUserMedia({audio: true, video: false});
以下应该工作:
var media;
jQuery(document).ready(function() {
var peer = new Peer({
key: 'xxxxxxxxxxxxx'
});
navigator.mediaDevices.getUserMedia({
audio: true,
video: false
})
.then(function(mediaStream) {
peer.on('open', function(id) {
console.log('My peer ID is: ' + id);
});
var conn = peer.connect(callID);
conn.on('open', function() {
// Receive messages
conn.on('data', function(data) {
console.log('Received', data);
});
// Send messages
conn.send('Hello!');
});
console.log(typeof(media));
var call = peer.call(callID, mediaStream);
peer.on('error', function(err) {
console.log(err);
});
});
});