Android二维码开发(一)——生成二维码

二维码的应用非常广泛,用途也很多,网上也有很多实用的精简包可以引入,本篇主要记录了不用引入新的module,自己集成生成二维码功能的过程。


一、引入依赖

首先在libs文件目录下放进jar包zxing.jar,然后引入依赖,sync。

implementation files('libs/zxing.jar')

也可以在file/project structure/app/dependencies中点击+号选择添加jar包

在这里插入图片描述

二、集成工具类

然后添加二维码工具类EncodingUtils.class

package com.example.qrcodedemo.utils;

import android.graphics.Bitmap;
import android.graphics.Canvas;

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 com.google.zxing.qrcode.decoder.ErrorCorrectionLevel;

import java.util.HashMap;
import java.util.Map;

/**
 * 二维码生成工具类
 */
public class EncodingUtils {

    /**
     * 创建二维码
     *
     * @param content   content
     * @param widthPix  widthPix
     * @param heightPix heightPix
     * @param logoBm    logoBm
     * @return 二维码
     */
    public static Bitmap createQRCode(String content, int widthPix, int heightPix, Bitmap logoBm) {
        try {
            if (content == null || "".equals(content)) {
                return null;
            }
            // 配置参数
            Map<EncodeHintType, Object> hints = new HashMap<>();
            hints.put(EncodeHintType.CHARACTER_SET, "utf-8");
            // 容错级别
            hints.put(EncodeHintType.ERROR_CORRECTION, ErrorCorrectionLevel.H);
            // 图像数据转换,使用了矩阵转换
            BitMatrix bitMatrix = new QRCodeWriter().encode(content, BarcodeFormat.QR_CODE, widthPix,
                    heightPix, hints);
            int[] pixels = new int[widthPix * heightPix];
            // 下面这里按照二维码的算法,逐个生成二维码的图片,
            // 两个for循环是图片横列扫描的结果
            for (int y = 0; y < heightPix; y++) {
                for (int x = 0; x < widthPix; x++) {
                    if (bitMatrix.get(x, y)) {
                        pixels[y * widthPix + x] = 0xff000000;
                    } else {
                        pixels[y * widthPix + x] = 0xffffffff;
                    }
                }
            }
            // 生成二维码图片的格式,使用ARGB_8888
            Bitmap bitmap = Bitmap.createBitmap(widthPix, heightPix, Bitmap.Config.ARGB_8888);
            bitmap.setPixels(pixels, 0, widthPix, 0, 0, widthPix, heightPix);
            if (logoBm != null) {
                bitmap = addLogo(bitmap, logoBm);
            }
            //必须使用compress方法将bitmap保存到文件中再进行读取。直接返回的bitmap是没有任何压缩的,内存消耗巨大!
            return bitmap;
        } catch (WriterException e) {
            e.printStackTrace();
        }
        return null;
    }

    /**
     * 在二维码中间添加Logo图案
     */
    private static Bitmap addLogo(Bitmap src, Bitmap logo) {
        if (src == null) {
            return null;
        }
        if (logo == null) {
            return src;
        }
        //获取图片的宽高
        int srcWidth = src.getWidth();
        int srcHeight = src.getHeight();
        int logoWidth = logo.getWidth();
        int logoHeight = logo.getHeight();
        if (srcWidth == 0 || srcHeight == 0) {
            return null;
        }
        if (logoWidth == 0 || logoHeight == 0) {
            return src;
        }
        //logo大小为二维码整体大小的1/5
        float scaleFactor = srcWidth * 1.0f / 5 / logoWidth;
        Bitmap bitmap = Bitmap.createBitmap(srcWidth, srcHeight, Bitmap.Config.ARGB_8888);
        try {
            Canvas canvas = new Canvas(bitmap);
            canvas.drawBitmap(src, 0, 0, null);
            canvas.scale(scaleFactor, scaleFactor, srcWidth / 2, srcHeight / 2);
            canvas.drawBitmap(logo, (srcWidth - logoWidth) / 2, (srcHeight - logoHeight) / 2, null);
            canvas.save();
            canvas.restore();
        } catch (Exception e) {
            bitmap = null;
            e.getStackTrace();
        }
        return bitmap;
    }
}
三、使用

