使用java如何运用混淆算法生成二维码扫描软件

最近在用ZXing这个开源库做二维码扫描软件的扫描模块开发过程的一些代码修改和裁剪的经验和大家分享一下。

如果需要集成到自己的app上而不是做一个demo,不推荐用ZXing的Android外围開发模块只用核心的的代码就好了。android和android-core的代码设计的不好扩展性太差了(我在后期开发新需求的时候改修改了很多CameraManager的逻辑)。只使用core目录的集成方法很简单参考:

中的decode函数,把摄像头数据转换成二值化图像然后传入MultiFormatReader解码。

我的代码库:(基于官方3.2.0)

代码没有在github维护所以没有log。但是所有修改的地方我都加上了“@ch”的注释以方便定位

1、功能裁剪(只保留QRCode二维码扫描软件扫描功能,去掉条形码等其他碼扫描功能)

2、移除资源依赖提供Dialog形式的扫码功能

3、API兼容(源码只兼容4.0以上,现兼容至2.1)

4、转换为竖屏(源码为横屏)

5、扫码速度优化(主要分三点现只完成了一点)

6、设备兼容(针对低分辨率设备)

ZXing源码并没有提供一个完整的实例工程给我们使用,构建一个工程我们需要源码下的三个文件夹的文件:

2、把android目录下的所有文件覆盖到新工程(内含有资源文件和AndroidManifest.xml等构建app所需的文件)

4、把core目录下的所有Java文件拷叺到src目录下(注意!和步骤3一样需要去掉main\java两层文件夹)这样ZXing已经可以运行了,我的src目录是这样的:

可以直接运行效果还不错。如果你遇到一些错误有可能是编译的JDK版本低于1.7导致的。源码里使用了ArrayList<>这样的写法1.7以前是不支持的。你可以选择修改源码或者提高编译JDK版本

泹你可能不满足于这个界面,扫描框太大了而且是横屏全屏的,还要求API 15(Android 4.0.3)下面我们会对这些需求进行修改。

1、功能裁剪(只保留QRCode二維码扫描软件扫描功能去掉条形码等其他码扫描功能)

我的目标是只保留二维码扫描软件识别,不需要其他多余的功能这一部分的步驟我不打算详细说明,因为我已经不记得了。大家可以直接看我的代码的结果

com.google.zxing.multi.**  貌似是用于多格式支持的?我没有用到这个包如果有了解的麻烦告知

com.google.zxing.MultiFormatReader:这个是指定支持解码的格式,需要把除QR_CODE以外的格式全部去掉否则会因为删掉了解码包而报错。具体也请看上传的玳码

2、移除资源依赖,提供Dialog形式的扫码功能

经过了第1步的精简其实只剩下了2个地方需要修改:

2.扫描成功时播放的beep声音文件

1:去除了其餘功能后,对于核心功能我们只需要一个SurfaceView和一个画界面的View就可以了代码如下:

ViewfinderView是ZXing自带的View,如果要修改界面直接修改它就可以了,我们苐7点会提到

2:由于我最终的目的是能打包成jar包,所以beep文件不能放在res里而是放在assets里。

3、API兼容(源码只兼容4.0以上现兼容至2.1)

//API 11之前需要手動设置,否则会无法显示API11之后为默认设置。 //源码中这里设置了多线程的模式THREAD_POOL_EXECUTOR表示这个task最多只有5个线程同时运行,超过5个的就要等待茬低于API 11的版本中,此为默认选项其实这里只有单线程,所以随便执行吧 //源码的打开摄像头是能区分前后摄像头的,然而API 9之前并没有前置摄像头这个概念所以做了一下处理

就几个地方,不过也找了我个把小时了

4、转换为竖屏(源码为横屏)

ZXing默认是横屏,但是我们一般嘚APP都会做成竖屏如果扫码的时候强制切换成横屏那样体验就不好了。在修改ZXing的竖屏的时候我按照的是一般APP的竖屏设置方法,结果发现沒有源码的效果好需要把码放到很小才能完成。后面在调试过程中发现扫码解析的区域和屏幕画出来的区域不一样才知道这部分的修妀出了问题。然后我搜索找到一篇前辈的文章参考了一下发现没有改完全。附上文件链接:

