HTML5는 카메라를 호출하고 사진을 찍는 기능을 구현합니다.

王林
풀어 주다: 2020-12-28 10:16:19
앞으로
2846명이 탐색했습니다.

HTML5는 카메라를 호출하고 사진을 찍는 기능을 구현합니다.

관련 소개:

우리는 일반적으로 DOMContentLoaded 이벤트가 window.onload 전에 실행된다는 것을 알고 있습니다. DOM 트리가 빌드되면 DOMContentLoaded 이벤트가 실행되고, 페이지가 로드될 때 window.onload가 실행됩니다. 실행 전 여기에는 그림과 같은 요소가 포함됩니다.

(동영상 공유 학습: html5 동영상 튜토리얼)

일반적으로 우리는 DOM 트리가 구축된 후 이벤트를 요소에 바인딩하려고 하며, 때로는 외부 도메인 이미지를 로드하는 것이 매우 느립니다.

구현 코드:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
video {
border: 1px solid #ccc;
display: block;
margin: 0 0 20px 0;
float:left;
}
#canvas {
margin-top: 20px;
border: 1px solid #ccc;
display: block;
}
</style>
</head>
<body>
<video id="video" width="500" height="400" autoplay></video>
<canvas id="canvas" width="500" height="400"></canvas>
<button id="snap">拍照</button>
<script type="text/javascript">
var context = canvas.getContext("2d");
//当DOM树构建完成的时候就会执行DOMContentLoaded事件
window.addEventListener("DOMContentLoaded", function() {
//获得Canvas对象
var canvas = document.getElementById("canvas");
//获得video摄像头区域
var video = document.getElementById("video");
var videoObj = {
"video" : true
};
var errBack = function(error) {
console.log("Video capture error: ", error.code);
};
//获得摄像头并显示到video区域
if (navigator.getUserMedia) { // Standard
navigator.getUserMedia(videoObj, function(stream) {
video.src = stream;
video.play();
}, errBack);
} else if (navigator.webkitGetUserMedia) { // WebKit-prefixed
navigator.webkitGetUserMedia(videoObj, function(stream) {
video.src = window.webkitURL.createObjectURL(stream);
video.play();
}, errBack);
} else if (navigator.mozGetUserMedia) { // Firefox-prefixed
navigator.mozGetUserMedia(videoObj, function(stream) {
video.src = window.URL.createObjectURL(stream);
video.play();
}, errBack);
}
}, false);
// 触发拍照动作
document.getElementById("snap").addEventListener("click", function() {
context.drawImage(video, 0, 0, 640, 480);
});
</script>
</body>
</html>
로그인 후 복사

구현 효과:

HTML5는 카메라를 호출하고 사진을 찍는 기능을 구현합니다.관련 권장 사항: html5 튜토리얼

위 내용은 HTML5는 카메라를 호출하고 사진을 찍는 기능을 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:csdn.net
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!