File: getDisplayMedia.html

package info (click to toggle)
webkit2gtk 2.34.6-1~deb10u1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 262,936 kB
  • sloc: cpp: 2,410,633; javascript: 191,866; ansic: 97,227; xml: 65,800; python: 30,274; ruby: 17,137; perl: 15,396; asm: 9,345; yacc: 2,309; sh: 1,660; lex: 1,293; java: 726; makefile: 106; pascal: 60
file content (61 lines) | stat: -rw-r--r-- 1,799 bytes parent folder | download | duplicates (4)
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
56
57
58
59
60
61
<!DOCTYPE html>
<html>
    <head>
        <script>
            let stream = null;

            function promptForCapture(constraints)
            {
                if (!window.internals) {
                    window.webkit.messageHandlers.testHandler.postMessage('test requires internals');
                    return;
                }

                window.internals.withUserGesture(() => {
                    navigator.mediaDevices.getDisplayMedia(constraints)
                    .then((s) => {
                        stream = s;
                        video.srcObject = stream;
                        if (window.webkit)
                          window.webkit.messageHandlers.testHandler.postMessage('allowed');
                    })
                    .catch((error) => {
                        if (window.webkit)
                           window.webkit.messageHandlers.testHandler.postMessage('denied');
                    });
                });
            }

            function stop(kind)
            {
                if (!stream)
                    return;

                let activeTracks = [];
                stream.getTracks().forEach(track => {
                    if (!kind || track.kind == kind)
                        track.stop();
                    else
                        activeTracks.push(track);
                });

                if (!activeTracks.length) {
                    stream = null;
                    video.srcObject = null;
                }
            }

            function haveStream()
            {
                return stream !== null;
            }
        </script>
    <head>

    <body>
        <video id="video" controls></video>
        <p>
        <button onclick="stop()">Stop</button>
        </p>
    </body>
</html>