Во-первых, addStream
и onaddstream
устарели и не будут работать в других браузерах.Вместо этого используйте addTrack и ontrack .
Секунда, время.
Вы звоните peerConn.createOffer()
до peerConn.addStream(stream)
, чтобы треки не выбиралисьup.
То же самое с peerConn.createAnswer()
до peerConn.addStream(stream)
.
Наконец, смешивание обратных вызовов и обещаний приводит в замешательство порядок вещей здесь.Попробуйте:
const peerConn = new RTCPeerConnection(peerConnCfg);
peerConn.ontrack = function (event) {
alert('new stream added! ' + event.streams[0]);
}
function initiate_call() {
navigator.mediaDevices.getUserMedia({audio: true, video: true})
.then(function (stream) {
localVideo.srcObject = stream;
for (const track of stream.getTracks()) {
peerConn.addTrack(track, stream);
}
return peerConn.createOffer();
})
.then(function (offer) {
// signaling and invite
return peerConn.setLocalDescription(off);
})
.catch(function (err) {
console.log(err.message);
});
}
function accept_send_answer(offer) {
peerConn.setRemoteDescription(offer)
.then(function () {
return navigator.mediaDevices.getUserMedia({audio: true, video: true});
})
.then(function (stream) {
video.srcObject = stream;
for (const track of stream.getTracks()) {
peerConn.addTrack(track, stream);
}
return peerConn.createAnswer();
})
.then(function (answer) {
//signaling to caller and send answer
return peerConn.setLocalDescription(answer);
})
.catch(function (err) {
console.log(err.message);
});
}
Обратите внимание, что в вашем коде (и моем ответе) по-прежнему отсутствуют критические фрагменты: обмен ледяными кандидатами, и вы не показываете код setRemoteDescription(answer)
для завершения переговоровloop.
Обратите внимание, что в большинстве примеров, как правило, используется один и тот же JS с обеих сторон, как, например, это рабочая скрипка с использованием iframe postMessage для сигнализации.