mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-21 06:38:19 +00:00
sendrecv/js: Call getUserMedia on incoming call
Instead of registering it on page load. This will allow us to add an option for users to override the default constraints later. This is also generally nicer because the browser won't open the webcam immediately when you load the page and keep recording from it.
This commit is contained in:
parent
563826deaf
commit
bd6deaca46
1 changed files with 20 additions and 13 deletions
|
@ -13,6 +13,7 @@ var peer_connection = null;
|
||||||
var rtc_configuration = {iceServers: [{urls: "stun:stun.services.mozilla.com"},
|
var rtc_configuration = {iceServers: [{urls: "stun:stun.services.mozilla.com"},
|
||||||
{urls: "stun:stun.l.google.com:19302"}]};
|
{urls: "stun:stun.l.google.com:19302"}]};
|
||||||
var ws_conn;
|
var ws_conn;
|
||||||
|
// Promise for local stream after constraints are approved by the user
|
||||||
var local_stream;
|
var local_stream;
|
||||||
var peer_id;
|
var peer_id;
|
||||||
|
|
||||||
|
@ -54,7 +55,10 @@ function onIncomingSDP(sdp) {
|
||||||
if (sdp.type != "offer")
|
if (sdp.type != "offer")
|
||||||
return;
|
return;
|
||||||
setStatus("Got SDP offer, creating answer");
|
setStatus("Got SDP offer, creating answer");
|
||||||
peer_connection.createAnswer().then(onLocalDescription).catch(setStatus);
|
local_stream.then((stream) => {
|
||||||
|
peer_connection.createAnswer()
|
||||||
|
.then(onLocalDescription).catch(setStatus);
|
||||||
|
}).catch(errorUserMediaHandler);
|
||||||
}).catch(setStatus);
|
}).catch(setStatus);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -130,6 +134,17 @@ function onServerError(event) {
|
||||||
window.setTimeout(websocketServerConnect, 3000);
|
window.setTimeout(websocketServerConnect, 3000);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function getLocalStream() {
|
||||||
|
var constraints = {video: true, audio: true};
|
||||||
|
|
||||||
|
// Add local stream
|
||||||
|
if (navigator.mediaDevices.getUserMedia) {
|
||||||
|
return navigator.mediaDevices.getUserMedia(constraints);
|
||||||
|
} else {
|
||||||
|
errorUserMediaHandler();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function websocketServerConnect() {
|
function websocketServerConnect() {
|
||||||
connect_attempts++;
|
connect_attempts++;
|
||||||
if (connect_attempts > 3) {
|
if (connect_attempts > 3) {
|
||||||
|
@ -156,17 +171,6 @@ function websocketServerConnect() {
|
||||||
ws_conn.addEventListener('error', onServerError);
|
ws_conn.addEventListener('error', onServerError);
|
||||||
ws_conn.addEventListener('message', onServerMessage);
|
ws_conn.addEventListener('message', onServerMessage);
|
||||||
ws_conn.addEventListener('close', onServerClose);
|
ws_conn.addEventListener('close', onServerClose);
|
||||||
|
|
||||||
var constraints = {video: true, audio: true};
|
|
||||||
|
|
||||||
// Add local stream
|
|
||||||
if (navigator.mediaDevices.getUserMedia) {
|
|
||||||
navigator.mediaDevices.getUserMedia(constraints)
|
|
||||||
.then((stream) => { local_stream = stream })
|
|
||||||
.catch(errorUserMediaHandler);
|
|
||||||
} else {
|
|
||||||
errorUserMediaHandler();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function onRemoteStreamAdded(event) {
|
function onRemoteStreamAdded(event) {
|
||||||
|
@ -192,7 +196,10 @@ function createCall(msg) {
|
||||||
peer_connection = new RTCPeerConnection(rtc_configuration);
|
peer_connection = new RTCPeerConnection(rtc_configuration);
|
||||||
peer_connection.onaddstream = onRemoteStreamAdded;
|
peer_connection.onaddstream = onRemoteStreamAdded;
|
||||||
/* Send our video/audio to the other peer */
|
/* Send our video/audio to the other peer */
|
||||||
peer_connection.addStream(local_stream);
|
local_stream = getLocalStream().then((stream) => {
|
||||||
|
console.log('Adding local stream');
|
||||||
|
peer_connection.addStream(stream);
|
||||||
|
}).catch(errorUserMediaHandler);
|
||||||
|
|
||||||
if (!msg.sdp) {
|
if (!msg.sdp) {
|
||||||
console.log("WARNING: First message wasn't an SDP message!?");
|
console.log("WARNING: First message wasn't an SDP message!?");
|
||||||
|
|
Loading…
Reference in a new issue