婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > html5調用攝像頭功能的實現代碼

html5調用攝像頭功能的實現代碼

熱門標簽:濟南辦理400電話 鄭州電銷外呼系統違法嗎 威海營銷外呼系統招商 農村住宅地圖標注 鶴壁手機自動外呼系統怎么安裝 漳州人工外呼系統排名 ai電銷機器人連接網關 中紳電銷智能機器人 跟電銷機器人做同事

前言

前些天,線上筆試的時候,發現需要瀏覽器同意開啟攝像頭,感覺像是 js 調用的,由于當時筆試,也就沒想到這么多問題。今天閑來無事,看了下自己的 todo,發現有這個調用攝像頭的todo,才想到😂。網上查了一下,果然 js 有調用攝像頭的 api,為此自己寫一個 demo ,避免忘記。

正文

調用攝像頭

一共有兩種實現方式,一種是使用navigator.getUserMedia(該特性已經從 Web 標準中刪除,雖然一些瀏覽器目前仍然支持它,但也許會在未來的某個時間停止支持,請盡量不要使用該特性),前面一種已經從 Web 標準中刪除,僅為了向后兼容而存在,第二種是使用navigator.mediaDevices.getUserMedia(推薦使用),這兩種方法 Safari 貌似都不支持。。。。

第一種方法navigator.getUserMedia用法詳見mdn ,代碼如下:

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>攝像頭調用1</title>
</head>
<body>
    <video id="v"></video>
    <script>
        !(function () {
            function userMedia() {
                return navigator.getUserMedia = navigator.getUserMedia ||
                    navigator.webkitGetUserMedia ||
                    navigator.mozGetUserMedia ||
                    navigator.msGetUserMedia || null;
            }
            if (userMedia()) {
                var constraints = {
                    video: true,
                    audio: false
                };
                var media = navigator.getUserMedia(constraints, function (stream) {
                    var v = document.getElementById('v');
                    var url = window.URL || window.webkitURL;
                    v.src = url ? url.createObjectURL(stream) : stream;
                    v.play();
                }, function (error) {
                    console.log("ERROR");
                    console.log(error);
                });
            } else {
                console.log("不支持");
            }
        })();
    </script>
</body>
</html>

第二種方法navigator.mediaDevices.getUserMedia用法詳見mdn。navigator.mediaDevices.getUserMedia 其實和第一種差不多,主要第二種返回是一個 Promise 對象,代碼如下:

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>攝像頭調用2</title>
</head>
<body>
    <video id="v"></video>
    <script>
        !(function () {
            // 老的瀏覽器可能根本沒有實現 mediaDevices,所以我們可以先設置一個空的對象
            if (navigator.mediaDevices === undefined) {
                navigator.mediaDevices = {};
            }
            if (navigator.mediaDevices.getUserMedia === undefined) {
                navigator.mediaDevices.getUserMedia = function (constraints) {
                    // 首先,如果有getUserMedia的話,就獲得它
                    var getUserMedia = navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia;

                    // 一些瀏覽器根本沒實現它 - 那么就返回一個error到promise的reject來保持一個統一的接口
                    if (!getUserMedia) {
                        return Promise.reject(new Error('getUserMedia is not implemented in this browser'));
                    }

                    // 否則,為老的navigator.getUserMedia方法包裹一個Promise
                    return new Promise(function (resolve, reject) {
                        getUserMedia.call(navigator, constraints, resolve, reject);
                    });
                }
            }
            const constraints = {
                video: true,
                audio: false
            };
            let promise = navigator.mediaDevices.getUserMedia(constraints);
            promise.then(stream => {
                let v = document.getElementById('v');
                // 舊的瀏覽器可能沒有srcObject
                if ("srcObject" in v) {
                    v.srcObject = stream;
                } else {
                    // 防止再新的瀏覽器里使用它,應為它已經不再支持了
                    v.src = window.URL.createObjectURL(stream);
                }
                v.onloadedmetadata = function (e) {
                    v.play();
                };
            }).catch(err => {
                console.error(err.name + ": " + err.message);
            })
        })();
    </script>
</body>
</html>

拍照

思路是設置一個標志變量 videoPlaying 看看是否 video 有在 play,監聽拍照按鈕的點擊事件,如果videoPlaying 為 true ,使用一個canvas 獲取 video 的寬高(默認 canvas 是不顯示的),然后使用 canvas 的drawImage,然后使用 canvas 的 toDataURL返回一個 data url,將這個 url,設置在一個 img 標簽上即可😀

