• 调摄像头 实时录制视频 下载


     不知道咋解释  copy就完了   等我研究明白回来补

    <!DOCTYPE html>
    <html lang="en">

    <head>
        <title></title>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1">
    </head>

    <body>
        <video width="400" height="300" controls id="video" autoplay></video>
        <div>
            <button type="button" id="record">record</button>
            <button type="button" id="pause">pause</button>
            <button type="button" id="resume">resume</button>
            <button type="button" id="stop">stop</button>
            <button type="button" id="finish">finish</button>
            <a href="#" target="_blank" id="download">download</a>
        </div>
        <div>
            <button type="button" id="info">info</button>
            <button type="button" id="isTypeSupported">isTypeSupported</button>
        </div>

        <script type="text/javascript">
            (function() {
                let mediaRecorder = null;
                let mediaStream = null;
                let chunks = [];

                function getMediaStream(params) {
                    var constraints = {
                        audio: true,
                        video: true
                    };

                    return navigator
                        .mediaDevices
                        .getUserMedia(constraints);
                }

                function attachMedia() {
                    getMediaStream()
                        .then(stream => {
                            console.log(stream888888)
                            document.querySelector('#video').srcObject = stream;
                            mediaStream = stream;
                        })
                        .catch(err => alert(`${err.name}${err.message}`));
                }

                function record() {
                    mediaRecorder = new MediaRecorder(mediaStream, {
                        mimeType: "video/webm"
                    });

                    mediaRecorder.addEventListener('dataavailable'e => {
                        console.log('dataavailable %o'e);
                        chunks.push(e.data);
                    });
                    mediaRecorder.addEventListener('error'e => console.log('error %o'e));
                    mediaRecorder.addEventListener('pause'e => console.log('pause %o'e));
                    mediaRecorder.addEventListener('resume'e => console.log('resume %o'e));
                    mediaRecorder.addEventListener('start'e => console.log('start %o'e));
                    mediaRecorder.addEventListener('stop'e => console.log('stop %o'e));

                    // 调用时可以通过给timeslice参数设置一个毫秒值,如果设置这个毫秒值,那么录制的媒体会按照你设置的值进行分割成一个个单独的区块, 而不是以默认的方式录制一个非常大的整块内容.
                    mediaRecorder.start(10);
                }

                function stop() {
                    mediaRecorder.stop();
                }

                function pause() {
                    mediaRecorder.pause();
                }

                function resume() {
                    mediaRecorder.resume();
                }

                function stop() {
                    mediaRecorder.stop();
                }

                function download() {
                    var blob = new Blob(chunks, {
                        type: "video/webm"
                    });

                    chunks = [];

                    var downloadLink = document.querySelector('a#download');
                    var videoURL = window.URL.createObjectURL(blob);
                    var rand = Math.floor((Math.random() * 10000000));
                    var name = "video_" + rand + ".webm";

                    downloadLink.href = videoURL;
                    downloadLink.setAttribute("download"name);
                    downloadLink.setAttribute("name"name);
                }

                function info() {
                    console.log(`mimeType ${mediaRecorder.mimeType}`);
                    console.log(`state ${mediaRecorder.state}`);
                    console.log(`stream ${mediaRecorder.stream}`);
                    console.log(`videoBitsPerSecond %o`mediaRecorder.videoBitsPerSecond);
                    console.log(`audioBitsPerSecond ${mediaRecorder.audioBitsPerSecond}`);
                }

                function isTypeSupported() {
                    var types = [
                        "video/webm",
                        "audio/webm",
                        "video/webm;codecs=vp8",
                        "video/webm;codecs=daala",
                        "video/webm;codecs=h264",
                        "audio/webm;codecs=opus",
                        "video/mpeg"
                    ];

                    for (var i in types) {
                        console.log(`Is ${types[i]} supported? ${MediaRecorder.isTypeSupported(types[i] ? "Maybe!" : "No")}`);
                    }
                }

                document.querySelector('#record').addEventListener('click'e => record());
                document.querySelector('#pause').addEventListener('click'e => pause());
                document.querySelector('#resume').addEventListener('click'e => resume());
                document.querySelector('#stop').addEventListener('click'e => stop());
                document.querySelector('#finish').addEventListener('click'e => download());

                document.querySelector('#info').addEventListener('click'e => info());
                document.querySelector('#isTypeSupported').addEventListener('click'e => isTypeSupported());

                attachMedia();
            })()
        </script>
    </body>

    </html>
  • 相关阅读:
    存储过程
    pl/sql锁
    事务处理
    记录类型(学习笔记)
    ExecutorException: A query was run and no Result Maps were found for the Mapped Statement ''. It's likely that neither a Result Type nor a Result Map was specified.
    element中的el-form踩的坑
    关于location.href家族的区别和用法
    ajax的路径跳转
    使用thymeleaf模板引擎时的路径问题
    关于mybatis的传多个参数的问题
  • 原文地址:https://www.cnblogs.com/qjh0208/p/14098896.html
Copyright © 2020-2023  润新知