我正在创建一个 Web 应用程序,用于使用 WebRTC 通过智能手机进行监控,而对于我正在使用 socket.io 的信令服务器。
当我发送一个流时,我在接收这个流的“watch”页面上创建了一个RTCPeerConnection对象。我在单独的页面上发送流。用户最多可以附加来自智能手机的四个流,因此在“观看”页面上最多有四个RTCPeerConnection对象。
一旦出现“传输”页面的报价,就会自动接收流,然后在“监视”页面上创建RTCPeerConnection对象并连接到标准 WebRTC 模式。
“传输”页面:
function onCreateOfferSuccess(sdp){
//console.log(sdp);
pc.setLocalDescription(new RTCSessionDescription(sdp));
console.log('ask');
socket.emit('ask', {"sdp":JSON.stringify(pc.localDescription),
"user": loggedUserID,
"fromSocket": ownSocket});
}
“观看”页面:
socket.on('ask', function(offer){
if (offer.user === loggedUserID){
TempDescriptions = JSON.parse(offer.sdp);
console.log(TempDescriptions)
currTransmiterSocket = offer.fromSocket;
console.log(currTransmiterSocket);
getStream();
}
function getStream(){
try {
setTimeout(function(){
console.log(time, 'getStream()');
connection = getPeerConnection();
connection.setRemoteDescription(
new RTCSessionDescription(TempDescriptions),
function() {
connection.createAnswer(gotDescription, function(error){
console.log(error)
});
}, function(error){
console.log(error)
});
}, getStreamDelay*3000)
getStreamDelay++
}
catch(err){
console.log(err);
}
};
我的 Web 应用程序需要这样的功能,当我们退出“观看”页面并再次返回时,必须显示所有以前包含的流。
为了实现这个功能,我使用了oniceconnectionstatechange方法。如果流断开连接,则执行iceRestart函数,该函数使用选项{iceRestart: true}创建报价
“传输”页面:
var options_with_restart = {offerToReceiveAudio: false,
offerToReceiveVideo: true,
iceRestart: true};
function iceRestart(event){
try{
setTimeout(function(){
pc.createOffer(options_with_restart).then(onCreateOfferSuccess, onCreateOfferError);
},1000);
} catch(error) {
console.log(error);
问题是当我重新启动“观看”页面时,所有页面“传输”立即发送询问。尽管一次创建了四个RTCPeerConnection对象(假设用户发送了四个流),但只连接了一个对象。
我已经为这个问题苦苦挣扎了好几天。如上面的代码所示,我尝试在对getStream()函数的后续调用中设置增加的时间延迟,我尝试signallingState
在执行getStream()函数之前检查连接,我尝试了其他几种方法,但都没有奏效。
如果您需要我的代码的某些部分来提供帮助,请写信。
编辑:
“观看”页面中的 gotDescription() 方法。
function gotDescription(sdp) {
try{
connection.setLocalDescription(sdp,
function() {
registerIceCandidate();
socket.emit('response', {"sdp": sdp,
"user": loggedUserID,
"fromSocket": ownSocket,
"toSocket": currTransmiterSocket});
}, function(error){
console.log(error)
});
} catch(err){
console.log(err);
}
}
我console.log
加上RTCPeerConnection object
控制台输出: https ://i.stack.imgur.com/dQXkE.png 1
日志显示signalingState
连接是“稳定的”,但是当我开发对象时,signalingState
等于“have-remote-offer”