【Android App】二维码的讲解及生成属于自己的二维码实战(附源码和演示 超详细必看)

简介: 【Android App】二维码的讲解及生成属于自己的二维码实战(附源码和演示 超详细必看)

需要全部代码请点赞关注收藏后评论区留言~~~

一、二维码基本内容介绍

条形码只能表达十几位数字编码,无法表示更复杂的数据。 二维码在二维方格上描出一个个黑点,从而表达更丰富的信息。 二维码早已在手机App中广泛使用,不管是添加好友还是支付收款,只要出示二维码让别人扫一扫,滴的一下便轻松操作完成了

二维码在二维方格上描出一个个黑点,从而表达更丰富的信息,二维码中每个点有是(显示黑点)和否(不显示黑点)两种状态,二维码的左上角、右上角、左下角各有一个带黑框的黑色方块,这三个黑方块用于确定二维码的上下左右方位。因为用户可能斜着扫描,也可能倒过来扫描,通过三个角落的黑色方块便能将二维码旋转至正常方向,另外二维码中间放着公众号的logo图标,并不影响扫描识别,这是因为二维码留出了一定的容错率,即使部分区域被遮盖或者被污损,扫码软件依然能够根据剩余的大部分区域自动纠错,从而解析得到原始的编码信息。

当然,功能如此强悍的二维码可不是随随便便生成的,而要根据特定的算法将一串文本经过编码处理而形成的,若要使用App生成二维码,需要借助谷歌开源的zxing库,在代码中引入二维码撰写器QRCodeWriter,并调用撰写器的encode方法即可生成二维码位图

二、生成自己的二维码

运行测试App效果如下 可在下拉框中选择二维码的不同容错率,对应的二维码形状也会发生变化

代码如下

