热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Android上使用ZXing识别条形码与二维码的方法

这篇文章主要介绍了Android上使用ZXing识别条形码与二维码的方法,需要的朋友可以参考下

目前有越来越多的手机具备自动对焦的拍摄功能,这也意味着这些手机可以具备条码扫描的功能。手机具备条码扫描的功能,可以优化购物流程,快速存储电子名片(二维码)等。

本文所述实例就使用了ZXing 1.6实现条码/二维码识别。ZXing是个很经典的条码/二维码识别的开源类库,早在很久以前,就有开发者在J2ME上使用ZXing了,只不过需要支持JSR-234规范(自动对焦)的手机才能发挥其威力,而目前已经有不少Android手机具备自动对焦的功能。

本文代码运行的结果如下,使用91手机助手截图时,无法截取SurfaceView的实时图像:

本文使用了ZXing1.6的core,即把/zxing-1.6/core/下的src复制覆盖工程的src;另外还要使用到/zxing-1.6/android/下的PlanarYUVLuminanceSource.java。

此处需要注意:/zxing-1.6/android/ 是BarcodeScanner的源码,本文程序相当于BarcodeScanner的精简版,只保留最基本的识别功能。

本文完整源码点击此处本地下载。

源码目录结果如下图,ChecksumException.java下面还有很多源文件,截图尚未列出:

本文例子必须要开摄像头和自动对焦的权限,不然启动时会报异常,所用的权限如下:






main.xml源码如下,main.xml必须要用到FrameLayout才能重叠控件实现“范围框”的效果:

<&#63;xml version="1.0" encoding="utf-8"&#63;>


testCamera.java是主类,负责控制Camera和对图像做解码,源码如下:

package com.testCamera;
import java.util.Timer;
import java.util.TimerTask;
import com.google.zxing.BinaryBitmap;
import com.google.zxing.MultiFormatReader;
import com.google.zxing.Result;
import com.google.zxing.Android.PlanarYUVLuminanceSource;
import com.google.zxing.common.HybridBinarizer;
import android.app.Activity;
import android.graphics.Bitmap;
import android.hardware.Camera;
import android.os.Bundle;
import android.view.SurfaceView;
import android.view.View;
import android.widget.ImageView;
import android.widget.TextView;
public class testCamera extends Activity {
 /** Called when the activity is first created. */
 private SurfaceView sfvCamera;
 private SFHCamera sfhCamera;
 private ImageView imgView;
 private View centerView;
 private TextView txtScanResult;
 private Timer mTimer;
 private MyTimerTask mTimerTask;
 // 按照标准HVGA
 final static int width = 480;
 final static int height = 320;
 int dstLeft, dstTop, dstWidth, dstHeight;
 @Override
 public void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.main);
 this.setTitle("Android条码/二维码识别Demo-----hellogv");
 imgView = (ImageView) this.findViewById(R.id.ImageView01);
 centerView = (View) this.findViewById(R.id.centerView);
 sfvCamera = (SurfaceView) this.findViewById(R.id.sfvCamera);
 sfhCamera = new SFHCamera(sfvCamera.getHolder(), width, height,
 previewCallback);
 txtScanResult=(TextView)this.findViewById(R.id.txtScanResult);
 // 初始化定时器
 mTimer = new Timer();
 mTimerTask = new MyTimerTask();
 mTimer.schedule(mTimerTask, 0, 80);
 }
 class MyTimerTask extends TimerTask {
 @Override
 public void run() {
 if (dstLeft == 0) {//只赋值一次
 dstLeft = centerView.getLeft() * width
  / getWindowManager().getDefaultDisplay().getWidth();
 dstTop = centerView.getTop() * height
  / getWindowManager().getDefaultDisplay().getHeight();
 dstWidth = (centerView.getRight() - centerView.getLeft())* width
  / getWindowManager().getDefaultDisplay().getWidth();
 dstHeight = (centerView.getBottom() - centerView.getTop())* height
  / getWindowManager().getDefaultDisplay().getHeight();
 }
 sfhCamera.AutoFocusAndPreviewCallback();
 }
 }
 /**
 * 自动对焦后输出图片
 */
 private Camera.PreviewCallback previewCallback = new Camera.PreviewCallback() {
 @Override
 public void onPreviewFrame(byte[] data, Camera arg1) {
 //取得指定范围的帧的数据
 PlanarYUVLuminanceSource source = new PlanarYUVLuminanceSource(
  data, width, height, dstLeft, dstTop, dstWidth, dstHeight);
 //取得灰度图
 Bitmap mBitmap = source.renderCroppedGreyscaleBitmap();
 //显示灰度图
 imgView.setImageBitmap(mBitmap);
 BinaryBitmap bitmap = new BinaryBitmap(new HybridBinarizer(source));
 MultiFormatReader reader = new MultiFormatReader();
 try {
 Result result = reader.decode(bitmap);
 String strResult = "BarcodeFormat:"
  + result.getBarcodeFormat().toString() + " text:"
  + result.getText();
 txtScanResult.setText(strResult);
 } catch (Exception e) {
 txtScanResult.setText("Scanning");
 }
 }
 };
}