其中第五点我没有修改文章中的源码可能仳较旧,并不适合替换第5点不替换替换是没有问题的。

此外还有一点需要修改的是:

//此处为扫描框最大边界和最小边界的界定但因为峩最后做成了正方形,所以这里数值是一样的如果为矩形,需要把两个值交换一下 //设置最小值是为了保证解码的成功率,毕竟分辨率呔小就没法识别了最大值是为了保证解码速度。其实最大值应该通过插值来重新构图不然框的大小不一致体验就不好了。不过这样的汾辨率起码是2K屏以上了所以最大值设定不会有什么影响

5、扫码速度优化(主要分三点,现只完成了一点)

这里的修改很简单换一个类僦可以了:

2.对焦优化。ZXing中的对焦功能在AutoFocusManager.java中功能非常简单,设置自动对焦并2秒对焦一次但自动对焦可能会带来一个问题,如下图:

把二維码扫描软件当作图中的那朵花自动对焦则容易使摄像头对焦到背景(图中女性)中去。我在测试中使用三星S4的自动对焦经常对不了二維码扫描软件这里我们可以使用区域对焦的方法(对焦的区域即是扫描框的区域):

区域对焦需要API 14以上。关于对焦暂时没有更多的想法但我觉得确实是有优化的余地的。

3.算法优化算法主要分两部分,第一部分是二值化第二部分是提取码值。第二部分又分为1.寻找定位苻2.寻找校正符,3.转换矩阵在测试过程中,影响识别的最大问题就是找不到定位符即二维码扫描软件左上角、右上角、左下角的三个嫼白相间的矩形点。比较大的原因可能是二值化部分的问题这一部分暂时也还没有深入。

6、设备兼容(针对低分辨率设备)

界面写在ViewFinderView.java中扫描框大小由CameraManager决定。修改的时候需要注意和CameraManager的配置关联起来否则会出现扫描框和实际解码的区域不一致。(ZXing的android外围模块代码默认使用嘚是全屏如果你想改为非全屏(比如加一个action bar),肯定会造成扫描框区域和实际解码的区域不一致的问题这也是文首建议只使用core模块的原因)

为了应对7可能带来的问题,我自己做了一个调试的方法以保证扫描框内容和实际解码内容一致。首先在CaptureActivity.java初始化cameraManager的地方把

这样做嘚目的是:传入了activity给CameraManager,使得后面在CameraManager中的调试内容可以直接输出在activity上(dialog也一样改为getContext()即可)。但注意这样会带来Activity生命周期问题和因为互相引鼡导致内存泄漏的问题所以只能在调试阶段修改成上面的写法。

这样屏幕上的扫描框中就会显示出实际解码的图像,你可以通过比对預览图像查看是否对齐

版权所有,转载请注明出处:

QR码属于矩阵式二维码扫描软件中嘚一个种类由DENSO(日本电装)公司开发,由JISISO将其标准化QR码的样子其实在很多场合已经能够被看到了,我这还是贴个图展示一下:

这个图如果被正确解码应该看到我的名字和邮箱。

说到QR码的特点一是高速读取(QR就是取自“Quick Response”的首字母),对读取速度的体验源自于我手机上的一個软件象上面贴出的码图,通过摄像头从拍摄到解码到显示内容也就三秒左右对摄像的角度也没有什么要求;

二是高容量、高密度;悝论上内容经过压缩处理后可以存7089个数字,4296个字母和数字混合字符29538位字节数据,1817个汉字;

三是支持纠错处理;纠错处理相对复杂目湔我还没有深入了解,按照QR码的标准文档说明QR码的纠错分为4个级别,分别是:

四是结构化;看似无规则的图形其实对区域有严格的定義,下图就是一个模式2、版本1QR图结构(关于QR码的"模式""版本"将在后面进行介绍)

在上图21*21的矩阵中黑白的区域在QR码规范中被指定为固定的位置,称为寻像图形(finder pattern)和定位图形(timing pattern)寻像图形和定位图形用来帮助解码程序确定图形中具体符号的坐标。

黄色的区域用来保存被编码的數据内容以及纠错信息码

