Files
Oliver Dunk 5bf419b385 Reorganize directory structure (#825)
* Remove docs folder.

This was a redirect from a GitHub pages site that does not appear
to be in use.

* Rename api folder to api-samples.

* Move examples to functional-samples folder.

* Move cookbook sample to functional-samples.

* Move tutorials to functional-samples folder.

* Move mv2 and apps folders to _archive.

* Rename tools folder to .repo.

* Move reference folder to functional-samples.

* Update README.

Update README with new relative links for reorg.

* Update README.md

Co-authored-by: amysteamdev <37001393+AmySteam@users.noreply.github.com>

---------

Co-authored-by: amysteamdev <37001393+AmySteam@users.noreply.github.com>
2023-02-03 10:58:04 -06:00

138 lines
3.7 KiB
JavaScript

// 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, options) {
if (!id) {
console.log('Access rejected.');
return;
}
var audioConstraint = {
mandatory: {
chromeMediaSource: 'desktop',
chromeMediaSourceId: id
}
};
console.log(options.canRequestAudioTrack);
if (!options.canRequestAudioTrack)
audioConstraint = false;
navigator.webkitGetUserMedia({
audio: audioConstraint,
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');
try {
video.srcObject = stream;
} catch (error) {
video.src = URL.createObjectURL(stream);
}
stream.onended = function() { console.log('Ended'); };
pc1 = new RTCPeerConnection();
pc1.onicecandidate = function(event) {
onIceCandidate(pc1, event);
};
pc2 = new RTCPeerConnection();
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');
try {
remoteVideo.srcObject = event.stream;
} catch (error) {
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);
}
}