package com.example.face;
import androidx.appcompat.app.AppCompatActivity;
import android.graphics.Bitmap;
import android.graphics.Color;
import android.os.Bundle;
import android.os.Environment;
import android.text.TextUtils;
import android.util.Log;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.Spinner;
import android.widget.Toast;
import com.example.face.util.BitmapUtil;
import com.example.face.util.DateUtil;
import com.google.zxing.BarcodeFormat;
import com.google.zxing.EncodeHintType;
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 GenerateQrcodeActivity extends AppCompatActivity {
    private final static String TAG = "GenerateQrcodeActivity";
    private EditText et_content; // 声明一个编辑框对象
    private ImageView iv_qrcode; // 声明一个图像视图对象
    private Bitmap mBitmap; // 声明一个位图对象
    private ErrorCorrectionLevel mErrorRate; // 容错率
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_generate_qrcode);
        et_content = findViewById(R.id.et_content);
        iv_qrcode = findViewById(R.id.iv_qrcode);
        findViewById(R.id.btn_generate).setOnClickListener(v -> {
            String content = et_content.getText().toString();
            if (TextUtils.isEmpty(content)) {
                Toast.makeText(this, "请先输入原始文本", Toast.LENGTH_SHORT).show();
                return;
            }
            // 生成原始文本对应的二维码位图
            mBitmap = createQrcodeBitmap(content, mErrorRate);
            iv_qrcode.setImageBitmap(mBitmap); // 设置图像视图的位图对象
        });
        findViewById(R.id.btn_save).setOnClickListener(v -> {
            if (mBitmap == null) {
                Toast.makeText(this, "请先生成二维码图片", Toast.LENGTH_SHORT).show();
                return;
            }
            // 生成图片文件的保存路径
            String path = String.format("%s/%s.jpg",
                    getExternalFilesDir(Environment.DIRECTORY_DOWNLOADS).toString(),
                    DateUtil.getNowDateTime());
            BitmapUtil.saveImage(path, mBitmap); // 把位图保存为图片文件
            BitmapUtil.notifyPhotoAlbum(this, path); // 通知相册来了张新图片
            Toast.makeText(this, "成功保存二维码图片:" + path, Toast.LENGTH_SHORT).show();
        });
        initErrorSpinner(); // 初始化容错率下拉框
    }
    // 初始化容错率下拉框
    private void initErrorSpinner() {
        ArrayAdapter<String> errorAdapter = new ArrayAdapter<>(this,
                R.layout.item_select, errorNameArray);
        Spinner sp_error = findViewById(R.id.sp_error);
        sp_error.setPrompt("请选择容错率");
        sp_error.setAdapter(errorAdapter);
        sp_error.setOnItemSelectedListener(new ErrorSelectedListener());
        sp_error.setSelection(0);
    }
    private String[] errorNameArray = {"30%", "25%", "15%", "7%"};
    private ErrorCorrectionLevel[] erroLevelArray = {ErrorCorrectionLevel.H,
            ErrorCorrectionLevel.Q, ErrorCorrectionLevel.M, ErrorCorrectionLevel.L};
    class ErrorSelectedListener implements AdapterView.OnItemSelectedListener {
        public void onItemSelected(AdapterView<?> arg0, View arg1, int arg2, long arg3) {
            mErrorRate = erroLevelArray[arg2];
        }
        public void onNothingSelected(AdapterView<?> arg0) {}
    }
    // 生成原始文本对应的二维码位图
    private Bitmap createQrcodeBitmap(String content, ErrorCorrectionLevel errorRate) {
        if (TextUtils.isEmpty(content)) {
            return null;
        }
        int width = content.length()*6; // 二维码图片的宽度
        int height = width; // 二维码图片的高度
        int margin = width / 20; // 二维码图片的空白边距
        Log.d(TAG, "content="+content+",width="+width+",height="+height+",margin="+margin+",errorRate="+errorRate.name());
        Map<EncodeHintType, Object> hints = new HashMap<>();
        hints.put(EncodeHintType.MARGIN, margin); // 设置空白边距
        hints.put(EncodeHintType.CHARACTER_SET, "UTF-8"); // 设置字符编码格式
        hints.put(EncodeHintType.ERROR_CORRECTION, errorRate); // 设置容错率
        try {
            // 根据配置参数生成位矩阵对象
            BitMatrix bitMatrix = 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 (bitMatrix.get(x, y)) { // 返回true表示黑色色块
                        pixels[y * width + x] = Color.BLACK;
                    } else { // 返回false表示白色色块
                        pixels[y * width + x] = Color.WHITE;
                    }
                }
            }
            // 创建位图对象,并根据像素数组设置每个像素的色值
            Bitmap bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888);
            bitmap.setPixels(pixels, 0, width, 0, 0, width, height);
            if (bitmap.getWidth() < 300) { // 图片太小的话,要放大图片
                bitmap = BitmapUtil.getScaleBitmap(bitmap, 300.0/bitmap.getWidth());
            }
            return bitmap;
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }
}

创作不易 觉得有帮助请点赞关注收藏~~~