第一種方法navigator.getUserMedia實現代碼:

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>拍照1</title>
</head>
<body>
    <button id="take">拍照</button>
    <br />
    <video id="v" style="width: 640px;height: 480px;"></video>
    <canvas id="canvas" style="display:none;"></canvas>
    <br />
    <img src="http://placehold.it/640&text=Your%20image%20here%20..." id="photo" alt="photo">
    <script>
        !(function () {
            function userMedia() {
                return navigator.getUserMedia = navigator.getUserMedia ||
                    navigator.webkitGetUserMedia ||
                    navigator.mozGetUserMedia ||
                    navigator.msGetUserMedia || null;
            }
            if (userMedia()) {
                let videoPlaying = false;
                let constraints = {
                    video: true,
                    audio: false
                };
                let video = document.getElementById('v');
                let media = navigator.getUserMedia(constraints, function (stream) {
                    let url = window.URL || window.webkitURL;
                    video.src = url ? url.createObjectURL(stream) : stream;
                    video.play();
                    videoPlaying = true;
                }, function (error) {
                    console.log("ERROR");
                    console.log(error);
                });
                document.getElementById('take').addEventListener('click', function () {
                    if (videoPlaying) {
                        let canvas = document.getElementById('canvas');
                        canvas.width = video.videoWidth;
                        canvas.height = video.videoHeight;
                        canvas.getContext('2d').drawImage(video, 0, 0);
                        let data = canvas.toDataURL('image/webp');
                        document.getElementById('photo').setAttribute('src', data);
                    }
                }, false);
            } else {
                console.log("不支持");
            }
        })();
    </script>
</body>
</html>

第二種navigator.mediaDevices.getUserMedia實現方法:

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>拍照2</title>
</head>

<body>
    <button id="take">拍照</button>
    <br />
    <video id="v" style="width: 640px;height: 480px;"></video>
    <canvas id="canvas" style="display:none;"></canvas>
    <br />
    <img src="http://placehold.it/640&text=Your%20image%20here%20..." id="photo" alt="photo">
    <script>
        !(function () {
            // 老的瀏覽器可能根本沒有實現 mediaDevices,所以我們可以先設置一個空的對象
            if (navigator.mediaDevices === undefined) {
                navigator.mediaDevices = {};
            }
            if (navigator.mediaDevices.getUserMedia === undefined) {
                navigator.mediaDevices.getUserMedia = function (constraints) {
                    // 首先,如果有getUserMedia的話,就獲得它
                    var getUserMedia = navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia;

                    // 一些瀏覽器根本沒實現它 - 那么就返回一個error到promise的reject來保持一個統一的接口
                    if (!getUserMedia) {
                        return Promise.reject(new Error('getUserMedia is not implemented in this browser'));
                    }

                    // 否則,為老的navigator.getUserMedia方法包裹一個Promise
                    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);
            })
            document.getElementById('take').addEventListener('click', function () {
                if (videoPlaying) {
                    let canvas = document.getElementById('canvas');
                    canvas.width = v.videoWidth;
                    canvas.height = v.videoHeight;
                    canvas.getContext('2d').drawImage(v, 0, 0);
                    let data = canvas.toDataURL('image/webp');
                    document.getElementById('photo').setAttribute('src', data);
                }
            }, false);
        })();
    </script>
</body>
</html>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

標簽:紅河 咸陽 惠州 文山 萍鄉 甘南 營口 蘇州

