html5移动端页面上html5调用本地摄像头手机摄像头扫描二维码并获取二维码信息代码?

Html5实现二维码扫描并解析
作者:佚名
字体:[ ] 来源:互联网 时间:01-20 15:23:41
这篇文章主要介绍了Html5实现二维码扫描并解析 的相关资料,需要的朋友可以参考下
引子: 最近公司项目有个需求,微博客户端中, h5 的页面上的某个按钮能够与native 交互呼起摄像头,扫描二维码并且解析。在非微博客户端中(微信或者是原生浏览器,如:safari)呼起系统的拍照或者上传图片按钮,通过拍照或者上传图片解析二维码。 第二种方案需要在前端 js 解析二维码。这样依赖一个第三方的解析库jsqrcode。这个库已经支持在浏览器端呼起摄像头的操作了,但是依赖一个叫getUserMedia的属性。该属性移动端的浏览器支持的都不是很好,所以只能间接的上传图片的方式解析二维码。 getUserMedia属性兼容浏览器列表:
首先感谢 jsqrcode 的开发者,提供这么优秀的解析二维码的代码,为我减少了很大的工作量。jsqrcode 地址:我的代码库地址: 1.解决的问题: 1.能够在微博客户端呼起摄像头扫描二维码并且解析; 2.能够在原生浏览器和微信客户端中扫描二维码并且解析; 2.优点: web端或者是 h5端可以直接完成扫码的工作; 3.缺点: 图片不清晰很容易解析失败(拍照扫描图片需要镜头离二维码的距离很近),相对于 native 呼起的摄像头解析会有1-2秒的延时。 说明: 此插件需要配合zepto.js 或者 jQuery.js使用 使用方法: 1.在需要使用的页面按照下面顺序引入lib目录下的 js 文件 代码如下:&script src="lib/zepto.js"&&/script& &script src="lib/qrcode.lib.min.js"&&/script& &script src="lib/qrcode.js"&&/script&
2.自定义按钮的 html 样式 因为该插件需要使用&input type=&file& /& ,该 html 结构在网页上面是有固定的显示样式,为了能够自定义按钮样式,我们可以按照下面的示例代码结构嵌套代码 代码如下:&div class="qr-btn" node-type="jsbridge"&扫描二维码1 &input node-type="jsbridge" type="file" name="myPhoto" value="扫描二维码1" /& &/div& 然后设置 input 按钮的 css 隐藏按钮,比如我使用的是属性选择器 代码如下:input[node-type=jsbridge]{ visibility: }这里我们只需要按照自己的需要定义class=&qr-btn&的样式即可。 3.在页面上初始化 Qrcode 对象 代码如下://初始化扫描二维码按钮,传入自定义的 node-type 属性 $(function() { Qrcode.init($('[node-type=jsbridge]')); });
主要代码解析 代码如下:(function($) { var Qrcode = function(tempBtn) { //该对象只支持微博域下的解析,也就是说不是微博域下的页面只能用第二种方案解析二维码 if (window.WeiboJSBridge) { $(tempBtn).on('click', this.weiBoBridge); } else { $(tempBtn).on('change', this.getImgFile); } }; Qrcode.prototype = { weiBoBridge: function() { WeiboJSBridge.invoke('scanQRCode', null, function(params) { //得到扫码的结果 location.href=params. }); }, getImgFile: function() { var _this_ = var imgFile = $(this)[0]. var oFile = imgFile[0]; var oFReader = new FileReader(); var rFilter = /^(?:image\/bmp|image\/cis\-cod|image\/gif|image\/ief|image\/jpeg|image\/jpeg|image\/jpeg|image\/pipeg|image\/png|image\/svg\+xml|image\/tiff|image\/x\-cmu\-raster|image\/x\-cmx|image\/x\-icon|image\/x\-portable\-anymap|image\/x\-portable\-bitmap|image\/x\-portable\-graymap|image\/x\-portable\-pixmap|image\/x\-rgb|image\/x\-xbitmap|image\/x\-xpixmap|image\/x\-xwindowdump)$/i; if (imgFile.length === 0) {
} if (!rFilter.test(oFile.type)) { alert("选择正确的图片格式!");
} //读取图片成功后执行的代码 oFReader.onload = function(oFREvent) { qrcode.decode(oFREvent.target.result); qrcode.callback = function(data) { //得到扫码的结果 location.href = }; }; oFReader.readAsDataURL(oFile); }, destory: function() { $(tempBtn).off('click'); } }; //初始化 Qrcode.init = function(tempBtn) { var _this_ = var inputD tempBtn.each(function() { new _this_($(this)); }); $('[node-type=qr-btn]').on('click', function() { $(this).find('[node-type=jsbridge]')[0].click(); }); }; window.Qrcode = Q })(window.Zepto ? Zepto : jQuery); 样例展示 1.呼起前的页面
2.呼起后的页面
大家感兴趣的内容
12345678910
最近更新的内容h5调用摄像头的实现方法
作者:佚名
字体:[ ] 来源:互联网 时间:06-01 09:54:27
下面小编就为大家带来一篇h5调用摄像头的实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
&!DOCTYPE&html&&
&lang=&zh-CN&&&
&charset=&UTF-8&&&
GetUserMedia实例&&
&id=&video&&autoplay&&
&type=&text/javascript&&&
var&getUserMedia&=&(navigator.getUserMedia&||&navigator.webkitGetUserMedia&||&navigator.mozGetUserMedia&||&navigator.msGetUserMedia); &&
getUserMedia.call(navigator,&{ &&
video:&true, &&
audio:&true &&
},&function(localMediaStream)&{ &&
var&video&=&document.getElementById('video'); &&
video.src&=&window.URL.createObjectURL(localMediaStream); &&
video.onloadedmetadata&=&function(e)&{ &&
console.log(&Label:&&&+&localMediaStream.label); &&
console.log(&AudioTracks&&,&localMediaStream.getAudioTracks()); &&
console.log(&VideoTracks&&,&localMediaStream.getVideoTracks()); &&
},&function(e)&{ &&
console.log('Reeeejected!',&e); &&
以上这篇h5调用摄像头的实现方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
大家感兴趣的内容
12345678910
最近更新的内容CSS3网页右侧悬浮固定二维码扫描与在线客服等功能代码
下载资源()次
阅读次数()次
发布时间:
用法简介:
CSS3网页右侧悬浮固定二维码扫描与在线客服等功能代码。文件引用:.toolbar-item,.toolbar-layer{background:url(../images/toolbar.png)&no-}
.toolbar{position:right:0bottom:50}/*假设网页宽度为1200px,导航条在右侧悬浮*/
.toolbar-item{display:width:52height:52margin-top:1position:-moz-transition:background-position&1s;-ms-transition:background-position&1s;-o-moz-transition:background-position&1s;-webkit-moz-transition:background-position&1s;transition:background-position&1s;}
.toolbar-item:hover&.toolbar-layer{opacity:1;filter:alpha(opacity=100);transform:scale(1);-webkit-transform:scale(1);-moz-transform:scale(1);-ms-transform:scale(1);-o-transform:scale(1);}
.toolbar-item-weixin{background-position:0&-798}
.toolbar-item-weixin:hover{background-position:0&-860}
.toolbar-item-weixin&.toolbar-layer{height:212background-position:0&0;}
.toolbar-item-feedback{background-position:0&-426}
.toolbar-item-feedback:hover{background-position:0&-488}
.toolbar-item-app{background-position:0&-550}
.toolbar-item-app:hover{background-position:0&-612}
.toolbar-item-app&.toolbar-layer{height:194background-position:0&-222}
.toolbar-item-top{background-position:0&-674}
.toolbar-item-top:hover{background-position:0&-736}
.toolbar-layer{position:right:46bottom:-10width:172opacity:0;filter:alpha(opacity=0);
transform-origin:&95%&95%;-moz-transform-origin:&95%&95%;-ms-transform-origin:&95%&95%;-o-transform-origin:&95%&95%;-webkit-transform-origin:&95%&95%;transform:scale(0.01);
-moz-transform:scale(0.01);-ms-transform:scale(0.01);-o-transform:scale(0.01);-webkit-transform:scale(0.01);transition:all&1s;-moz-transition:all&1s;-ms-transition:all&1s;-o-transition:all&1s;-webkit-transition:all&1s;}
相关标签:
网友评论:
一、不得利用本站危害国家安全、泄露国家秘密,不得侵犯国家社会集体的和公民的合法权益,不得利用本站制作、复制和传播不法有害信息!
二、互相尊重,对自己的言论和行为负责。
什么是邮箱订阅?
邮箱订阅是xw素材网为jquery爱好者与web程序员提供一项以邮箱的方式发送最新jquery资源与素材资源的模式,用户只需在左侧填写正确的邮箱用户名与邮箱地址我们将每天推荐最新优质资源到用户邮箱。当然每份邮箱都会有一个取消订阅按钮,当用户点击取消按钮时我们将会停止对用户发送邮箱资源推送。再次感谢大家对xw素材网的支持与关注。

我要回帖

更多关于 html5调用摄像头录像 的文章

 

随机推荐