File: getDisplayMedia.html

package info (click to toggle)
wpewebkit 2.48.3-1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 421,720 kB
  • sloc: cpp: 3,670,389; javascript: 194,411; ansic: 165,592; python: 46,476; asm: 19,276; ruby: 18,528; perl: 16,602; xml: 4,650; yacc: 2,360; java: 1,993; sh: 1,948; lex: 1,327; pascal: 366; makefile: 85
file content (66 lines) | stat: -rw-r--r-- 1,948 bytes parent folder | download | duplicates (10)
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
62
63
64
65
66
<!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;
            }

            function hasSleepDisabler()
            {
                return window.internals ? internals.hasSleepDisabler() : false;
            }
        </script>
    <head>

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