-
Notifications
You must be signed in to change notification settings - Fork 0
/
script.js
27 lines (24 loc) · 850 Bytes
/
script.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
const videoElement = document.getElementById('video')
const button = document.getElementById('button')
// Async func to prompt user to select media stream, pass to our video element, then play
async function selectMediaStream() {
try {
const mediaStream = await navigator.mediaDevices.getDisplayMedia()
videoElement.srcObject = mediaStream
videoElement.onloadedmetadata = () => {
videoElement.play()
}
} catch (error) {
// Catch errors here
console.log('whoops, error here:', error)
}
}
button.addEventListener('click', async () => {
// Disable the Button when click on it
button.disabled = true// Start Picture in Picture
await videoElement.requestPictureInPicture()
// Reset Button
button.disabled = false
})
// Call function On Load
selectMediaStream()