blob: a6d8e4717dbddaedddec07a92f605056b63fb86c [file] [log] [blame]
// Copyright 2013 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
'use strict';
const DESKTOP_MEDIA = ['screen', 'window', 'tab', 'audio'];
var pending_request_id = null;
var pc1 = null;
var pc2 = null;
// Launch the chooseDesktopMedia().
document.querySelector('#start').addEventListener('click', function(event) {
pending_request_id = chrome.desktopCapture.chooseDesktopMedia(
DESKTOP_MEDIA, onAccessApproved);
});
document.querySelector('#cancel').addEventListener('click', function(event) {
if (pending_request_id != null) {
chrome.desktopCapture.cancelChooseDesktopMedia(pending_request_id);
}
});
document.querySelector('#startFromBackgroundPage')
.addEventListener('click', function(event) {
chrome.runtime.sendMessage(
{}, function(response) { console.log(response.farewell); });
});
// Launch webkitGetUserMedia() based on selected media id.
function onAccessApproved(id) {
if (!id) {
console.log('Access rejected.');
return;
}
navigator.webkitGetUserMedia({
audio:{
mandatory: {
chromeMediaSource: 'desktop',
chromeMediaSourceId: id} },
video: {
mandatory: {
chromeMediaSource: 'desktop',
chromeMediaSourceId: id,
maxWidth:screen.width,
maxHeight:screen.height} }
}, gotStream, getUserMediaError);
}
function getUserMediaError(error) {
console.log('navigator.webkitGetUserMedia() errot: ', error);
}
// Capture video/audio of media and initialize RTC communication.
function gotStream(stream) {
console.log('Received local stream', stream);
var video = document.querySelector('video');
video.src = URL.createObjectURL(stream);
stream.onended = function() { console.log('Ended'); };
var servers = null;
pc1 = new webkitRTCPeerConnection(servers);
pc1.onicecandidate = function(event) {
onIceCandidate(pc1, event);
};
pc2 = new webkitRTCPeerConnection(servers);
pc2.onicecandidate = function(event) {
onIceCandidate(pc2, event);
};
pc1.oniceconnectionstatechange = function(event) {
onIceStateChange(pc1, event);
};
pc2.oniceconnectionstatechange = function(event) {
onIceStateChange(pc2, event);
};
pc2.onaddstream = gotRemoteStream;
pc1.addStream(stream);
pc1.createOffer(onCreateOfferSuccess, function() {});
}
function onCreateOfferSuccess(desc) {
pc1.setLocalDescription(desc);
pc2.setRemoteDescription(desc);
// Since the 'remote' side has no media stream we need
// to pass in the right constraints in order for it to
// accept the incoming offer of audio and video.
var sdpConstraints = {
'mandatory': {
'OfferToReceiveAudio': true,
'OfferToReceiveVideo': true
}
};
pc2.createAnswer(onCreateAnswerSuccess, function(){}, sdpConstraints);
}
function gotRemoteStream(event) {
// Call the polyfill wrapper to attach the media stream to this element.
console.log('hitting this code');
remoteVideo.src = URL.createObjectURL(event.stream);
}
function onCreateAnswerSuccess(desc) {
pc2.setLocalDescription(desc);
pc1.setRemoteDescription(desc);
}
function onIceCandidate(pc, event) {
if (event.candidate) {
var remotePC = (pc === pc1) ? pc2 : pc1;
remotePC.addIceCandidate(new RTCIceCandidate(event.candidate));
}
}
function onIceStateChange(pc, event) {
if (pc) {
console.log('ICE state change event: ', event);
}
}