이 글에서는 QR 코드 스캔 효과를 얻기 위해 web/html5를 사용하여 카메라를 호출하는 방법을 소개합니다. 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.
html5(navigator.getUserMedia)를 사용하여 카메라를 호출하여 이미지 미디어 스트림을 캡처하고 Java 인터페이스를 호출하여 PHP를 통해 이미지 QR 코드를 구문 분석하여 QR 코드 분석을 수행하며 이를 비즈니스와 결합할 수 있습니다! 하지만 현재 지원하는 브라우저가 많지 않아 문제가 됩니다.
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 포트에서 소켓 모니터링을 허용하므로 모든 네트워크 프로그래밍 언어로 호출할 수 있습니다.
1 명령줄에서 jar 패키지를 시작합니다.
java -jar xxxxx.jar
성공적인 시작 후 포트 20147의 응용 프로그램을 볼 수 있습니다.
2 서비스 소켓 호출
PHP 호출 코드가 일시적으로 제공됩니다.
최종 효과:
브라우저 지원 상태
요약: 위 내용은 이 글의 전체 내용입니다. 모든 사람의 학습에 도움이 되기를 바랍니다. 더 많은 관련 튜토리얼을 보려면 Html5 비디오 튜토리얼을 방문하세요!
관련 추천:
위 내용은 web/html5는 카메라를 호출하여 QR 코드 스캔 효과를 얻습니다(코드 예)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!