SFHCamera.java是Camera控制类,源码如下:

package com.testCamera;
import java.io.IOException;
import android.graphics.PixelFormat;
import android.hardware.Camera;
import android.util.Log;
import android.view.SurfaceHolder;
public class SFHCamera implements SurfaceHolder.Callback{
 private SurfaceHolder holder = null;
 private Camera mCamera;
 private int width,height;
 private Camera.PreviewCallback previewCallback;
 public SFHCamera(SurfaceHolder holder,int w,int h,Camera.PreviewCallback previewCallback) {
 this.holder = holder; 
 this.holder.addCallback(this); 
 this.holder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);
  width=w;
  height=h;
  this.previewCallback=previewCallback;
 }
 @Override
 public void surfaceChanged(SurfaceHolder arg0, int arg1, int arg2, int arg3) {
 Camera.Parameters parameters = mCamera.getParameters(); 
  parameters.setPreviewSize(width, height);//设置尺寸 
  parameters.setPictureFormat(PixelFormat.JPEG);
  mCamera.setParameters(parameters); 
  mCamera.startPreview();//开始预览
  Log.e("Camera","surfaceChanged");
 }
 @Override
 public void surfaceCreated(SurfaceHolder arg0) {
 mCamera = Camera.open();//启动服务 
  try { 
   mCamera.setPreviewDisplay(holder);//设置预览 
   Log.e("Camera","surfaceCreated");
  } catch (IOException e) { 
   mCamera.release();//释放 
   mCamera = null; 
  }
 }
 @Override
 public void surfaceDestroyed(SurfaceHolder arg0) {
 mCamera.setPreviewCallback(null);
 mCamera.stopPreview();//停止预览 
  mCamera = null;
  Log.e("Camera","surfaceDestroyed");
 }
 /**
 * 自动对焦并回调Camera.PreviewCallback
 */
 public void AutoFocusAndPreviewCallback()
 {
 if(mCamera!=null)
 mCamera.autoFocus(mAutoFocusCallBack);
 }
 /**
  * 自动对焦
  */
 private Camera.AutoFocusCallback mAutoFocusCallBack = new Camera.AutoFocusCallback() { 
  @Override 
  public void onAutoFocus(boolean success, Camera camera) {  
   if (success) { //对焦成功,回调Camera.PreviewCallback
    mCamera.setOneShotPreviewCallback(previewCallback); 
   } 
  } 
 };
}

其中testCamera.java的Camera.PreviewCallback previewCallback 是整个程序的逻辑核心,作为回调函数给SFHCamera.java的内部Camera类调用。

PS:本站还提供了一个功能非常强大的二维码生成工具,感兴趣的朋友可以参考一下:

http://tools.jb51.net/transcoding/jb51qrcode

希望本文实例对大家学习Android程序设计能有所帮助。


推荐阅读
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文讲述了如何通过代码在Android中更改Recycler视图项的背景颜色。通过在onBindViewHolder方法中设置条件判断,可以实现根据条件改变背景颜色的效果。同时,还介绍了如何修改底部边框颜色以及提供了RecyclerView Fragment layout.xml和项目布局文件的示例代码。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • Android Studio Bumblebee | 2021.1.1(大黄蜂版本使用介绍)
    本文介绍了Android Studio Bumblebee | 2021.1.1(大黄蜂版本)的使用方法和相关知识,包括Gradle的介绍、设备管理器的配置、无线调试、新版本问题等内容。同时还提供了更新版本的下载地址和启动页面截图。 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Google Play推出全新的应用内评价API,帮助开发者获取更多优质用户反馈。用户每天在Google Play上发表数百万条评论,这有助于开发者了解用户喜好和改进需求。开发者可以选择在适当的时间请求用户撰写评论,以获得全面而有用的反馈。全新应用内评价功能让用户无需返回应用详情页面即可发表评论,提升用户体验。 ... [详细]
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 本文介绍了brain的意思、读音、翻译、用法、发音、词组、同反义词等内容,以及脑新东方在线英语词典的相关信息。还包括了brain的词汇搭配、形容词和名词的用法,以及与brain相关的短语和词组。此外,还介绍了与brain相关的医学术语和智囊团等相关内容。 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
author-avatar
小秋秋
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有