# Android-Zxing
**Repository Path**: elim132/Android-Zxing
## Basic Information
- **Project Name**: Android-Zxing
- **Description**: android google zxing 可配置扫描框、线样式 ,生成二维码(文字、联系人)
- **Primary Language**: Android
- **License**: Not specified
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2021-04-01
- **Last Updated**: 2021-04-02
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
### 一、概述
相信Adnroid开发都知道,有四款扫描器,[Zxing](https://github.com/zxing/zxing) 、[Zbar](https://github.com/zbar/zbar) ,[Barcode4J](https://sourceforge.net/projects/barcode4j/files/)、[OkapiBarcode](https://github.com/woo-j/OkapiBarcode) 前二者应用较广泛,至于介绍与区别就在此阐述,网上有很多。此文主要介绍在在使用过程中,官方客户端各种达不到需求。相信很多童鞋都有此体会,所以借此机会就在Zxing 官方客户端基础上修改,去除无用功能并二次封装达到可扩展。
- 官方客户端目前问题汇总
- 设置功能多余
- 竖屏后不能正向扫描条形码
- 扫描框大小、颜色、扫描线配置不够灵活
- 无生成二维码、主动识别二维码功能
- 介于以上问题,于是该库就华丽的诞生
- 修复竖屏不能正向扫描条形码
- 可定制扫描框与扫描线样式
- 加入创建二维码、识别图片中的二维码功能
### 二、效果图
### 三、[下载APK体验](https://www.90pan.com/b2339598)或手机扫描下面二维码
### 四、引用
## 1、在线 本库内部已集成`zxing:core:3.4.0`
- 依赖使用 Gradle 构建时添加一下即可
```javascript
compile 'com.mylhyl:zxingscanner:2.2.0'
```
## 2、离线jar,需要手动添加 Zxing 核心库
- [jar包](https://github.com/mylhyl/Android-Zxing/tree/master/preview/lib)
- 也可自己打包jar文件打开终端,切换置项目根据目录,执行命令:gradlew makeJar
- [最新Zxing核心库点击查看](http://jcenter.bintray.com/com/google/zxing/core/)取出aar
- 也可使用Gradle构建时如下:
```javascript
compile 'com.google.zxing:core:3.4.0'
```
[gradle makeJar](http://blog.csdn.net/hupei/article/details/51886221) 或者参考下图,在android studio中执行

- [直接下载jar](preview)
### 五、使用
[例子](https://github.com/mylhyl/Android-Zxing/blob/master/sample/src/main/java/com/mylhyl/zxing/scanner/sample/OptionsScannerActivity.java)
直接在`layout xml`使用`ScannerView`即可
```xml
```
###### 注意生命周期中的使用
重写`onResume`调用`mScannerView.onResume();`
```java
@Override
protected void onResume() {
mScannerView.onResume();
super.onResume();
}
@Override
protected void onPause() {
mScannerView.onPause();
super.onPause();
}
```
注册扫描成功监听器`mScannerView.setOnScannerCompletionListener`
```java
/**
* 扫描成功后将调用
*
* @param rawResult 扫描结果
* @param parsedResult 结果类型
* @param barcode 扫描后的图像
*/
void OnScannerCompletion(Result rawResult, ParsedResult parsedResult, Bitmap barcode);
```
开启闪光灯
```java
mScannerView.toggleLight(true);//开
mScannerView.toggleLight(false);//关
```
调用如下方法获取类型
```java
ParsedResultType type = parsedResult.getType();
```
可根据`type`强转为相应的对象,按项目需求处理。每个项目都有不同的需求,所以此库将最终处理结果丢给你们自己咯,想怎么玩就怎么玩,下面代码是在 sample 中
```java
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;
}
```
生成二维码使用
```java
//联系人类型
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();
```
解析图中二维码
```java
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](https://github.com/mylhyl/Android-Zxing/blob/master/zxingscanner/src/main/java/com/mylhyl/zxing/scanner/ScannerOptions.java)
### 七、注意事项
权限
```xml
```
### 八、常见问题
* 对于`setLaserFrameTopMargin`方法,扫描区域偏移的问题[issues-13](https://github.com/mylhyl/Android-Zxing/issues/13)
* 可以在扫描成功后,调用`restartPreviewAfterDelay`连续扫描
* 对于加密后的二维码,判断二维码类型可以如下:
```java
//重新包装`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;
}
```
### 联系方式
* 可能会因为工作忙碌原因没有及时回复,大家方便的话可以加我个人微信号:48025211,备注:github