当前位置:   article > 正文

Android Zbar和Zxing_android zbar zxing

android zbar zxing

Android Zbar和Zxing

96 
Trainee 
2016.12.02 15:12*  字数 1340  阅读 7687 评论 1

Android中用于二维码相关的库比较少,并且大多数已经不再维护(具体可见https://android-arsenal.com/tag/81)。其中最常用的是zxing和zbar,zxing项目是谷歌推出的用来识别多种格式条形码的开源项目,项目地址为https://github.com/zxing/zxing,zxing有多个人在维护,覆盖主流编程语言,也是目前还在维护的较受欢迎的二维码扫描开源项目之一。zbar则是主要用C来写的,速度极快,推出了iPhone的SDK和Android的相关调用方法(JNI),但这个项目已经有几年不维护了,目前并没有维护下去的意思,见https://github.com/ZBar/ZBar

Paste_Image.png

二维码优化

优化其实我觉得有两方面
(1)优化二维码生成算法,因为现在有专门做二维码的公司,说明二维码是可以做的更好识别的(微信扫二维码之所快,他们扫描的算法是一方面,但是二维码生成也是优化的)
(2)优化二维码的扫描算法

Zxing

zxing 的Demo修改后实现的扫描最大的问题就是角度,用zxing做的扫描需要与二维码差不多完全平行才能扫出来(图片识别出了问题),优化下zxing

  • 项目工程代码优化
    去掉不必要的类,比如我们的目的是扫描二维码,但其实原github上Zxing的Demo是可以扫描条形码,扫描获取到图片之后它会进行判断,类似的多余类去掉可以稍微提升一下速度(主要是使工程不那么臃肿)


    Paste_Image.png
  • 扩大扫描区域
    默认的是扫描框中才能识别二维码,但是你可以把扫描范围变大,我将扫描改成整个手机屏幕,这样,在识别的过程中,可能二维码还没整个进入框中,就已经识别出来了,让人觉得识别速度很快(缺点貌似就是生成的图像的数据变大,对手机的性能会有一定的要求,但是现在的手机基本都没问题)
  • 二分值算法
    二维码扫描精度和许多因素有关,最关键的因素是扫描算法。目前在图形识别领域中,较常用的二维码识别算法主要有两种,分别是HybridBinarizer和GlobalHistogramBinarizer这两种算法都是基于二值化,即将图片的色域变为黑白两个颜色,然后提取图形中的二维码矩阵。
    实际上,zxing中的HybridBinarizer继承GlobalHistogramBinarizer,并在此基础上做了功能性的改进。GlobalHistogramBinarizer算法适合于低端的设备,对手机的CPU和内存要求不高。但它选择了全部的黑点来计算,因此无法处理阴影和渐变这两种情况。HybridBinarizer算法在执行效率上要慢于GlobalHistogramBinarizer算法,但识别相对更有效。它专门为以白色为背景的连续黑色块二维码图像解析而设计,也更适合用来解析具有严重阴影和渐变的二维码图像。///
    和官方的介绍大致一样。然而目前的大部分二维码都是黑色二维码,白色背景的。不管是二维码扫描还是二维码图像识别,使用GlobalHistogramBinarizer算法的效果要稍微比HybridBinarizer好一些,识别的速度更快,对低分辨的图像识别精度更高。
    然而Demo中默认的是采用HybridBinarizer,我们将其替换成GlobalHistogramBinarizer算法

还有其他优化等等。。。。,但是做完之后发现并没有什么改变,我只能说如果你扫描的角度对了,是和二维码平行的话,二维码绝对识别的出来,而且特别快,如果你不是平行,你贴着屏幕扫二维码都还是扫不出来,最烦的是网上基本没有解决的办法,那些说优化过的Demo角度问题还是没有解决,所以我就去找了AndroidZbar的Demo

Zbar

网上基本都是说Android用Zxing,ios用Zbar,所以我开始没想在Android用Zbar,网上AndroidZbar Demo特别少,然后我就去了OSChina找,发现了github上的一个基于Zbar的开源库BGAQRCode

代码结构:

Paste_Image.png

主要用到的东西:

MainActivity.java

其实就是跳转界面

TestScanActivity

  1. public class TestScanActivity extends AppCompatActivity implements QRCodeView.Delegate {
  2. private static final String TAG = TestScanActivity.class.getSimpleName();
  3. private QRCodeView mQRCodeView;
  4. public void onCreate(Bundle savedInstanceState) {
  5. super.onCreate(savedInstanceState);
  6. setContentView(R.layout.activity_test_scan);
  7. setSupportActionBar((Toolbar) findViewById(R.id.toolbar));
  8. mQRCodeView = (ZBarView) findViewById(R.id.zbarview);
  9. mQRCodeView.setDelegate(this);
  10. }
  11. @Override
  12. protected void onStart() {
  13. super.onStart();
  14. mQRCodeView.startCamera();
  15. }
  16. @Override
  17. protected void onStop() {
  18. mQRCodeView.stopCamera();
  19. super.onStop();
  20. }
  21. @Override
  22. protected void onDestroy() {
  23. mQRCodeView.onDestroy();
  24. super.onDestroy();
  25. }
  26. private void vibrate() {
  27. Vibrator vibrator = (Vibrator) getSystemService(VIBRATOR_SERVICE);
  28. vibrator.vibrate(200);
  29. }
  30. //下面这个方法就是返回扫描结果的
  31. @Override
  32. public void onScanQRCodeSuccess(String result) {
  33. Log.i(TAG, "result:" + result);
  34. Toast.makeText(this, result, Toast.LENGTH_SHORT).show();
  35. vibrate();
  36. mQRCodeView.startSpot();
  37. }
  38. @Override
  39. public void onScanQRCodeOpenCameraError() {
  40. Log.e(TAG, "打开相机出错");
  41. }
  42. public void onClick(View v) {
  43. switch (v.getId()) {
  44. //开启扫描
  45. case R.id.start_spot:
  46. mQRCodeView.startSpot();
  47. break;
  48. //关闭扫描
  49. case R.id.stop_spot:
  50. mQRCodeView.stopSpot();
  51. break;
  52. case R.id.start_spot_showrect:
  53. mQRCodeView.startSpotAndShowRect();
  54. break;
  55. case R.id.stop_spot_hiddenrect:
  56. mQRCodeView.stopSpotAndHiddenRect();
  57. break;
  58. case R.id.show_rect:
  59. mQRCodeView.showScanRect();
  60. break;
  61. case R.id.hidden_rect:
  62. mQRCodeView.hiddenScanRect();
  63. break;
  64. case R.id.start_preview:
  65. mQRCodeView.startCamera();
  66. break;
  67. case R.id.stop_preview:
  68. mQRCodeView.stopCamera();
  69. break;
  70. case R.id.open_flashlight:
  71. mQRCodeView.openFlashlight();
  72. break;
  73. case R.id.close_flashlight:
  74. mQRCodeView.closeFlashlight();
  75. break;
  76. case R.id.scan_barcode:
  77. mQRCodeView.changeToScanBarcodeStyle();
  78. break;
  79. case R.id.scan_qrcode:
  80. mQRCodeView.changeToScanQRCodeStyle();
  81. break;
  82. }
  83. } ```
  84. ###R.layout.activity_test_scan

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
style="@style/MatchMatch">

  1. <cn.bingoogolapple.qrcode.zbar.ZBarView
  2. android:id="@+id/zbarview"
  3. style="@style/MatchMatch"
  4. app:qrcv_animTime="1000"
  5. app:qrcv_barCodeTipText="将条码放入框内,即可自动扫描"
  6. app:qrcv_barcodeRectHeight="140dp"
  7. app:qrcv_borderColor="@android:color/white"
  8. app:qrcv_borderSize="1dp"
  9. app:qrcv_cornerColor="@color/colorPrimaryDark"
  10. app:qrcv_cornerLength="20dp"
  11. app:qrcv_cornerSize="3dp"
  12. app:qrcv_customGridScanLineDrawable="@mipmap/custom_grid_scan_line"
  13. app:qrcv_isBarcode="false"
  14. app:qrcv_isOnlyDecodeScanBoxArea="false"
  15. app:qrcv_isShowDefaultGridScanLineDrawable="true"
  16. app:qrcv_isShowDefaultScanLineDrawable="true"
  17. app:qrcv_isShowTipBackground="true"
  18. app:qrcv_isShowTipTextAsSingleLine="false"
  19. app:qrcv_isTipTextBelowRect="false"
  20. app:qrcv_maskColor="#33FFFFFF"
  21. app:qrcv_qrCodeTipText="将二维码/条码放入框内,即可自动扫描"
  22. app:qrcv_rectWidth="200dp"
  23. app:qrcv_scanLineColor="@color/colorPrimaryDark"
  24. app:qrcv_toolbarHeight="56dp"
  25. app:qrcv_topOffset="90dp" />
  26. <include layout="@layout/toolbar"/>
  27. <include layout="@layout/view_control"/>

</RelativeLayout>```

基本只要改这上边两个类,代码比zxing简单N倍,扫描速度也够快是zxing的3~5倍(我觉得用zxing的公司可能做了大量代码算法优化),毕竟Zbar基于c,对于单纯的对扫描速度的有要求,就算我们们不优化代码,也满足我们的需要

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号