修改布局文件用于预览二维码效果,其中EditText用于输入放在二维码中的文本信息,qrCode1为生成不带logo的二维码的点击事件,qrCode2为生成带logo的二维码的点击事件。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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"
    android:orientation="vertical">

    <EditText
        android:id="@+id/input_txt"
        android:layout_width="300dp"
        android:textSize="18sp"
        android:layout_height="wrap_content"
        android:layout_marginTop="10dp"
        android:hint="输入要生成二位码的内容"/>
    <Button
        android:text="生成二维码"
        android:layout_width="239dp"
        android:layout_height="wrap_content"
        android:id="@+id/encode_btn1"
        android:textSize="18sp"
        android:onClick="qrCode1"
        android:layout_marginTop="20dp"/>
    <ImageView
        android:layout_width="200dp"
        android:layout_height="200dp"
        android:id="@+id/code_image1"
        android:layout_marginTop="20dp" />
    <TextView
        android:layout_width="match_parent"
        android:layout_height="2dp"
        android:layout_marginTop="10dp"
        android:background="#7e7b7b"/>
    <Button
        android:text="生成带Logo的二维码"
        android:layout_width="239dp"
        android:layout_height="wrap_content"
        android:id="@+id/encode_btn2"
        android:textSize="18sp"
        android:onClick="qrCode2"
        android:layout_marginTop="10dp"/>
    <ImageView
        android:layout_width="200dp"
        android:layout_height="200dp"
        android:id="@+id/code_image2"
        android:layout_marginTop="20dp"/>

</LinearLayout>

然后我们在主活动中使用集成的EncodingUtils类中的createQRCode()方法来生成相应的二维码,第一个参数content为二维码中所存放的信息,第二个参数widthPix为所生成二维码的宽度,第三个参数heightPix为所生成二维码的高度,第四个参数logoBm为二维码中间的logo,如果不带logo的话此参数设为null即可。

package com.example.qrcodedemo;

import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.Toast;

import com.example.qrcodedemo.utils.EncodingUtils;

public class MainActivity extends AppCompatActivity {
    private ImageView enCodeImage1,enCodeImage2;//展示生成的二维码
    private EditText editText;//输入要生成二维码的内容
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //初始化控件
        enCodeImage1 = (ImageView) findViewById(R.id.code_image1);
        enCodeImage2 = (ImageView) findViewById(R.id.code_image2);
        editText = (EditText) findViewById(R.id.input_txt);
    }
    /**
     * 生成不带Logo的二维码点击事件
     * @param view
     */
    public void qrCode1(View view){
        if ("".equals(editText.getText().toString())){
            Toast.makeText(this, "请在输入框中输入内容", Toast.LENGTH_SHORT).show();
            return;
        }
        //生成二维码
        Bitmap codeBitmap = EncodingUtils.createQRCode(editText.getText().toString(),500,500,null);
        enCodeImage1.setImageBitmap(codeBitmap);//显示二维码
    }
    /**
     * 生成带Logo的二维码
     * @param view
     */
    public void qrCode2 (View view){
        if ("".equals(editText.getText().toString())){
            Toast.makeText(this, "请在输入框中输入内容", Toast.LENGTH_SHORT).show();
            return;
        }
        //获取logo资源,
        //R.drawable.logo为logo图片
        Bitmap logoBitmap = BitmapFactory.decodeResource(getResources(),R.drawable.logo);
        //生成二维码
        Bitmap codeBitmap = EncodingUtils.createQRCode(editText.getText().toString(),500,500,logoBitmap);
        enCodeImage2.setImageBitmap(codeBitmap);//显示二维码
    }
}

效果如下:

在这里插入图片描述


