Allows to switch to desktop stream from the very beginning of the conference.
This commit is contained in:
parent
d5a1fe636d
commit
1f51021041
6
app.js
6
app.js
|
@ -221,7 +221,9 @@ $(document).bind('remotestreamadded.jingle', function (event, data, sid) {
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (data.stream.id !== 'mixedmslabel') {
|
if (data.stream.id !== 'mixedmslabel') {
|
||||||
console.warn('can not associate stream', data.stream.id, 'with a participant');
|
console.error('can not associate stream', data.stream.id, 'with a participant');
|
||||||
|
// We don't want to add it here since it will cause troubles
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
// FIXME: for the mixed ms we dont need a video -- currently
|
// FIXME: for the mixed ms we dont need a video -- currently
|
||||||
container = document.createElement('span');
|
container = document.createElement('span');
|
||||||
|
@ -448,6 +450,8 @@ $(document).bind('callactive.jingle', function (event, videoelem, sid) {
|
||||||
|
|
||||||
$(document).bind('callterminated.jingle', function (event, sid, reason) {
|
$(document).bind('callterminated.jingle', function (event, sid, reason) {
|
||||||
// FIXME
|
// FIXME
|
||||||
|
focus = null;
|
||||||
|
activecall = null;
|
||||||
});
|
});
|
||||||
|
|
||||||
$(document).bind('setLocalDescription.jingle', function (event, sid) {
|
$(document).bind('setLocalDescription.jingle', function (event, sid) {
|
||||||
|
|
|
@ -42,14 +42,17 @@ function setDesktopSharing(method) {
|
||||||
if(method == "ext") {
|
if(method == "ext") {
|
||||||
if(RTC.browser === 'chrome') {
|
if(RTC.browser === 'chrome') {
|
||||||
obtainDesktopStream = obtainScreenFromExtension;
|
obtainDesktopStream = obtainScreenFromExtension;
|
||||||
|
console.info("Using Chrome extension for desktop sharing");
|
||||||
} else {
|
} else {
|
||||||
console.log("Chrome is required to use extension method");
|
console.error("Chrome is required to use extension method");
|
||||||
obtainDesktopStream = null;
|
obtainDesktopStream = null;
|
||||||
}
|
}
|
||||||
} else if(method == "webrtc") {
|
} else if(method == "webrtc") {
|
||||||
obtainDesktopStream = obtainWebRTCScreen;
|
obtainDesktopStream = obtainWebRTCScreen;
|
||||||
|
console.info("Using WebRTC for desktop sharing");
|
||||||
} else {
|
} else {
|
||||||
obtainDesktopStream = null;
|
obtainDesktopStream = null;
|
||||||
|
console.info("Desktop sharing disabled");
|
||||||
}
|
}
|
||||||
showDesktopSharingButton();
|
showDesktopSharingButton();
|
||||||
}
|
}
|
||||||
|
@ -66,11 +69,8 @@ function showDesktopSharingButton() {
|
||||||
* Toggles screen sharing.
|
* Toggles screen sharing.
|
||||||
*/
|
*/
|
||||||
function toggleScreenSharing() {
|
function toggleScreenSharing() {
|
||||||
if (!(connection && connection.connected
|
if (switchInProgress || !obtainDesktopStream) {
|
||||||
&& !switchInProgress
|
console.warn("Switch in progress or no method defined");
|
||||||
&& getConferenceHandler().peerconnection.signalingState == 'stable'
|
|
||||||
&& getConferenceHandler().peerconnection.iceConnectionState == 'connected'
|
|
||||||
&& obtainDesktopStream )) {
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
switchInProgress = true;
|
switchInProgress = true;
|
||||||
|
@ -85,7 +85,7 @@ function toggleScreenSharing() {
|
||||||
// Hook 'ended' event to restore camera when screen stream stops
|
// Hook 'ended' event to restore camera when screen stream stops
|
||||||
stream.addEventListener('ended',
|
stream.addEventListener('ended',
|
||||||
function(e) {
|
function(e) {
|
||||||
if(!switchInProgress) {
|
if(!switchInProgress && isUsingScreenStream) {
|
||||||
toggleScreenSharing();
|
toggleScreenSharing();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -118,13 +118,24 @@ function newStreamCreated(stream) {
|
||||||
|
|
||||||
change_local_video(stream, !isUsingScreenStream);
|
change_local_video(stream, !isUsingScreenStream);
|
||||||
|
|
||||||
|
var conferenceHandler = getConferenceHandler();
|
||||||
|
if(conferenceHandler) {
|
||||||
|
console.info("Conference considered as started");
|
||||||
// FIXME: will block switchInProgress on true value in case of exception
|
// FIXME: will block switchInProgress on true value in case of exception
|
||||||
getConferenceHandler().switchStreams(
|
conferenceHandler.switchStreams(stream, oldStream, streamSwitchDone);
|
||||||
stream, oldStream,
|
} else {
|
||||||
function() {
|
// We are done immediately
|
||||||
// Switch operation has finished
|
console.error("No conference handler");
|
||||||
|
streamSwitchDone();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function streamSwitchDone() {
|
||||||
|
//window.setTimeout(
|
||||||
|
// function() {
|
||||||
switchInProgress = false;
|
switchInProgress = false;
|
||||||
});
|
// }, 100
|
||||||
|
//);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -49,7 +49,10 @@ SessionBase.prototype.switchStreams = function (new_stream, oldStream, success_c
|
||||||
var self = this;
|
var self = this;
|
||||||
|
|
||||||
// Remember SDP to figure out added/removed SSRCs
|
// Remember SDP to figure out added/removed SSRCs
|
||||||
var oldSdp = new SDP(self.peerconnection.localDescription.sdp);
|
var oldSdp = null;
|
||||||
|
if(self.peerconnection.localDescription) {
|
||||||
|
oldSdp = new SDP(self.peerconnection.localDescription.sdp);
|
||||||
|
}
|
||||||
|
|
||||||
// Stop the stream to trigger onended event for old stream
|
// Stop the stream to trigger onended event for old stream
|
||||||
oldStream.stop();
|
oldStream.stop();
|
||||||
|
@ -63,6 +66,12 @@ SessionBase.prototype.switchStreams = function (new_stream, oldStream, success_c
|
||||||
self.connection.jingle.localStreams.push(self.connection.jingle.localAudio);
|
self.connection.jingle.localStreams.push(self.connection.jingle.localAudio);
|
||||||
self.connection.jingle.localStreams.push(self.connection.jingle.localVideo);
|
self.connection.jingle.localStreams.push(self.connection.jingle.localVideo);
|
||||||
|
|
||||||
|
// Conference is not active
|
||||||
|
if(!oldSdp) {
|
||||||
|
success_callback();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
self.peerconnection.switchstreams = true;
|
self.peerconnection.switchstreams = true;
|
||||||
self.modifySources(function() {
|
self.modifySources(function() {
|
||||||
console.log('modify sources done');
|
console.log('modify sources done');
|
||||||
|
|
Loading…
Reference in New Issue