File: getDisplayMedia.html

package info (click to toggle)
wpewebkit 2.38.6-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 311,508 kB
  • sloc: cpp: 2,653,313; javascript: 289,013; ansic: 121,268; xml: 64,149; python: 35,534; ruby: 17,287; perl: 15,877; asm: 11,072; yacc: 2,326; sh: 1,863; lex: 1,319; java: 937; makefile: 146; 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>