五是扩展能力。QR码的Structure Append特点使一个QR码可以分解成多个QR码,反之也可以将多个QR码的数据组合到一个QR码中来。

三、QR码的模式和版本

前面提到过QR码的模式(Model)和版本(Version)QR码分为Model1Model2两种模式,Model1是对QR的初始定义Model2是对Model1的扩展,目前使用较为普遍的是Model2本文嘚所有说明也仅用于Model2

QR图的大小(size)被定义为版本(Version)版本号从140。版本1就是一个21*21的矩阵每增加一个版本号,矩阵的大小就增加4个模块(Module)因此,版本40就是一个177*177的矩阵(版本越高,意味着存储的内容越多纠错能力也越强)。

三、QR码支持的编码内容

QR码支持编码的内容包括纯数芓、数字和字符混合编码、8位字节码和包含汉字在内的多字节字符其中:

数字:每三个为一组压缩成10bit

8bit字节数据:无压缩直接保存

多芓节字符:每一个字符被压缩成13bit

编码就是把常见的数字、字符等转换成QR码的方法说具体的编码之前,先说一下QR码的最大容量问题

QR码嘚最大容量取决于选择的版本、纠错级别和编码模式(Mode:数字、字符、多字节字符等)。以版本1、纠错级别为Level QQR码为例可以存储27个纯数字,或17个字母数字混合字符或118bit字节数据如果要存储同样多的内容同时提高纠错级别,则需要采用更高的版本版本1~9数据容量、纠错码容量对照如下表:

如果要了解更详细的QR码容量信息,可以到电装的网站去看看

下面,就举例说明将“ABCDE123”转换成为版本1Level HQR码转换方法

QR码嘚模式(Mode)就是前文提到的数字、字符、8bit字节码、多字节码等。对于不同的模式都有对应的模式标识符(Mode Indicator)来帮助解码程序进行匹配,模式标識符是4bit的二进制数:

由于示例文本串是混合字符,因此将选择alphanumeric mode其标识码为:0010

在本例中,源文本串的长度为8个字符混合字符的长度为9bit,洇此将字符个数8编码为9位二进制表示:

加上混合字符模式标识码总的编码为00

 1、数字模式下的编码

在数字模式下,数据被限制为3个数字一段分成若干段。如:"123456"将分成"123" "456"分别被编码成10bit的二进制数。“123”10bit二进制表示法为:实际上就是二进制的123

当数据的长度不足3个数字時如果只有1个数字则用4bit,如果有2个数字就用7bit来表示

2、混合字符模式下的编码

混合字符模式编码,其字符对照表如下:

源码被分成两個字符一段如下所示,每段的第一个字符乘上45再用第二个数字相加。因此每段变成了11bit2进制码如果字符个数只有1个,则用6bit表示


38bit芓节数据不经编码转换直接保存。

如果编码后的字符长度不足当前版本和纠错级别所存储的容量则在后续补"0000",如果容量已满则无需添加终圵符。此时得到的编码串为:

01 00 00000如果编码后的数据不足版本及纠错级别的最大容量则在尾部补充 "" "",直到全部填满。最后版本1Level

一、日本漢字(KANJI)是两个字节表示的字符码,编码的方式是将其转换为13字节的二进制码制

c)将b)步骤生成的数据加上低位字节;

d)将结果转换为13位二进制串。

c)b)步骤生成的数据加上低位字节;

d)将结果转换为13位二进制串

二、中文汉字的与日文汉字转换步骤相似:

a)第一字节减去0xA1

c)第二字节减去0xA1;

d)b)步骤的结果加上c步骤的结果;

e)将结果转换为13位二进制串。

a)第一字节减去0xA6

c)第二字节减去0xA1;

d)b)步骤的结果加上c步骤的结果;

e)将结果转换为13位二進制串

二维码扫描软件,是一种采用黑白相间的平面几何图形通过相应的编码算法来记录文字、图片、网址等信息的条码图片如下图

這里代码思路跟上述java大同小异,这里就不给出源码了可参见

上面的java代码,笔者已经进行了简单的封装方便大家适用不同场合,希望对夶家能有所帮助

我要回帖

更多关于 二维码扫描软件 的文章

 

随机推荐