相信Adnroid开发都知道,有四款扫描器,Zxing 、Zbar ,Barcode4J、OkapiBarcode 前二者应用较广泛,至于介绍与区别就在此阐述,网上有很多。此文主要介绍在在使用过程中,官方客户端各种达不到需求。相信很多童鞋都有此体会,所以借此机会就在Zxing 官方客户端基础上修改,去除无用功能并二次封装达到可扩展。
- 官方客户端目前问题汇总
- 设置功能多余
- 竖屏后不能正向扫描条形码
- 扫描框大小、颜色、扫描线配置不够灵活
- 无生成二维码、主动识别二维码功能
- 介于以上问题,于是该库就华丽的诞生
- 修复竖屏不能正向扫描条形码
- 可定制扫描框与扫描线样式
- 加入创建二维码、识别图片中的二维码功能
三、下载APK体验或手机扫描下面二维码
- 依赖使用 Gradle 构建时添加一下即可
compile 'com.mylhyl:zxingscanner:2.1.6'
- jar包
- 也可自己打包jar文件打开终端,切换置项目根据目录,执行命令:gradlew makeJar
- 最新Zxing核心库点击查看取出aar
- 也可使用Gradle构建时如下:
compile 'com.google.zxing:core:3.3.3'
gradle makeJar 或者参考下图,在android studio中执行
直接在layout xml
使用ScannerView
即可
<com.mylhyl.zxing.scanner.ScannerView
android:id="@+id/scanner_view"
android:layout_width="match_parent"
android:layout_height="match_parent" />
重写onResume
调用mScannerView.onResume();
@Override
protected void onResume() {
mScannerView.onResume();
super.onResume();
}
@Override
protected void onPause() {
mScannerView.onPause();
super.onPause();
}
注册扫描成功监听器mScannerView.setOnScannerCompletionListener
/**
* 扫描成功后将调用
*
* @param rawResult 扫描结果
* @param parsedResult 结果类型
* @param barcode 扫描后的图像
*/
void OnScannerCompletion(Result rawResult, ParsedResult parsedResult, Bitmap barcode);
开启闪光灯
mScannerView.toggleLight(true);//开
mScannerView.toggleLight(false);//关
调用如下方法获取类型
ParsedResultType type = parsedResult.getType();
可根据type
强转为相应的对象,按项目需求处理。每个项目都有不同的需求,所以此库将最终处理结果丢给你们自己咯,想怎么玩就怎么玩,下面代码是在 sample 中
switch (type) {
case ADDRESSBOOK:
AddressBookParsedResult addressBook = (AddressBookParsedResult) parsedResult;
bundle.putSerializable(Intents.Scan.RESULT, new AddressBookResult(addressBook));
break;
case URI:
URIParsedResult uriParsedResult = (URIParsedResult) parsedResult;
bundle.putString(Intents.Scan.RESULT, uriParsedResult.getURI());
break;
case TEXT:
bundle.putString(Intents.Scan.RESULT, rawResult.getText());
break;
}
生成二维码使用
//联系人类型
Bitmap bitmap = new QREncode.Builder(this)
.setParsedResultType(ParsedResultType.ADDRESSBOOK)
.setAddressBookUri(contactUri).build().encodeAsBitmap();
//文本类型
Bitmap bitmap = new QREncode.Builder(this)
.setColor(getResources().getColor(R.color.colorPrimary))//二维码颜色
//.setParsedResultType(ParsedResultType.TEXT)//默认是TEXT类型
.setContents("我是石头")//二维码内容
.setLogoBitmap(logoBitmap)//二维码中间logo
.build().encodeAsBitmap();
解析图中二维码
public static void decodeQR(String picturePath, OnScannerCompletionListener listener);
public static void decodeQR(Bitmap srcBitmap, final OnScannerCompletionListener listener)
说明:1.6.0
以后版本将废弃ScannerView
样式设置,使用新增ScannerOptions
,后续版本只会在ScannerOptions
中维护。
具体api请看ScannerOptions.Builder
权限
<uses-permission android:name="android.permission.CAMERA" />
- 对于
setLaserFrameTopMargin
方法,扫描区域偏移的问题issues-13 - 可以在扫描成功后,调用
restartPreviewAfterDelay
连续扫描 - 对于加密后的二维码,判断二维码类型可以如下:
//重新包装`Result`,`decryptText`为解密后的内容
Result decryptResult = new Result(decryptText, rawResult.getRawBytes(),
rawResult.getNumBits(), rawResult.getResultPoints(),
rawResult.getBarcodeFormat(), rawResult.getTimestamp());
//转换扫描结果为类型枚举
ParsedResult decryptParsedResult = Scanner.parseResult(decryptResult);
final ParsedResultType decryptType = decryptParsedResult.getType();
switch (decryptType) {
//类型分支
case :
break;
}