欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

html5調(diào)用攝像頭,Html5調(diào)用攝像頭讀取二維碼

如何通過(guò)html5調(diào)用手機(jī)攝像頭

1)獲取視頻流

專注于為中小企業(yè)提供做網(wǎng)站、網(wǎng)站設(shè)計(jì)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)大洼免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了千余家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過(guò)網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

添加一個(gè)HTML5的Video標(biāo)簽,并將從攝像頭獲得視頻作為這個(gè)標(biāo)簽的輸入來(lái)源

var video = document.getElementByIdx_x_x("video");

navigator.getUserMedia({video:true}, function (stream) {

video.src = window.webkitURL.createObjectURL(stream);

}, function (error) { alert(error); });

2)拍照

關(guān)于拍照功能,采用HTML5的Canvas實(shí)時(shí)捕獲Video標(biāo)簽的內(nèi)容,Video元素能作為Canvas圖像的輸入

function scamera() {

var videoElement = document.getElementByIdx_x_x('video');

var canvasObj = document.getElementByIdx_x_x('canvas1');

var context1 = canvasObj.getContext('2d');

context1.fillStyle = "#ffffff";

context1.fillRect(0, 0, 320, 240);

context1.drawImage(videoElement, 0, 0, 320, 240);

}

3)圖片獲取

要從Canvas獲取圖片數(shù)據(jù),其核心思路是用canvas的toDataURL將Canvas的數(shù)據(jù)轉(zhuǎn)換為base64位編碼的PNG圖像

var imgData=canvas.toDataURL(“image/png”);

imgData格式如下:”data:image/png;base64,xxxxx“

真正圖像數(shù)據(jù)是base64編碼逗號(hào)之后的部分。

如何通過(guò)html5調(diào)用攝像頭拍照

先簡(jiǎn)單的添加需要的控件

video id="video" autoplay=""style='width:640px;height:480px'/video

button id='picture'PICTURE/button

canvas id="canvas" width="640" height="480"/canvas

并在script中定義

var video = document.getElementById("video");

var context = canvas.getContext("2d")

var errocb = function () {

console.log('sth wrong!');

}

然后,簡(jiǎn)單的說(shuō)就是利用html5的api?navigator.getUserMedia來(lái)開(kāi)啟設(shè)備的攝像頭,瀏覽器上會(huì)出現(xiàn)圖示中的提示

if (navigator.getUserMedia) { // 標(biāo)準(zhǔn)的API

navigator.getUserMedia({ "video": true }, function (stream) {

video.src = stream;

video.play();

}, errocb);

} else if (navigator.webkitGetUserMedia) { // WebKit 核心的API

navigator.webkitGetUserMedia({ "video": true }, function (stream) {

video.src = window.webkitURL.createObjectURL(stream);

video.play();

}, errocb);

}

網(wǎng)上有些例子中,navigator.getUserMedia第一個(gè)參數(shù)是‘video’,這可能是早期的版本,現(xiàn)在必須是obj

還有關(guān)于getUserMedia和webkitGetUserMedia 的判斷,網(wǎng)上有這么寫(xiě)的

navigator.getUserMedia = (navigator.getUserMedia ||

navigator.webkitGetUserMedia ||

navigator.mozGetUserMedia ||

navigator.msGetUserMedia);

但要注意,他們綁定video.src的方法不一樣,本人沒(méi)有測(cè)過(guò)createObjectURL是否通用

拍照功能就是簡(jiǎn)單的調(diào)用canvas中的drawImage即可

document.getElementById("picture").addEventListener("click", function () {

context.drawImage(video, 0, 0, 640, 480);

});

所有script代碼如圖示

然后瀏覽器中就能看到攝像頭,點(diǎn)擊picture,就會(huì)在把當(dāng)前攝像頭的圖片就會(huì)出現(xiàn)在右邊了

如何通過(guò)html5調(diào)用手機(jī)攝像頭?

HTML5 The Media Capture API提供了對(duì)攝像頭的可編程訪問(wèn),用戶可以直接用getUserMedia獲得攝像頭提供的視頻流。但實(shí)際上用html5調(diào)用手機(jī)攝像頭存在很多問(wèn)題:

1)谷歌的發(fā)布的Chrome到了21版本后,才新增了一個(gè)用于高質(zhì)量視頻音頻通訊的getUserMedia API,該API允許Web應(yīng)用程序訪問(wèn)攝像頭和麥克風(fēng),其他手機(jī)瀏覽器只有opera支持html5調(diào)用本地拍照功能

2)兩個(gè)瀏覽器均不支持訪問(wèn)多個(gè)攝像頭:chrome不支持訪問(wèn)后置攝像頭,pera支持訪問(wèn)后置攝像頭的

android手機(jī),瀏覽器chrome32版本下實(shí)現(xiàn)了瀏覽器調(diào)用設(shè)備攝像頭進(jìn)行拍照。主要分3個(gè)步驟來(lái)完成:

1)獲取視頻流

添加一個(gè)HTML5的Video標(biāo)簽,并將從攝像頭獲得視頻作為這個(gè)標(biāo)簽的輸入來(lái)源

var?video?=?document.getElementByIdx_x_x("video");

navigator.getUserMedia({video:true},?function?(stream)?{

video.src?=?window.webkitURL.createObjectURL(stream);

},?function?(error)?{?alert(error);?});

2)拍照

關(guān)于拍照功能,采用HTML5的Canvas實(shí)時(shí)捕獲Video標(biāo)簽的內(nèi)容,Video元素能作為Canvas圖像的輸入

function?scamera()?{

var?videoElement?=?document.getElementByIdx_x_x('video');

var?canvasObj?=?document.getElementByIdx_x_x('canvas1');

var?context1?=?canvasObj.getContext('2d');

context1.fillStyle?=?"#ffffff";

context1.fillRect(0,?0,?320,?240);

context1.drawImage(videoElement,?0,?0,?320,?240);

}

3)圖片獲取

要從Canvas獲取圖片數(shù)據(jù),其核心思路是用canvas的toDataURL將Canvas的數(shù)據(jù)轉(zhuǎn)換為base64位編碼的PNG圖像

var?imgData=canvas.toDataURL(“image/png”);

imgData格式如下:”data:image/png;base64,xxxxx“

真正圖像數(shù)據(jù)是base64編碼逗號(hào)之后的部分

分享文章:html5調(diào)用攝像頭,Html5調(diào)用攝像頭讀取二維碼
轉(zhuǎn)載來(lái)源:http://chinadenli.net/article8/dsejgop.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供電子商務(wù)網(wǎng)站排名外貿(mào)建站網(wǎng)站設(shè)計(jì)公司靜態(tài)網(wǎng)站關(guān)鍵詞優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁(yè)設(shè)計(jì)