相关文章
|
5月前
|
Android开发 数据安全/隐私保护 开发者
Android自定义view之模仿登录界面文本输入框(华为云APP)
本文介绍了一款自定义输入框的实现,包含静态效果、hint值浮动动画及功能扩展。通过组合多个控件完成界面布局,使用TranslateAnimation与AlphaAnimation实现hint文字上下浮动效果,支持密码加密解密显示、去除键盘回车空格输入、光标定位等功能。代码基于Android平台,提供完整源码与attrs配置,方便复用与定制。希望对开发者有所帮助。
|
8月前
|
JavaScript 前端开发 Android开发
【03】仿站技术之python技术,看完学会再也不用去购买收费工具了-修改整体页面做好安卓下载发给客户-并且开始提交网站公安备案-作为APP下载落地页文娱产品一定要备案-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
【03】仿站技术之python技术,看完学会再也不用去购买收费工具了-修改整体页面做好安卓下载发给客户-并且开始提交网站公安备案-作为APP下载落地页文娱产品一定要备案-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
234 13
【03】仿站技术之python技术,看完学会再也不用去购买收费工具了-修改整体页面做好安卓下载发给客户-并且开始提交网站公安备案-作为APP下载落地页文娱产品一定要备案-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
|
3月前
|
存储 Android开发 数据安全/隐私保护
Thanox安卓系统增加工具下载,管理、阻止、限制后台每个APP运行情况
Thanox是一款Android系统管理工具,专注于权限、后台启动及运行管理。支持应用冻结、系统优化、UI自定义和模块管理,基于Xposed框架开发,安全可靠且开源免费,兼容Android 6.0及以上版本。
202 4
|
3月前
|
缓存 小程序 视频直播
基于uni-app+vite5+vue3实战短视频+直播+聊天app应用
基于uniapp+vue3+vite5从0-1实战搭建仿抖音/微信直播带货商城。集短视频+聊天+直播功能于一体。实现全屏沉浸式切换短视频/直播,支持编译运行到h5+小程序端+app端。
255 4
|
3月前
|
存储 移动开发 监控
App Trace功能实战:一键拉起、快速安装与免提写邀请码的应用实践
App Trace系统通过一键拉起、快速安装和免提写邀请码三大功能,显著提升用户转化率、安装成功率和邀请注册率。结合深度技术实现与优化,助力公司用户增长,成为移动端核心基础设施。
|
5月前
|
XML 搜索推荐 Android开发
Android改变进度条控件progressbar的样式(根据源码修改)
本文介绍了如何基于Android源码自定义ProgressBar样式。首先分析了系统源码中ProgressBar样式的定义,发现其依赖一张旋转图片实现动画效果。接着分两步指导开发者实现自定义:1) 模仿源码创建一个旋转动画XML文件(放置在drawable文件夹),修改图片为自定义样式;2) 在UI控件中通过`indeterminateDrawable`属性应用该动画。最终实现简单且个性化的ProgressBar效果,附带效果图展示。
279 2
|
5月前
|
Java Android开发 开发者
Android使用zxing生成二维码
这是一篇关于如何在Android应用中生成二维码的教程。首先,需要导入zxing库的jar包。布局文件中包含一个按钮、一个图片控件和一个输入框。用户可以在输入框中输入想要转换为二维码的内容,点击按钮后,程序会通过实例化QRCodeWriter类并使用for循环绘制二维码图像,最后将生成的二维码显示在ImageView上。源码展示了具体的实现细节,包括布局定义与Java逻辑代码,便于开发者理解和实践。
107 2
|
6月前
|
数据采集 JSON 网络安全
移动端数据抓取:Android App的TLS流量解密方案
本文介绍了一种通过TLS流量解密技术抓取知乎App热榜数据的方法。利用Charles Proxy解密HTTPS流量,分析App与服务器通信内容;结合Python Requests库模拟请求,配置特定请求头以绕过反爬机制。同时使用代理IP隐藏真实IP地址,确保抓取稳定。最终成功提取热榜标题、内容简介、链接等信息,为分析热点话题和用户趋势提供数据支持。此方法也可应用于其他Android App的数据采集,但需注意选择可靠的代理服务。
224 11
移动端数据抓取:Android App的TLS流量解密方案
|
6月前
|
NoSQL 应用服务中间件 PHP
布谷一对一直播源码android版环境配置流程及功能明细
部署需基于 CentOS 7.9 系统,硬盘不低于 40G,使用宝塔面板安装环境,包括 PHP 7.3(含 Redis、Fileinfo 扩展)、Nginx、MySQL 5.6、Redis 和最新 Composer。Swoole 扩展需按步骤配置。2021.08.05 后部署需将站点目录设为 public 并用 ThinkPHP 伪静态。开发环境建议 Windows 操作系统与最新 Android Studio,基础配置涉及 APP 名称修改、接口域名更换、包名调整及第三方登录分享(如 QQ、微信)的配置,同时需完成阿里云与腾讯云相关设置。
|
16天前
|
移动开发 小程序 Android开发
基于 uni-app 开发的废品回收类多端应用功能与界面说明
本文将对一款基于 uni-app 开发的废品回收类多端应用,从多端支持范围、核心功能模块及部分界面展示进行客观说明,相关资源信息也将一并呈现。
51 0

热门文章

最新文章