-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.js
55 lines (45 loc) · 1.67 KB
/
main.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
let channel = new MessageChannel();
let track;
let sendPortBtn = document.getElementById("sendPort");
let startTrackBtn = document.getElementById("startTrack");
startTrackBtn.disabled = true;
let transferBtn = document.getElementById("transfer");
transferBtn.disabled = true;
const frameOrigin =
document.location.host == "localhost:8000" ? "http://localhost:8001" : "https://tonyherre.github.io/mst-transfer-sample";
document.getElementById("subframe").src = frameOrigin + "/frame.html";
function isTrackTransferSupported() {
let track = document.createElement("canvas").captureStream().getTracks()[0];
let port = new MessageChannel().port1;
try {
port.postMessage({},[track]);
} catch(e) {
console.log("Transfer support check failed: ", e);
return false;
}
return true;
}
onload = () => {
if (!isTrackTransferSupported()) {
sendPortBtn.disabled = true;
window.statusMsg = document.getElementById("status");
statusMsg.innerText = "MediaStreamTrack Transfer is not supported by this browser.";
}
};
function sendPort() {
sendPortBtn.disabled = true;
let frame = document.getElementById("subframe");
frame.contentWindow.postMessage({name:"port", port: channel.port2}, frameOrigin, [channel.port2]);
startTrackBtn.disabled = false;
};
async function startTrack() {
startTrackBtn.disabled = true;
const s = await navigator.mediaDevices.getDisplayMedia();
document.getElementById("videoel").srcObject = new MediaStream([s.getVideoTracks()[0]]);
document.getElementById("videoel").play();
track = s.getVideoTracks()[0];
transferBtn.disabled = false;
}
function transferTrack() {
channel.port1.postMessage({name:"track", track}, [track]);
};