使用JavaScript根据图片获取条形码的方法


Posted in Javascript onJuly 04, 2017

最近在弄一个零售超市的项目,但是苦于需要自己录入数据,超市少的也有1000多种商品,自己一个一个录入肯定不太现实,所以考虑扫描商品的条形码,根据条形码获取商品的信息这样效率就高多了。

根据条形码获取商品信息这个在网上有很多api一般都是付费的费用不高,可以直接拿来用,这里就略过了。

这里重点说说JavaScript识别图片中的条形码。

开源库quaggaJS

项目地址:https://github.com/serratus/quaggaJS

这里要感谢大神提供这么牛B的js库,让我的想法得以实现!

这个库的使用方式也非常简单,在github上有很丰富的讲解,但是我只使用了其中一个扫描条形码图片,获取条形码的功能,所以我就直接把我需要的功能列举一个例子,有其他的需求的可以去上面的连接里面找。

页面部分

<html>
<body>
<section id="container" class="container">
 <div class="controls">
   <fieldset class="input-group">
     <input type="file" accept="image/*;capture=camera">
     <button>Rerun</button>
   </fieldset>
 </div>
 <div id="result_strip">
  <ul class="thumbnails"></ul>
 </div>
 <div id="interactive" class="viewport"><canvas class="imgBuffer" width="800" height="566"></canvas><canvas class="drawingBuffer" width="800" height="566"></canvas><br clear="all"></div>
</section>
<script src="jquery-1.11.0.min.js"></script>
<script src="quagga.min.js" type="text/javascript"></script>
<script src="file_input.js" type="text/javascript"></script>
</body>
</html>

JavaScript部分

$(function() {
   $(".controls button").on("click", function(e) {
    var input = document.querySelector(".controls input[type=file]");
    if (input.files && input.files.length) {
      Quagga.decodeSingle({
        inputStream: {
          size: 800 // 这里指定图片的大小,需要自己测试一下
        },
        locator: {
          patchSize: "medium",
          halfSample: false
        },
        numOfWorkers: 1,
        decoder: {
          readers: [{
            format: "ean_reader",// 这里指定ean条形码,就是国际13位的条形码
            config: {}
          }]
        },
        locate: true,
        src: URL.createObjectURL(input.files[0])
      }, function(result) {
         var code = result.codeResult.code,
          $node,
          canvas = Quagga.canvas.dom.image;
        // 将扫描得到的条形码打印出来
        $node = $('<li><div class="thumbnail"><div class="imgWrapper"><img /></div><div class="caption"><h4 class="code"></h4></div></div></li>');
        $node.find("img").attr("src", canvas.toDataURL());
        $node.find("h4.code").html(code);
        $("#result_strip ul.thumbnails").prepend($node);
      });
    }
  });
});

效果展示

使用JavaScript根据图片获取条形码的方法

以上所述是小编给大家介绍的使用JavaScript根据图片获取条形码的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JavaScript 利用Cookie记录用户登录信息
Dec 08 Javascript
JavaScript实现页面滚动图片加载(仿lazyload效果)
Jul 22 Javascript
读jQuery之十一 添加事件核心方法
Jul 31 Javascript
javascript阻止浏览器后退事件防止误操作清空表单
Nov 22 Javascript
基于jQuery实现返回顶部实例代码
Jan 01 Javascript
JS实现响应鼠标点击动画渐变弹出层效果代码
Mar 25 Javascript
全面解析jQuery $(document).ready()和JavaScript onload事件
Jun 08 Javascript
JavaScript中的Reflect对象详解(ES6新特性)
Jul 22 Javascript
JavaScript实现图片本地预览功能【不用上传至服务器】
Sep 20 Javascript
javascript设计模式 ? 简单工厂模式原理与应用实例分析
Apr 09 Javascript
javascript操作向表格中动态加载数据
Aug 27 Javascript
IDEA配置jQuery, $符号不再显示黄色波浪线的问题
Oct 09 jQuery
jquery拖动改变div大小
Jul 04 #jQuery
JavaScript无操作后屏保功能的实现方法
Jul 04 #Javascript
JS中type=&quot;button&quot;和type=&quot;submit&quot;的区别
Jul 04 #Javascript
5分钟打造简易高效的webpack常用配置
Jul 04 #Javascript
AngularJS实现表格的增删改查(仅限前端)
Jul 04 #Javascript
js CSS3实现卡牌旋转切换效果
Jul 04 #Javascript
JavaScript中三个等号和两个等号你了解多少
Jul 04 #Javascript
You might like
CI框架中集成CKEditor编辑器的教程
2014/06/09 PHP
PHP实现视频文件上传完整实例
2014/08/28 PHP
laravel安装和配置教程
2014/10/29 PHP
PHP实现链式操作的三种方法详解
2017/11/16 PHP
YII框架模块化处理操作示例
2019/04/26 PHP
JavaScript面象对象设计
2008/04/28 Javascript
JqGrid web打印实现代码
2011/05/31 Javascript
javascript实现的弹出层背景置灰-模拟(easyui dialog)
2013/12/27 Javascript
jQuery中appendTo()方法用法实例
2015/01/08 Javascript
JS动态修改图片的URL(src)的方法
2015/04/01 Javascript
基于jQuery通过jQuery.form.js插件使用ajax提交form表单
2015/08/17 Javascript
ECMA5数组的新增方法有哪些及forEach()模仿实现
2015/11/03 Javascript
js实现简单计算器
2015/11/22 Javascript
面包屑导航详解
2017/12/07 Javascript
vue el-table实现自定义表头
2019/12/11 Javascript
vue实现购物车功能(商品分类)
2020/04/20 Javascript
vue scroll滚动判断的实现(是否滚动到底部、滚动方向、滚动节流、获取滚动区域dom元素)
2020/06/11 Javascript
Laravel 如何在blade文件中使用Vue组件的示例代码
2020/06/28 Javascript
js回到页面指定位置的三种方式
2020/12/17 Javascript
对Pandas DataFrame缺失值的查找与填充示例讲解
2018/11/06 Python
初探利用Python进行图文识别(OCR)
2019/02/26 Python
python中可以声明变量类型吗
2020/06/18 Python
PyCharm+PyQt5+QtDesigner配置详解
2020/08/12 Python
Python页面加载的等待方式总结
2021/02/28 Python
美国嘻哈文化生活方式品牌:GLD
2018/04/15 全球购物
捷克母婴用品购物网站:Feedo.cz
2020/12/28 全球购物
什么是Linux虚拟文件系统VFS
2015/08/25 面试题
关于逃课的检讨书
2014/01/23 职场文书
《鞋匠的儿子》教学反思
2014/03/02 职场文书
我爱我校演讲稿
2014/05/21 职场文书
宪法宣传周工作方案
2014/05/26 职场文书
新闻编辑求职信
2014/07/13 职场文书
2015年库房工作总结
2015/04/30 职场文书
国庆节新闻稿
2015/07/17 职场文书
【js设计模式】SOLID五大设计原则
2022/03/24 Javascript
小程序实现侧滑删除功能
2022/06/25 Javascript