搜尋
首頁web前端H5教程web/html5呼叫攝影機實現二維碼掃描效果(程式碼實例)

這篇文章跟大家介紹如何用web/html5呼叫相機實現二維碼掃描的效果,有一定的參考價值,有需要的朋友可以參考一下,希望對你們有幫助。

利用html5(navigator.getUserMedia)呼叫攝影機抓拍圖片媒體串流,透過php呼叫java介面解析圖片二維碼,實現二維碼解析,可結合自己的業務!不過目前支援的瀏覽器不多是個問題。

html/js

nbsp;html>

	<title>HTML5 code Reader</title>
	<meta>

<style>
 html, body { height: 100%; width: 100%; text-align:center; }  
</style>
<script></script>
<script>
//这段代 主要是获取摄像头的视频流并显示在Video 签中  
var canvas=null,context=null,video=null;   
window.addEventListener("DOMContentLoaded", function ()
{
	try{
		canvas = document.getElementById("canvas");
		context = canvas.getContext("2d");
		video = document.getElementById("video");
		
		var videoObj = { "video": true,audio:false},
		flag=true,
		MediaErr = function (error)
		{           
			flag=false;  
			if (error.PERMISSION_DENIED)
			{
				 alert(&#39;用户拒绝了浏览器请求媒体的权限&#39;, &#39;提示&#39;);
			} else if (error.NOT_SUPPORTED_ERROR) {
				 alert(&#39;对不起,您的浏览器不支持拍照功能,请使用其他浏览器&#39;, &#39;提示&#39;);
			} else if (error.MANDATORY_UNSATISFIED_ERROR) {
				 alert(&#39;指定的媒体类型未接收到媒体流&#39;, &#39;提示&#39;);
			} else {
				 alert(&#39;系统未能获取到摄像头,请确保摄像头已正确安装。或尝试刷新页面,重试&#39;, &#39;提示&#39;);
			}
		};
		//获取媒体的兼容代码,目前只支持(Firefox,Chrome,Opera)
        if (navigator.getUserMedia)
		{
			//qq浏览器不支持
			if (navigator.userAgent.indexOf(&#39;MQQBrowser&#39;) > -1) {
				 alert(&#39;对不起,您的浏览器不支持拍照功能,请使用其他浏览器&#39;, &#39;提示&#39;);
				 return false;
            }
            navigator.getUserMedia(videoObj, function (stream) {
				video.src = stream;                
				video.play();      
            }, MediaErr);           
		}
		else if(navigator.webkitGetUserMedia)
		{
           navigator.webkitGetUserMedia(videoObj, function (stream)
		   {          
             video.src = window.webkitURL.createObjectURL(stream);           
             video.play();           
        	}, MediaErr);           
		}
		else if (navigator.mozGetUserMedia)
		{
			navigator.mozGetUserMedia(videoObj, function (stream) {
				 video.src = window.URL.createObjectURL(stream);
				 video.play();
			}, MediaErr);
		}
		else if (navigator.msGetUserMedia)
		{ 
			 navigator.msGetUserMedia(videoObj, function (stream) {
             	$(document).scrollTop($(window).height());
                video.src = window.URL.createObjectURL(stream);
                video.play();
             }, MediaErr);
		}else{
			alert(&#39;对不起,您的浏览器不支持拍照功能,请使用其他浏览器&#39;);
			return false;
		}
		if(flag){
			alert(&#39;为了获得更准确的测试结果,请尽量将二维码置于框中,然后进行拍摄、扫描。 请确保浏览器有权限使用摄像功能&#39;);
		}
     	 //这个是拍照按钮的事件,          
     	$("#snap").click(function () {startPat();}).show();
	}catch(e){      
        printHtml("浏览器不支持HTML5 CANVAS");       
    } 
}, false);
    
//打印内容到页面      
function printHtml(content){
	$(window.document.body).append(content+"<br/>");
}
//开始拍照
function startPat(){
	setTimeout(function(){//防止调用过快
		if(context)
		{
			context.drawImage(video, 0, 0, 320, 320);     
			CatchCode(); 
		}
	},200);
} 
//抓屏获取图像流,并上传到服务器      
function CatchCode() {        
	if(canvas!=null)
	{  
   		//以下开始编 数据   
		var imgData = canvas.toDataURL(); 
		//将图像转换为base64数据
        var base64Data = imgData;//.substr(22); //在前端截取22位之后的字符串作为图像数据
        //开始异步上
	   $.post("saveimg.php", { "img": base64Data },function (result)
	   {   
			printHtml("解析结果:"+result.data);
			if (result.status == "success" && result.data!="")
			{                 
				printHtml("解析结果成功!");
			}else{  
				startPat();//如果没有解析出来则重新抓拍解析       
			}
	   },"json");
	}
}      
</script>
  

<p></p>
<p>       
<video>
</video>       
<canvas>
</canvas> <br>
<button>开始扫描</button>  
   </p>



php(saveimg)

<?php include_once("utils.php");
$base64_image_content=$_POST[&#39;img&#39;];
if (preg_match(&#39;/^(data:\s*image\/(\w+);base64,)/&#39;, $base64_image_content, $result))
{
  $type = $result[2];
  $new_file = "./2.{$type}";
  if (file_put_contents($new_file, base64_decode(str_replace($result[1], &#39;&#39;, $base64_image_content)))){
	$code=utils::deCodeBitMap("2.png","192.168.46.123",20147);
	echo &#39;{"status":"success","data":"&#39;.trim($code).&#39;"}&#39;;
  }else{
  	echo &#39;{"status":"write error","data":"NO"}&#39;;
  }
}else{
	echo &#39;{"status":"preg error","data":"NO"}&#39;;
}
?>

php(utils)

 class  utils{
 	
	/**
     	* @access static
     	* @param  $imagepath String 图片的完整路径
	* @param  $host      String 主机如:127.0.0.1
	* @param  $port      String 端口号如:20147
     	* @return string 解析出的URL
    	*/
	static function deCodeBitMap($imagepath,$host,$port){
		$socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP) or die($imagepath." Could not connet server create\n"); // 创建一个Socket
		if(!$socket){
			return "";
		}
		$connection = socket_connect($socket, $host, $port) or die($imagepath." Could not connet server connection\n");    //  连接
		if(!$connection){
			return "";
		}
		socket_write($socket, $imagepath) or die("Write failed\n"); // 数据传送 向服务器发送消息

		$buff = socket_read($socket, 1024, PHP_NORMAL_READ);
		return $buff;
	}
	
 }

java擴展使用說明

該解析過程需要java環境支持,jar包啟動後在本機的20147埠接受socket監聽,因此網路程式語言都可以呼叫。
1 命令列啟動jar套件
java -jar xxxxx.jar
啟動成功應該可以看到20147埠的應用程式
2服務socket呼叫
暫時提供php呼叫程式碼

#最終效果:

web/html5呼叫攝影機實現二維碼掃描效果(程式碼實例)

#瀏覽器支援情況

web/html5呼叫攝影機實現二維碼掃描效果(程式碼實例)

#總結:以上就是這篇文章的全部內容,希望對大家的學習有所幫助。更多相關教學請造訪Html5影片教學

相關推薦:

php公益培訓影片教學

#

以上是web/html5呼叫攝影機實現二維碼掃描效果(程式碼實例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:CSDN。如有侵權,請聯絡admin@php.cn刪除
H5:如何增強網絡上的用戶體驗H5:如何增強網絡上的用戶體驗Apr 19, 2025 am 12:08 AM

H5通過多媒體支持、離線存儲和性能優化提升網頁用戶體驗。 1)多媒體支持:H5的和元素簡化開發,提升用戶體驗。 2)離線存儲:WebStorage和IndexedDB允許離線使用,提升體驗。 3)性能優化:WebWorkers和元素優化性能,減少帶寬消耗。

解構H5代碼:標籤,元素和屬性解構H5代碼:標籤,元素和屬性Apr 18, 2025 am 12:06 AM

HTML5代碼由標籤、元素和屬性組成:1.標籤定義內容類型,用尖括號包圍,如。 2.元素由開始標籤、內容和結束標籤組成,如內容。 3.屬性在開始標籤中定義鍵值對,增強功能,如。這些是構建網頁結構的基本單位。

了解H5代碼:HTML5的基本原理了解H5代碼:HTML5的基本原理Apr 17, 2025 am 12:08 AM

HTML5是構建現代網頁的關鍵技術,提供了許多新元素和功能。 1.HTML5引入了語義化元素如、、等,增強了網頁結構和SEO。 2.支持多媒體元素和,無需插件即可嵌入媒體。 3.表單增強了新輸入類型和驗證屬性,簡化了驗證過程。 4.提供了離線和本地存儲功能,提升了網頁性能和用戶體驗。

H5代碼:Web開發人員的最佳實踐H5代碼:Web開發人員的最佳實踐Apr 16, 2025 am 12:14 AM

H5代碼的最佳實踐包括:1.使用正確的DOCTYPE聲明和字符編碼;2.採用語義化標籤;3.減少HTTP請求;4.使用異步加載;5.優化圖像。這些實踐能提升網頁的效率、可維護性和用戶體驗。

H5:網絡標準和技術的發展H5:網絡標準和技術的發展Apr 15, 2025 am 12:12 AM

Web标准和技术从HTML4、CSS2和简单的JavaScript演变至今,经历了显著的发展。1)HTML5引入了Canvas、WebStorage等API,增强了Web应用的复杂性和互动性。2)CSS3增加了动画和过渡功能,使页面效果更加丰富。3)JavaScript通过Node.js和ES6的现代化语法,如箭头函数和类,提升了开发效率和代码可读性,这些变化推动了Web应用的性能优化和最佳实践的发展。

H5是HTML5的速記嗎?探索細節H5是HTML5的速記嗎?探索細節Apr 14, 2025 am 12:05 AM

H5不僅僅是HTML5的簡稱,它代表了一個更廣泛的現代網頁開發技術生態:1.H5包括HTML5、CSS3、JavaScript及相關API和技術;2.它提供更豐富、互動、流暢的用戶體驗,能在多設備上無縫運行;3.使用H5技術棧可以創建響應式網頁和復雜交互功能。

H5和HTML5:網絡開發中常用的術語H5和HTML5:網絡開發中常用的術語Apr 13, 2025 am 12:01 AM

H5與HTML5指的是同一個東西,即HTML5。 HTML5是HTML的第五個版本,帶來了語義化標籤、多媒體支持、畫布與圖形、離線存儲與本地存儲等新功能,提升了網頁的表現力和交互性。

H5指的是什麼?探索上下文H5指的是什麼?探索上下文Apr 12, 2025 am 12:03 AM

H5referstoHTML5,apivotaltechnologyinwebdevelopment.1)HTML5introducesnewelementsandAPIsforrich,dynamicwebapplications.2)Itsupportsmultimediawithoutplugins,enhancinguserexperienceacrossdevices.3)SemanticelementsimprovecontentstructureandSEO.4)H5'srespo

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱工具

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)