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:
Nirbheek Chauhan 2018-03-31 13:52:02 +05:30
parent 563826deaf
commit bd6deaca46

View file

@ -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!?");