這篇文章跟大家介紹如何用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('用户拒绝了浏览器请求媒体的权限', '提示'); } else if (error.NOT_SUPPORTED_ERROR) { alert('对不起,您的浏览器不支持拍照功能,请使用其他浏览器', '提示'); } else if (error.MANDATORY_UNSATISFIED_ERROR) { alert('指定的媒体类型未接收到媒体流', '提示'); } else { alert('系统未能获取到摄像头,请确保摄像头已正确安装。或尝试刷新页面,重试', '提示'); } }; //获取媒体的兼容代码,目前只支持(Firefox,Chrome,Opera) if (navigator.getUserMedia) { //qq浏览器不支持 if (navigator.userAgent.indexOf('MQQBrowser') > -1) { alert('对不起,您的浏览器不支持拍照功能,请使用其他浏览器', '提示'); 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('对不起,您的浏览器不支持拍照功能,请使用其他浏览器'); return false; } if(flag){ alert('为了获得更准确的测试结果,请尽量将二维码置于框中,然后进行拍摄、扫描。 请确保浏览器有权限使用摄像功能'); } //这个是拍照按钮的事件, $("#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['img']; if (preg_match('/^(data:\s*image\/(\w+);base64,)/', $base64_image_content, $result)) { $type = $result[2]; $new_file = "./2.{$type}"; if (file_put_contents($new_file, base64_decode(str_replace($result[1], '', $base64_image_content)))){ $code=utils::deCodeBitMap("2.png","192.168.46.123",20147); echo '{"status":"success","data":"'.trim($code).'"}'; }else{ echo '{"status":"write error","data":"NO"}'; } }else{ echo '{"status":"preg error","data":"NO"}'; } ?>
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呼叫程式碼
#最終效果:
#瀏覽器支援情況
#總結:以上就是這篇文章的全部內容,希望對大家的學習有所幫助。更多相關教學請造訪Html5影片教學!
相關推薦:
#以上是web/html5呼叫攝影機實現二維碼掃描效果(程式碼實例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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

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

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

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

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

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

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

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


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

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

SublimeText3 Linux新版
SublimeText3 Linux最新版

SublimeText3漢化版
中文版,非常好用

Atom編輯器mac版下載
最受歡迎的的開源編輯器

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