源代码:qrcodeDemo
jar包路径:zxing.jar,点击clone/下载,选择下载zip包即可获得项目文件,zxing.jar包在“你的下载位置\wd23-qrcodeDemo-master.zip\qrcodeDemo\app\libs”目录下
在这里插入图片描述
在这里插入图片描述
有帮助的话请点赞喔,笔芯~

  • 16
    点赞
  • 48
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
### 回答1: Android二维码生成库是一种在Android平台上使用的软件开发包,它提供了一套简单而有效的方法来生成二维码Android二维码生成库具有以下优点: 首先,它提供了丰富的功能和选项,使得开发者可以自定义生成的二维码开发者可以设置二维码的大小、颜色、背景、图像等属性。同时,还可以添加Logo、文字、链接等附加信息,使生成的二维码更加个性化。 其次,它具有良好的兼容性。Android二维码生成库可以在各种Android设备和各个版本上使用,并且与其他Android开发库和框架完美集成。无论是在智能手机、平板电脑还是其他Android设备上,都可以轻松生成高质量的二维码。 此外,Android二维码生成库还具有高性能和稳定性。它经过了严格的测试和优化,能够在各种条件下高效生成二维码。无论是生成单个二维码还是批量生成,都能快速且稳定地完成。 最后,Android二维码生成库还提供了简单易用的接口和示例代码,使得开发者可以快速上手并集成到自己的项目中。无论是初学者还是有经验的开发者,都可以轻松使用该库来生成二维码。 综上所述,Android二维码生成库是一种功能强大、兼容性好、高性能和稳定的开发工具,可以帮助开发者在Android平台上轻松生成个性化的二维码。无论是商业应用还是个人项目,都可以从中受益。 ### 回答2: Android二维码生成库是一种用于生成二维码的开源库。在Android开发中,我们可以通过使用这个库来轻松地生成二维码,并可以根据需求设置二维码的样式、大小和内容等属性。 Android二维码生成库通常提供了一个专门的API或者类,开发者可以通过调用这些方法,传入需要的参数来生成二维码。通常,我们需要传入的参数包括二维码的内容、二维码的宽度和高度等信息。生成二维码的过程通常是通过计算生成的图片的像素来实现的。生成的二维码可以保存为图片文件,也可以直接在应用中显示出来。 Android二维码生成库通常支持多种二维码格式,包括普通的二维码、带有Logo的二维码、带有颜色的二维码等。有些库还支持自定义二维码的样式,例如可以设置二维码的背景色、前景色或者在二维码中间添加Logo等。 使用Android二维码生成库可以方便快捷地生成二维码,无论是生成付款二维码、产品推广二维码还是其他类型的二维码,都可以轻松实现。同时,这些库通常有很好的兼容性,可以适用于不同版本的Android系统,并且提供了丰富的文档和示例来帮助开发者更好地使用。 总之,Android二维码生成库是开发Android应用时非常方便的工具,可以帮助开发者轻松实现二维码生成的功能,提升应用的用户体验和功能扩展性。 ### 回答3: Android二维码生成库是一种在Android平台上使用的工具库,用于快速生成二维码。通过使用这种库,开发者可以方便地生成个性化的二维码图像,以满足不同需求。 Android二维码生成库通常提供了丰富的API和功能,可以设置二维码的大小、颜色、边距、错误纠正级别等属性,并支持在二维码中添加文本、网址、联系方式等额外信息。开发者可以根据自己的需求自定义这些属性,以生成符合预期的二维码。 使用Android二维码生成库,开发者只需引入相应的库文件,并在代码中调用相应的方法即可生成二维码。一般来说,生成二维码的步骤包括设置二维码的内容、生成二维码位图、将位图显示在界面上或保存为文件等操作。通过调整参数和样式,开发者可以生成不同风格和类型的二维码Android二维码生成库的优点是方便易用、功能丰富、效果灵活。开发者可以根据自己的需求选择适合的库来使用,以实现二维码生成的功能。此外,由于二维码的应用非常广泛,使用这种库可以在Android应用中快速实现二维码相关的功能,提升用户的体验和便利性。 总之,Android二维码生成库是一种用于在Android平台上生成二维码的工具库,具有方便易用、功能丰富、效果灵活等优点。通过使用这种库,开发者可以快速生成二维码,以实现各种二维码相关的功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值