国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JavaScript > 正文

js和HTML5基于過濾器從攝像頭中捕獲視頻的方法

2020-03-24 16:01:43
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了js+HTML5基于過濾器從攝像頭中捕獲視頻的方法,涉及javascript基于html5元素操作多媒體的使用技巧,需要的朋友可以參考下

本文實例講述了js+HTML5基于過濾器從攝像頭中捕獲視頻的方法。分享給大家供大家參考。具體如下:

index.html頁面:

 p >

style.css文件:

.grayscale{ -webkit-filter:grayscale(1); -moz-filter:grayscale(1); -o-filter:grayscale(1); -ms-filter:grayscale(1); filter:grayscale(1);.sepia{ -webkit-filter:sepia(0.8); -moz-filter:sepia(0.8); -o-filter:sepia(0.8); -ms-filter:sepia(0.8); filter:sepia(0.8);.blur{ -webkit-filter:blur(3px); -moz-filter:blur(3px); -o-filter:blur(3px); -ms-filter:blur(3px); filter:blur(3px);.brightness{ -webkit-filter:brightness(0.3); -moz-filter:brightness(0.3); -o-filter:brightness(0.3); -ms-filter:brightness(0.3); filter:brightness(0.3);.contrast{ -webkit-filter:contrast(0.5); -moz-filter:contrast(0.5); -o-filter:contrast(0.5); -ms-filter:contrast(0.5); filter:contrast(0.5);.hue-rotate{ -webkit-filter:hue-rotate(90deg); -moz-filter:hue-rotate(90deg); -o-filter:hue-rotate(90deg); -ms-filter:hue-rotate(90deg); filter:hue-rotate(90deg);.hue-rotate2{ -webkit-filter:hue-rotate(180deg); -moz-filter:hue-rotate(180deg); -o-filter:hue-rotate(180deg); -ms-filter:hue-rotate(180deg); filter:hue-rotate(180deg);.hue-rotate3{ -webkit-filter:hue-rotate(270deg); -moz-filter:hue-rotate(270deg); -o-filter:hue-rotate(270deg); -ms-filter:hue-rotate(270deg); filter:hue-rotate(270deg);.saturate{ -webkit-filter:saturate(10); -moz-filter:saturate(10); -o-filter:saturate(10); -ms-filter:saturate(10); filter:saturate(10);.invert{ -webkit-filter:invert(1); -moz-filter:invert(1); -o-filter: invert(1); -ms-filter: invert(1); filter: invert(1);}

script.js 文件:

// Main initializationdocument.addEventListener( DOMContentLoaded , function() { // Global variables var video = document.querySelector( video  var audio, audioType; var canvas = document.querySelector( canvas  var context = canvas.getContext( 2d  // Custom video filters var iFilter = 0; var filters = [ grayscale , sepia , blur , brightness , contrast , hue-rotate , hue-rotate2 , hue-rotate3 , saturate , invert , none  // Get the video stream from the camera with getUserMedia navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia; window.URL = window.URL || window.webkitURL || window.mozURL || window.msURL; if (navigator.getUserMedia) { // Evoke getUserMedia function navigator.getUserMedia({video: true, audio: true}, onSuccessCallback, onErrorCallback); function onSuccessCallback(stream) { // Use the stream from the camera as the source of the video element video.src = window.URL.createObjectURL(stream) || stream; // Autoplay video.play(); // HTML5 Audio audio = new Audio(); audioType = getAudioType(audio); if (audioType) { audio.src = polaroid. + audioType; audio.play(); // Display an error function onErrorCallback(e) { var expl = An error occurred: [Reason: + e.code + ]  console.error(expl); alert(expl); return; } else { document.querySelector( .container ).style.visibility = hidden  document.querySelector( .warning ).style.visibility = visible  return; // Draw the video stream at the canvas object function drawVideoAtCanvas(obj, context) { window.setInterval(function() { context.drawImage(obj, 0, 0); }, 60); // The canPlayType() function doesn t return true or false. In recognition of how complex // formats are, the function returns a string: probably , maybe or an empty string. function getAudioType(element) { if (element.canPlayType) { if (element.canPlayType( audio/mp4; codecs= mp4a.40.5 ) !== ) { return( aac  } else if (element.canPlayType( audio/ogg; codecs= vorbis ) !== ) { return( ogg  return false; // Add event listener for our video s Play function in order to produce video at the canvas video.addEventListener( play , function() { drawVideoAtCanvas(this, context); }, false); // Add event listener for our Button (to switch video filters) document.querySelector( button ).addEventListener( click , function() { video.className =  canvas.className =  var effect = filters[iFilter++ % filters.length]; // Loop through the filters. if (effect) { video.classList.add(effect); canvas.classList.add(effect); document.querySelector( .container h3 ).innerHTML = Current filter is: + effect; }, false);}, false);

以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP !

相關推薦:

如何解決HTML5 虛擬鍵盤出現擋住輸入框的問題

HTML5 Plus 實現手機APP拍照或相冊選擇圖片上傳的功能

以上就是js和HTML5基于過濾器從攝像頭中捕獲視頻的方法的詳細內容,其它編程語言

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 石狮市| 麦盖提县| 汝州市| 肥乡县| 天等县| 隆安县| 龙江县| 安义县| 甘德县| 牡丹江市| 神池县| 胶南市| 信丰县| 分宜县| 嵊泗县| 漳浦县| 宣威市| 富源县| 肃北| 元氏县| 津市市| 衡水市| 武山县| 耒阳市| 宣武区| 华安县| 德安县| 鹤岗市| 长丰县| 宝丰县| 奉贤区| 环江| 庆城县| 临朐县| 武安市| 罗源县| 彭州市| 宣威市| 衡山县| 七台河市| 衢州市|