Android基于zxing的二维码(网格)扫描 仿支付宝网格扫描
前言:对于二维码扫描我们使用的是开源框架Zxing或者Zbar,这里使用基于zxing的二维码扫描,类似支付宝网格扫描。
二维码原理介绍:
二维码是用某种特定的几何图形按一定的规律在平面上分布的黑白相间的图形记录数据符号信息的,在代码编制上巧妙的利用构成计算机内部逻辑基础的0/1比特流的概念,使用若干个与二进制相对应的几何形体来表示文字数值信息,通过图像输入设备或光电扫描设备自动识读以实现信息自动处理;二维码能够在横向和纵向两个方位同时表达信息,因此能在很小的面积内表达大量的信息.
效果:

真机效果不明显具体见源码
引入依赖:
compile 'com.google.zxing:core:3.2.1'
actvity中:
public class MainActivity extends AppCompatActivity implements QRCodeView.Delegate {
private ZXingView zXingView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
zXingView = (ZXingView) findViewById(R.id.zxingview);
zXingView.setDelegate(this);//接收返回值
zXingView.startSpotAndShowRect();//显示扫描框,并且延迟1.5秒后开始识别
}
@Override
public void onScanQRCodeSuccess(String result) {//二维码返回的信息
Log.i("zhh", "result:" + result);
Toast.makeText(this, result, Toast.LENGTH_SHORT).show();
vibrate();//兼容API23
zXingView.startSpot();
}
@Override
public void onScanQRCodeOpenCameraError() {
Log.e("zhh", "打开相机出错");
Toast.makeText(this, "打开相机出错", Toast.LENGTH_SHORT).show();
finish();
}
@Override
protected void onStart() {
super.onStart();
zXingView.startCamera();
}
@Override
protected void onStop() {
zXingView.stopCamera();
super.onStop();
}
private void vibrate() {
Vibrator vibrator = (Vibrator) getSystemService(VIBRATOR_SERVICE);
vibrator.vibrate(200);
}
@Override
protected void onDestroy() {
zXingView.onDestroy();
super.onDestroy();
}
}
布局代码:
<?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"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.zhh.test.MainActivity">
<com.zhh.test.qrcode.ZXingView
android:id="@+id/zxingview"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:qrcv_animTime="1000"
app:qrcv_barcodeRectHeight="220dp"
app:qrcv_borderColor="@android:color/white"
app:qrcv_borderSize="0px"
app:qrcv_cornerColor="@color/colorPrimaryDark"
app:qrcv_cornerLength="20dp"
app:qrcv_cornerSize="3dp"
app:qrcv_isBarcode="false"
app:qrcv_isOnlyDecodeScanBoxArea="true"
app:qrcv_isScanLineReverse="true"
app:qrcv_isShowDefaultGridScanLineDrawable="true"
app:qrcv_isShowDefaultScanLineDrawable="false"
app:qrcv_isShowTipBackground="true"
app:qrcv_isShowTipTextAsSingleLine="false"
app:qrcv_isTipTextBelowRect="true"
app:qrcv_maskColor="#88000000"
app:qrcv_qrCodeTipText="将二维码放入框内,即可自动扫描"
app:qrcv_rectWidth="200dp"
app:qrcv_scanLineColor="@color/colorPrimaryDark"
app:qrcv_scanLineMargin="0dp"
app:qrcv_scanLineSize="1dp"
app:qrcv_tipTextColor="@android:color/white"
app:qrcv_tipTextSize="12sp"
app:qrcv_toolbarHeight="56dp"
app:qrcv_topOffset="90dp" />
</RelativeLayout>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
Android使用NumberPicker实现滑轮日期选择器
这篇文章主要为大家介绍了如何使用Android中的NumberPicker控件,以一种简单而直观的方式实现滑轮式的日期选择器,需要的小伙伴可以参考一下2023-06-06
关于Android Webview 设置Cookie问题详解
大家好,本篇文章是关于Android Webview 设置Cookie问题详解,感兴趣的同学可以看看,希望对你起到帮助,有用的话记得收藏,方便下次浏览2021-11-11
Android原生TabLayout使用的超全解析(看这篇就够了)
现在很多app都有顶部可左右切换的导航栏,并且还带动画效果,要实现这种导航栏,可以使用Android原生的Tablayout也可以借助第三方框架实现,这篇文章主要给大家介绍了关于Android原生TabLayout使用的相关资料,需要的朋友可以参考下2022-09-09
Android录音--AudioRecord、MediaRecorder的使用
本篇文章主要介绍了Android录音--AudioRecord、MediaRecorder的使用,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2017-02-02


最新评论