巨人網絡通訊聲明:本文標題《html5調用攝像頭功能的實現代碼》,本文關鍵詞  html5,調用,攝像頭,功能,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《html5調用攝像頭功能的實現代碼》相關的同類信息!
  • 本頁收集關于html5調用攝像頭功能的實現代碼的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产精品国产精品国产专区不片| 色8久久精品久久久久久蜜| 亚洲激情av在线| 日韩成人av影视| 色悠悠久久综合| 久久久久久麻豆| 午夜不卡在线视频| av一本久道久久综合久久鬼色| 91亚洲永久精品| 国产精品卡一卡二卡三| 国产一区不卡视频| 精品国产亚洲一区二区三区在线观看| 亚洲欧洲av在线| 成人高清av在线| 久久亚洲捆绑美女| 国产毛片精品国产一区二区三区| 欧美午夜寂寞影院| 亚洲三级在线免费观看| 国产a久久麻豆| 国产精品久久久久久一区二区三区| 美女网站色91| 国产婷婷色一区二区三区在线| 捆绑调教美女网站视频一区| 欧美一级艳片视频免费观看| 美女视频黄 久久| 精品久久人人做人人爽| 老司机一区二区| 欧美精品一区二区高清在线观看| 日本不卡在线视频| 国产亲近乱来精品视频| 色综合久久久久综合| 亚洲一区av在线| 国产欧美日韩在线观看| 色婷婷久久久久swag精品| 国产精品福利一区| 欧美男女性生活在线直播观看| 日韩福利视频导航| 国产精品亲子伦对白| 欧洲亚洲精品在线| 国产激情一区二区三区桃花岛亚洲 | 国产日产欧美精品一区二区三区| 国产一区二区在线影院| 天天影视涩香欲综合网| 国产精品三级久久久久三级| 精品久久久久久最新网址| 欧洲av一区二区嗯嗯嗯啊| 国产成人av资源| 国产另类ts人妖一区二区| 麻豆成人在线观看| 日韩专区欧美专区| 日韩avvvv在线播放| 亚洲第一电影网| 午夜视频在线观看一区二区三区| 国产精品欧美精品| 亚洲欧美日韩国产中文在线| 亚洲欧洲av另类| 亚洲18女电影在线观看| 亚洲制服丝袜av| 亚洲综合色区另类av| 日本欧美大码aⅴ在线播放| 老司机精品视频线观看86 | 欧美性高清videossexo| 91麻豆swag| 在线综合亚洲欧美在线视频| 久久亚洲捆绑美女| 色悠悠久久综合| 欧美mv日韩mv国产网站| 国产欧美一区二区精品性色超碰| 亚洲日本va午夜在线影院| 日韩主播视频在线| 色88888久久久久久影院野外| 在线观看av一区| 国产亚洲成aⅴ人片在线观看 | 亚洲欧美日韩久久| 韩国av一区二区三区在线观看| 97精品超碰一区二区三区| 精品国产乱码久久久久久1区2区 | 欧美三片在线视频观看 | 色综合久久中文综合久久97| 久久亚洲影视婷婷| 日韩av电影免费观看高清完整版| 成人综合在线观看| 精品久久久久久久久久久久包黑料 | 精品电影一区二区三区| 亚洲最大的成人av| 99精品久久只有精品| 国产精品视频一区二区三区不卡| 秋霞国产午夜精品免费视频| 在线免费不卡电影| 一区二区三区波多野结衣在线观看| 久久嫩草精品久久久久| 精品在线一区二区| 国产欧美日韩视频一区二区| 国产在线国偷精品免费看| 日韩欧美国产系列| 国产一区二区三区综合| 亚洲欧洲av在线| 欧美视频精品在线观看| 亚洲h动漫在线| 2021久久国产精品不只是精品| 国产精品一区免费在线观看| 欧美激情一区二区三区在线| av激情综合网| 天天色综合天天| 欧美极品少妇xxxxⅹ高跟鞋 | 国产在线播放一区二区三区 | 偷拍与自拍一区| 亚洲免费在线看| 成人开心网精品视频| 夜夜嗨av一区二区三区| 91丨porny丨户外露出| 国产日韩欧美a| 国产高清无密码一区二区三区| 久久久久久久精| 国产乱理伦片在线观看夜一区| 精品日产卡一卡二卡麻豆| 久久99精品久久久久久久久久久久| 日韩一区二区三区av| 九九视频精品免费| 国产夜色精品一区二区av| 成人综合婷婷国产精品久久| 亚洲电影你懂得| 蜜臀精品一区二区三区在线观看 | 国产精品视频yy9299一区| 欧美日韩电影一区| 欧美福利电影网| 精品久久国产字幕高潮| 国产精品无人区| 国产美女娇喘av呻吟久久| 色综合天天天天做夜夜夜夜做| 国产欧美日韩麻豆91| 国产传媒欧美日韩成人| 亚洲午夜久久久久久久久电影院| 欧美日韩国产小视频| 日韩精品一区二区三区中文不卡| 欧美v国产在线一区二区三区| 欧美tk—视频vk| 亚洲九九爱视频| 日韩电影免费在线观看网站| 国产麻豆成人精品| 在线视频中文字幕一区二区| 正在播放亚洲一区| 国产精品网站在线| 美美哒免费高清在线观看视频一区二区| 欧美aaaaa成人免费观看视频| 六月婷婷色综合| 国产一区二区三区香蕉| 国产成人综合在线观看| 香蕉成人啪国产精品视频综合网| 视频一区中文字幕| 国产91清纯白嫩初高中在线观看| 国产日本一区二区| 蜜桃视频在线观看一区| 亚洲三级在线免费| 久久精品视频免费| 最好看的中文字幕久久| 亚洲蜜臀av乱码久久精品| 99精品国产视频| 99精品国产99久久久久久白柏 | 国产精品久久久久久久久免费相片| 风流少妇一区二区| 国产精品国产三级国产aⅴ入口 | 日韩欧美高清一区| 91黄色免费版| 国产成人在线色| 欧美日韩一区高清| 国产精品电影一区二区三区| 亚洲国产一区二区视频| 一区二区三区高清| 视频一区视频二区中文字幕| 欧美日韩国产影片| 精品少妇一区二区三区| 国产精品久久久久一区二区三区共| 激情久久五月天| 国产河南妇女毛片精品久久久| 精品国产精品一区二区夜夜嗨| 国产成人欧美日韩在线电影| 亚洲色图欧洲色图| 欧美v日韩v国产v| 在线看日韩精品电影| 国产精品亚洲成人| 偷拍自拍另类欧美| 亚洲图片欧美激情| 亚洲精品在线三区| 国产亚洲一区二区三区| 色综合久久99| 精品在线视频一区| 不卡一区中文字幕| 国产·精品毛片| gogogo免费视频观看亚洲一| 亚洲国产精品尤物yw在线观看| 精品国产a毛片| 久久久噜噜噜久久中文字幕色伊伊| 欧美性xxxxx极品少妇| 国产69精品久久99不卡| 视频一区中文字幕| 亚洲第一福利一区| 久久99久久精品| 免费一级片91| 日韩影院在线观看|