zxing是一个二维码的框架。
配置
1、
implementation 'com.journeyapps:zxing-android-embedded:4.1.0'
如果报错在这个文件的android下加上如下配置,让其支持Java1.8,不然只有1.7、1.6
(可在'app'右键---->open module settings------>Module看到)
compileOptions { sourceCompatibility JavaVersion.VERSION_1_8 targetCompatibility JavaVersion.VERSION_1_8 }
2、
<uses-sdk tools:overrideLibrary="com.google.zxing.client.android" /> <uses-permission android:name="android.permission.CAMERA"/>
记得点击Sync Now
生成二维码
步骤:
1、自定义一个负责生成二维码的类,方便调用,返回一个Bitmap
要点:利用Zxing中的 BarcodeEncoder 的 encodeBitmap方法
public Bitmap encodeBitmap(String contents, BarcodeFormat format, int width, int height, Map<EncodeHintType, ?> hints) throws WriterException
encodeBitmap方法
参数 | 内容 |
---|---|
contents | 码的内容 |
format | 码的类型(二维码、条形码…) |
width | 码的宽度 |
height | 码的高度 |
hints | 码的额外参数 |
Map<EncodeHintType, ?> hints码的额外参数
这里列举了一些常用的
这些都是Zxing中定义好的
参数 | 内容 |
---|---|
EncodeHintType.ERROR_CORRECTION | 设置容错率 L>M>Q>H 等级越高扫描时间越长,准确率越高 |
EncodeHintType.CHARACTER_SET | 设置字符集 |
EncodeHintType.MARGIN | 设置边距 |
QRcode类
package com.example.xianyu; import android.graphics.Bitmap; import com.google.zxing.BarcodeFormat; import com.google.zxing.EncodeHintType; import com.google.zxing.WriterException; import com.google.zxing.qrcode.decoder.ErrorCorrectionLevel; import com.journeyapps.barcodescanner.BarcodeEncoder; import java.util.HashMap; import java.util.Map; public class QRcode{ public Bitmap qrcode(String content){ int width = 400; int height = 400; //HashMap设置二维码参数 Map map = new HashMap(); // 设置容错率 L>M>Q>H 等级越高扫描时间越长,准确率越高 map.put(EncodeHintType.ERROR_CORRECTION, ErrorCorrectionLevel.M); //设置字符集 map.put(EncodeHintType.CHARACTER_SET,"utf-8"); //设置外边距 map.put(EncodeHintType.MARGIN,1); //利用编码器,生成二维码 BarcodeEncoder barcodeEncoder = new BarcodeEncoder(); Bitmap bitmap = null; try { bitmap = barcodeEncoder.encodeBitmap(content, BarcodeFormat.QR_CODE, width, height,map); } catch (WriterException e) { e.printStackTrace(); } return bitmap; } }
2、在要生成二维码的Activity,调用上述类,输入二维码内容生成二维码,之后显示在ImageView组件上
MainActivity
public class MainActivity extends AppCompatActivity { ImageView Code; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Code = findViewById(R.id.iv_code); QRcode qrcode = new QRcode(); Bitmap bitmap= qrcode.qrcode("CSDN"); Code.setImageBitmap(bitmap); }
成功获得二维码内容
扫码
步骤:
1、给点击扫码的组件添加点击监听事件
2、在监听事件中,利用Intent和startActivityForResult跳到Zxing定义好的默认的扫码界面CaptureActivity中(也可以自定义扫码界面)
3、重写onActivityResult方法处理二维码返回的内容
要点:
其中的REQUEST_CODEZxing是定义好的,一定要使用这个CODE
不然在onActivityResult方法中解析二维码将会不起作用
IntentIntegrator.parseActivityResult(requestCode, resultCode, data);
这段源码可知REQUEST_CODE要相等才会进行二维码解析,否则将会返回 null
public static IntentResult parseActivityResult(int requestCode, int resultCode, Intent intent) { if (requestCode == REQUEST_CODE) { return parseActivityResult(resultCode, intent); } return null; }
设置监听:
Code.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { Intent intent = new Intent(MainActivity.this, CaptureActivity.class); startActivityForResult(intent,REQUEST_CODE); } });
重写Activity中的onActivityResult得到二维码内容,我这里只是将获得的内容进行简单的输出
@Override protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) { IntentResult result = IntentIntegrator.parseActivityResult(requestCode, resultCode, data); if(result != null) { if(result.getContents() == null) { Toast.makeText(this, "Cancelled", Toast.LENGTH_LONG).show(); } else { Toast.makeText(this, "Scanned: " + result.getContents(), Toast.LENGTH_LONG).show(); } } else { super.onActivityResult(requestCode, resultCode, data); } }
总结
更多内容请到github查看:https://github.com/zxing/zxing
到此这篇关于Android 超简易Zxing框架 生成二维码+扫码功能的文章就介绍到这了,更多相关Android Zxing框架生成二维码+扫码内容请搜索呐喊教程以前的文章或继续浏览下面的相关文章希望大家以后多多支持呐喊教程!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。