初学安卓之二维码的简单实现,android开发网上购物app
打开闪光灯
ScanQRcode完整代码
实现结果
最后注解
参考链接
前言
=============================================================
随着互联网的发展,在网上的二维码种类和作用越来越多,因此我想着自己也实现生成二维码以及扫码。经过上网查资料发现,大多实现二维码功能的,主要都是靠集成了ZXing开源项目的功能,目前还有人在维护,足够我们学习使用。
- ZXing开源库链接https://github.com/zxing/zxing
生成二维码
================================================================
准备工作
- 在ZXing开源库中我们可以看到它已经升级到了3.4.0,于是导入3.4.0的依赖
- 在build.gradle中添加依赖com.google.zxing:core:3.4.0
apply plugin: ‘com.android.application’
android {
compileSdkVersion 29
buildToolsVersion “29.0.3”
defaultConfig {
applicationId “com.example.qrcodetest”
minSdkVersion 19
targetSdkVersion 29
versionCode 1
versionName “1.0”
testInstrumentationRunner “androidx.test.runner.AndroidJUnitRunner”
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile(‘proguard-android-optimize.txt’), ‘proguard-rules.pro’
}
}
}
dependencies {
implementation fileTree(dir: ‘libs’, include: [’*.jar’])
implementation ‘androidx.appcompat:appcompat:1.1.0’
implementation ‘androidx.constraintlayout:constraintlayout:1.1.3’
testImplementation ‘junit:junit:4.12’
androidTestImplementation ‘androidx.test.ext:junit:1.1.1’
androidTestImplementation ‘androidx.test.espresso:espresso-core:3.2.0’
implementation ‘com.google.zxing:core:3.4.0’
}
- 在activity_main.xml文件中添加两个按钮,一个是生成二维码,一个是扫描二维码,并在MainActivity中添加监听按钮点击,实现以下界面
生成简单二维码
- 创建一个名为GenerateQRcode的Activity,Android Studio自动生成其布局文件,布局文件改名为generate_qrcode.xml:放置一个
EditText
输入二维码内容、一个Button
监听操作以及一个ImageView
提供二维码的显示,对应的string在string.xml中添加
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 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=".MainActivity">
<EditText
android:id="@+id/editText"
android:layout_width=“match_parent”
android:layout_height=“wrap_content”
android:layout_alignParentEnd=“true”
android:text="@string/firstTest"
app:layout_constraintEnd_toEndOf=“parent”
app:layout_constraintStart_toStartOf=“parent”
app:layout_constraintTop_toTopOf=“parent” />
<Button
android:id="@+id/btn"
android:layout_width=“match_parent”
android:layout_height=“wrap_content”
android:text="@string/generate_btn"
app:layout_constraintTop_toBottomOf="@+id/editText"
app:layout_constraintEnd_toEndOf=“parent”
app:layout_constraintStart_toStartOf=“parent”/>
<ImageView
android:id="@+id/imageView"
android:layout_width=“256dp”
android:layout_height=“256dp”
android:layout_centerInParent=“true”
app:layout_constraintBottom_toBottomOf=“parent”
app:layout_constraintEnd_toEndOf=“parent”
app:layout_constraintStart_toStartOf=“parent”
app:layout_constraintTop_toTopOf=“parent” />
</androidx.constraintlayout.widget.ConstraintLayout>
https://www.baidu.com
生成二维码
- 在AndroidManifest.xml中注册(Android Studio会自动生成)
<application
…
…
- 要实现二维码的生成,主要是靠zxing提供的接口和方法,在GenerateQRcode文件中新建一个
generateSimpleBitmap
方法用于生成二维码,参数为二维码内容、宽和高,并将参数传入到QRCodeWriter的encode
方法生成BitMatrix
对象,创建一个大小为二维码宽*高的数组,根据BitMatrix
对象,往其中放置黑白色块,最后使用createBitmap
返回一个Bitmap
对象
private Bitmap generateSimpleBitmap(String content, int width, int height) {
// 字符串内容判空
if (TextUtils.isEmpty(content)) {
Toast.makeText(getApplicationContext(),“输入为空!”,Toast.LENGTH_LONG).show();
return null;
}
QRCodeWriter qrCodeWriter = new QRCodeWriter();
Map<EncodeHintType, String> hints = new HashMap<>();
hints.put(EncodeHintType.CHARACTER_SET, “utf-8”);
try {
BitMatrix encode = qrCodeWriter.encode(content, BarcodeFormat.QR_CODE, width, height, hints);
int[] pixels = new int[width * height];
for (int y = 0; y < height; y++) {
for (int x = 0; x < width; x++) {
if (encode.get(x, y)) {
pixels[y * width + x] = 0x00000000;
} else {
pixel
s[y * width + x] = 0xFFFFFFFF;
}
}
}
return Bitmap.createBitmap(pixels, 0, width, width, height, Bitmap.Config.RGB_565);
} catch (WriterException e) {
e.printStackTrace();
}
return null;
}
- 在GenerateQRcode文件中的
onCreate
引用,将结果注入布局的ImageView组件中
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.generate_qrcode);
btn = (Button)findViewById(R.id.btn);
editText = (EditText)findViewById(R.id.editText);
imageView = (ImageView)findViewById(R.id.imageView);
btn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
String content = editText.getText().toString();
Bitmap qrBitmap = generateSimpleBitmap(content,256, 256);
imageView.setImageBitmap(qrBitmap);
}
});
}
- 实现结果
修改二维码颜色
- 在以上基础上,在GenerateQRcode文件中新建一个
generateQRCodeBitmap
方法,相比generateSimpleBitmap
,参数多了两个颜色,一个为原二维码黑点的颜色,另一个为原来白色的背景颜色
public Bitmap generateQRCodeBitmap(String content, int width, int height,
int color_point, int color_back) {
//字符串内容判空
if (TextUtils.isEmpty(content)) {
Toast.makeText(getApplicationContext(),“输入为空!”,Toast.LENGTH_LONG).show();
return null;
}
Map<EncodeHintType, String> hints = new HashMap<>();
//格式utf-8
hints.put(EncodeHintType.CHARACTER_SET, “utf-8”);
//空白边距设置
hints.put(EncodeHintType.MARGIN, “1”);
try {
//生成BitMatrix对象encode
BitMatrix encode = new QRCodeWriter().encode(content, BarcodeFormat.QR_CODE, width, height, hints);
//生成宽*高的像素数组
int[] pixels = new int[width * height];
for (int y = 0; y < height; y++) {
for (int x = 0; x < width; x++) {
if (encode.get(x, y)) {
pixels[y * width + x] = color_point;
} else {
pixels[y * width + x] = color_back;
}
}
}
return Bitmap.createBitmap(pixels, 0, width, width, height, Bitmap.Config.RGB_565);
} catch (WriterException e) {
e.printStackTrace();
return null;
}
}
- 将上面简单二维码的引用改为
Bitmap qrBitmap = generateQRCodeBitmap(content, 256, 256, Color.BLUE, Color.GREEN);
- 实现结果
在二维码中心添加logo图片
- 在GenerateQRcode文件中新增一个
addLogo
方法,三个参数分别是原二维码、logo图片以及logo在二维码中占据的比例
private static Bitmap addLogo(Bitmap srcBitmap, Bitmap logoBitmap, float logoPercent){
if(srcBitmap == null){
return null;
}
if(logoBitmap == null){
return srcBitmap;
}
if(logoPercent < 0F || logoPercent > 1F){
logoPercent = 0.2F;
}
int srcWidth = srcBitmap.getWidth();
int srcHeight = srcBitmap.getHeight();
int logoWidth = logoBitmap.getWidth();
int logoHeight = logoBitmap.getHeight();
Bitmap bitmap = Bitmap.createBitmap(srcWidth, srcHeight, Bitmap.Config.ARGB_8888);
float scaleWidth = srcWidth * logoPercent / logoWidth;
float scaleHeight = srcHeight * logoPercent / logoHeight;
Canvas canvas = new Canvas(bitmap);
canvas.drawBitmap(srcBitmap, 0, 0, null);
canvas.scale(scaleWidth, scaleHeight, srcWidth/2, srcHeight/2);
canvas.drawBitmap(logoBitmap, srcWidth/2 - logoWidth/2, srcHeight/2 - logoHeight/2, null);
return bitmap;
}
- 修改刚才的
generateQRCodeBitmap
方法,添加两个参数,一个是logo图片,一个是所占比例,取值范围[0,1],并在其中引用addLogo
方法
public Bitmap generateQRCodeBitmap(String content, int width, int height,
int color_point, int color_back,
Bitmap logoBitmap, float logoPercent) {
// 字符串内容判空
if (TextUtils.isEmpty(content)) {
Toast.makeText(getApplicationContext(),“输入为空!”,Toast.LENGTH_LONG).show();
return null;
}
Map<EncodeHintType, String> hints = new HashMap<>();
//格式utf-8
hints.put(EncodeHintType.CHARACTER_SET, “utf-8”);
//空白边距设置
hints.put(EncodeHintType.MARGIN, “1”);
try {
//生成BitMatrix对象encode
BitMatrix encode = new QRCodeWriter().encode(content, BarcodeFormat.QR_CODE, width, height, hints);
//生成宽*高的像素数组
int[] pixels = new int[width * height];
for (int y = 0; y < height; y++) {
for (int x = 0; x < width; x++) {
if (encode.get(x, y)) {
pixels[y * width + x] = color_point;
} else {
pixels[y * width + x] = color_back;
}
}
}
Bitmap bitmap = Bitmap.createBitmap(pixels, 0, width, width, height, Bitmap.Config.RGB_565);
if(logoBitmap != null){
return addLogo(bitmap, logoBitmap, logoPercent);
}
return bitmap;
} catch (WriterException e) {
e.printStackTrace();
return null;
}
}
- 从网上下载一张图片,存放在drawable文件中,然后在GenerateQRcode文件中的
onCreate
引用,将结果注入布局的ImageView组件中
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.generate_qrcode);
btn = (Button)findViewById(R.id.btn);
editText = (EditText)findViewById(R.id.editText);
imageView = (ImageView)findViewById(R.id.imageView);
btn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
String content = editText.getText().toString();
Resources res = getResources();
Bitmap logoBitmap= BitmapFactory.decodeResource(res,R.drawable.cat);
//Bitmap qrBitmap = generateSimpleBitmap(content,256, 256);
Bitmap qrBitmap = generateQRCodeBitmap(content, 256, 256, Color.BLUE, Color.GREEN, logoBitmap, 0.2F);
imageView.setImageBitmap(qrBitmap);
}
});
}
- 实现结果
GenerateQRcode完整代码
package com.example.qrcodetest;
import com.google.zxing.BarcodeFormat;
import com.google.zxing.EncodeHintType;
import com.google.zxing.WriterException;
import com.google.zxing.common.BitMatrix;
import com.google.zxing.qrcode.QRCodeWriter;
import android.content.res.Resources;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Color;
import android.os.Bundle;
import android.graphics.Bitmap;
import android.text.TextUtils;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.Toast;
import androidx.appcompat.app.AppCompatActivity;
import java.util.HashMap;
import java.util.Map;
public class GenerateQRcode extends AppCompatActivity {
private Button btn;
private ImageView imageView;
private EditText editText;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.generate_qrcode);
btn = (Button)findViewById(R.id.btn);
editText = (EditText)findViewById(R.id.editText);
imageView = (ImageView)findViewById(R.id.imageView);
btn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
String content = editText.getText().toString();
Resources res = getResources();
Bitmap logoBitmap= BitmapFactory.decodeResource(res,R.drawable.cat);
//Bitmap qrBitmap = generateSimpleBitmap(content,256, 256);
Bitmap qrBitmap = generateQRCodeBitmap(content, 256, 256, Color.BLUE, Color.GREEN, logoBitmap, 0.2F);
imageView.setImageBitmap(qrBitmap);
}
});
}
private Bitmap generateSimpleBitmap(String content, int width, int height) {
// 字符串内容判空
if (TextUtils.isEmpty(content)) {
Toast.makeText(getApplicationContext(),“输入为空!”,Toast.LENGTH_LONG).show();
return null;
}
QRCodeWriter qrCodeWriter = new QRCodeWriter();
Map<EncodeHintType, String> hints = new HashMap<>();
hints.put(EncodeHintType.CHARACTER_SET, “utf-8”);
try {
BitMatrix encode = qrCodeWriter.encode(content, BarcodeFormat.QR_CODE, width, height, hints);
int[] pixels = new int[width * height];
for (int y = 0; y < height; y++) {
for (int x = 0; x < width; x++) {
if (encode.get(x, y)) {
pixels[y * width + x] = 0x00000000;//黑色
} else {
pixels[y * width + x] = 0xFFFFFFFF;//白色
}
}
}
return Bitmap.createBitmap(pixels, 0, width, width, height, Bitmap.Config.RGB_565);
} catch (WriterException e) {
e.printStackTrace();
}
return null;
}
public Bitmap generateQRCodeBitmap(String content, int width, int height,
int color_point, int color_back,
Bitmap logoBitmap, float logoPercent) {
// 字符串内容判空
if (TextUtils.isEmpty(content)) {
Toast.makeText(getApplicationContext(),“输入为空!”,Toast.LENGTH_LONG).show();
return null;
}
Map<EncodeHintType, String> hints = new HashMap<>();
//格式utf-8
hints.put(EncodeHintType.CHARACTER_SET, “utf-8”);
//空白边距设置
hints.put(EncodeHintType.MARGIN, “1”);
try {
//生成BitMatrix对象encode
BitMatrix encode = new QRCodeWriter().encode(content, BarcodeFormat.QR_CODE, width, height, hints);
//生成宽*高的像素数组
int[] pixels = new int[width * height];
for (int y = 0; y < height; y++) {
for (int x = 0; x < width; x++) {
if (encode.get(x, y)) {
pixels[y * width + x] = color_point;
} else {
pixels[y * width + x] = color_back;
}
}
}
Bitmap bitmap = Bitmap.createBitmap(pixels, 0, width, width, height, Bitmap.Config.RGB_565);
if(logoBitmap != null){
return addLogo(bitmap, logoBitmap, logoPercent);
}
return bitmap;
} catch (WriterException e) {
e.printStackTrace();
return null;
}
}
private static Bitmap addLogo(Bitmap srcBitmap, Bitmap logoBitmap, float logoPercent){
if(srcBitmap == null){
return null;
}
if(logoBitmap == null){
return srcBitmap;
}
if(logoPercent < 0F || logoPercent > 1F){
logoPercent = 0.2F;
}
int srcWidth = srcBitmap.getWidth();
int srcHeight = srcBitmap.getHeight();
int logoWidth = logoBitmap.getWidth();
int logoHeight = logoBitmap.getHeight();
Bitmap bitmap = Bitmap.createBitmap(srcWidth, srcHeight, Bitmap.Config.ARGB_8888);
float scaleWidth = srcWidth * logoPercent / logoWidth;
float scaleHeight = srcHeight * logoPercent / logoHeight;
Canvas canvas = new Canvas(bitmap);
canvas.drawBitmap(srcBitmap, 0, 0, null);
canvas.scale(scaleWidth, scaleHeight, srcWidth/2, srcHeight/2);
canvas.drawBitmap(logoBitmap, srcWidth/2 - logoWidth/2, srcHeight/2 - logoHeight/2, null);
return bitmap;
}
}
扫描二维码
================================================================
准备工作
打开真机调试
因为在虚拟机中的摄像头显示是一片黑暗,所以这里使用真机调试
首先在将手机和电脑用USB线连接,USB连接方式选择传输文件
- 然后在手机中打开开发者选项,启动USB调试。开发者选项一般是隐藏的,可在关于手机处多次点击版本号,即可出现。
- 即可在Android Studio调用
集成工作
- 在build.gradle中添加依赖com.google.zxing:core:3.4.0,此步在前面已添加,因此可不用再次操作
implementation ‘com.google.zxing:core:3.4.0’
- 打开ZXing的开源地址项目https://github.com/zxing/zxing,在该项目下方的readme中看到,ZXing已将扫描仪的一些功能封装整合到一个包中
我们可以下载其中的Android调用,但是,ZXing在封装了多个功能,而我们只需要做到一个简单扫码的功能,因此此处选择网上大神们从其中挑出并修改整合好的扫码的一些基本功能
参考链接https://github.com/ahuyangdong/QrCodeDemo4,下载备用
来到下载文件处,获取zxing内容,复制进自己的项目
- 获得音频文件,直接将raw放入自己项目中的res文件下(也可自己去别处下载)
- 拷贝attrs.xml、colors.xml以及ids.xml三个文件
- 获得图片
- 拷贝导航栏布局toolbar_scanner.xml以及扫码界面的布局activity_scanner.xml
821.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQyMzMzMTg2,size_16,color_FFFFFF,t_70)
- 拷贝attrs.xml、colors.xml以及ids.xml三个文件
- 获得图片
- 拷贝导航栏布局toolbar_scanner.xml以及扫码界面的布局activity_scanner.xml
初学安卓之二维码的简单实现,android开发网上购物app相关推荐
- 初学安卓之二维码的简单实现
初学安卓之二维码的简单实现 前言 生成二维码 准备工作 生成简单二维码 修改二维码颜色 在二维码中心添加logo图片 GenerateQRcode完整代码 扫描二维码 准备工作 打开真机调试 集成工作 ...
- 初学python制作二维码以及最新感悟
初学python制作二维码 一.安装Python 推荐百度经验链接. 二.安装pip模块 Python 3.4以后版本默认安装了pip,但是由于不是最新故需要升级,pip的升级命令为(开始->c ...
- Zxing与 Zbar生成二维码最简单的实现方式
Zxing与 Zbar生成二维码最简单的实现方式 导入依赖 implementation 'cn.bingoogolapple:bga-qrcode-zbar:1.2.1' 或者 implementa ...
- 视频教程-微信公众平台深度开发v2.0第3季——二维码、模板消息-微信开发
微信公众平台深度开发v2.0第3季--二维码.模板消息 微信企业号星级会员.10多年软件从业经历,国家级软件项目负责人,主要从事软件研发.软件企业员工技能培训.已经取得计算机技术与软件资格考试(软考) ...
- 扫描二维码,判断是Android还是iOS,并跳转到不同的下载地址
扫描二维码,判断是Android还是iOS,并跳转到不同的下载地址 问题概要 解决思路 页面代码 问题概要 一般情况下,我们开发App,有Android和iOS版本,为了方便用户,我们只能有一个二维码 ...
- 微信扫描二维码实现自动跳转 微信直接下载App(iOS/Android)的解决方案
微信扫描二维码实现自动跳转 微信直接下载App(iOS/Android)的解决方案 参考文章: (1)微信扫描二维码实现自动跳转 微信直接下载App(iOS/Android)的解决方案 (2)http ...
- 怎么做二维码更简单?这款二维码生成器了解一下
很多小伙伴经常会需要将不同的内容做成二维码,比如视频.文件.文字等等多种类型,都会做成二维码来分享给他人使用.那么有一款简单好用的二维码生成器是非常重要的,下面就让小编来给大家分享一款免费的二维码制作 ...
- SpringBoot利用ZXing工具来生成二维码(简单)
一.简单二维码生成 1.1.依赖 <!--二维码工具--> <dependency><groupId>com.google.zxing</groupId> ...
- halcon二维码识别简单案例
目录 二维码种类 编辑 halcon 二维码识别调用算子步骤 1.创建模型--create_data_code_2d_model( SymbolType, GenParamName, GenPara ...
最新文章
- 答疑 | 算法岗和开发岗有什么区别?
- python高阶函数闭包装饰器_Python_基础_(装饰器,*args,**kwargs,高阶函数,函数闭包,函数嵌套)...
- jquery-validation插件
- Larbin简介,及其在Ubuntu10.04下的编译安装
- thinkphp-add方法错误
- 快来捡武器:Black Hat USA 将推出的8款安全工具
- Promise用法总结
- Vue (二) --- Vue对象提供的属性功能
- ObserveIT Client安装后屏幕延迟问题
- StringUtil.format使用介绍
- 奥斯汀页眉怎么设置_word页眉怎么插入及删除
- 关于“善念科技”的思考
- 字节跳动实习生转正工资_日常实习 | 字节跳动西瓜视频招募运营实习生啦!
- 如何获取国际短信验证码---创蓝253国际短信接口调用demo
- X310工作原理及设备描述详细信息
- 政府采购和招标投标常见问题:评标的依据是什么?
- 把故事收回到一杯茶里,不知不觉,茶已经凉了
- php当月1号怎么获取,php获取下月1号和月底最后一天的时间
- Linux命令df和du
- 网站推广----献给广大站长(转载)