运用html5(navigator.getUserMedia)挪用摄像头抓拍图片媒体流,经由历程php挪用java接口剖析图片二维码,完成二维码剖析,可连系本身的营业!不过现在支撑的浏览器不多是个题目。
html/js
<!DOCTYPE html> <html><head> <title>HTML5 code Reader</title> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> </head> <style type="text/css"> html, body { height: 100%; width: 100%; text-align:center; } </style> <script src="jquery-1.9.1.js"></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> <body> <p id="support"></p> <p id="contentHolder"> <video id="video" width="320" height="320" autoplay> </video> <canvas style="display:none; background-color:#F00;" id="canvas" width="320" height="320"> </canvas> <br/> <button id="snap" style="display:none; height:50px; width:120px;">最先扫描</button> </p> </body></html>
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视频教程!
相干引荐:
php公益培训视频教程
以上就是web/html5挪用摄像头完成二维码扫描效果(代码实例)的细致内容,更多请关注ki4网别的相干文章!