当前位置:主页 > android教程 > zxing二维码位矩阵转Bitmap

zxing二维码位矩阵转换成Bitmap位图的实战教程

发布:2023-03-07 16:00:01 59


给网友们整理相关的编程文章,网友胡哲丽根据主题投稿了本篇教程内容,涉及到二维码转二进制矩阵、二维码、矩阵、zxing二维码位矩阵、zxing二维码位矩阵转Bitmap相关内容,已被399网友关注,如果对知识点想更进一步了解可以在下方电子资料中获取。

zxing二维码位矩阵转Bitmap

关于zxing

ZXing是一个开放源码的,用Java实现的多种格式的1D/2D条码图像处理库,它包含了联系到其他语言的端口。Zxing可以实现使用手机的内置的摄像头完成条形码的扫描及解码。

该项目可实现的条形码编码和解码。我们支持以下格式:

UPC-A,UPC-E

EAN-8,EAN-13

39码

93码

代码128

创新及科技基金

库德巴

RSS-14(所有的变体)

RSS扩展(大多数变体)

QR码

数据矩阵

阿兹台克人('测试版'质量)

PDF 417('阿尔法'的质量)

Zxing库的主要部分支持以下几个功能:核心代码的使用、适用于J2SE客户端的版本、适用于Android客户端的版本(即BarcodeScanner)、Android的集成(通过Intent支持和BarcodeScanner的集成)等。

关于zxing开源库中的位矩阵BitMatrix

Represents a 2D matrix of bits. In function arguments below, and throughout the common module, x is the column position, and y is the row position. The ordering is always x, y. The origin is at the top-left.
Internally the bits are represented in a 1-D array of 32-bit ints. However, each row begins with a new int. This is done intentionally so that we can copy out a row into a BitArray very efficiently.
The ordering of bits is row-major. Within each int, the least significant bits are used first, meaning they represent lower x values. This is compatible with BitArray's implementation.

 表示二维位矩阵。 在下面的函数参数中,以及整个通用模块中,x 是列位置,y 是行位置。 排序始终为 x, y。 原点在左上角。
在内部,这些位以 32 位整数的一维数组表示。 但是,每一行都以一个新的 int 开头。 这是有意完成的,以便我们可以非常有效地将一行复制到 BitArray 中。
位的顺序是行优先的。 在每个 int 中,首先使用最低有效位,这意味着它们代表较低的 x 值。 这与 BitArray 的实现兼容。

位矩阵配置

/// 1.设置二维码相关配置 ///
Hashtable hints = new Hashtable<>();
// 字符转码格式设置
hints.put(EncodeHintType.CHARACTER_SET, "UTF-8");
// 容错率设置
hints.put(EncodeHintType.ERROR_CORRECTION, "L");
// 空白边距设置
hints.put(EncodeHintType.MARGIN, "0");

位矩阵生成

BitMatrix matrix = new MultiFormatWriter().encode("二维码中的字符串信息", BarcodeFormat.QR_CODE, w, h, hints);

位矩阵转换成位图

int width = matrix.getWidth();
int height = matrix.getHeight();
//二维矩阵转为一维像素数组
int[] pixels = new int[width * height];
for (int j = 0; j < height; j++) {
    for (int i = 0; i < width; i++) {
        if (matrix.get(i, j)) {
            pixels[j * width + i] = Color.BLACK;
        }
    }
}
Bitmap bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_
//通过像素数组生成bitmap
bitmap.setPixels(pixels, 0, width, 0, 0, width, height);

matrix.get(i, j)是位矩阵中判断该点是否黑点

x - 水平分量(即哪一列)
y - 垂直分量(即哪一行)

关于位矩阵生成一位像素数组

按行遍历

int width = matrix.getWidth();
int height = matrix.getHeight();
//二维矩阵转为一维像素数组
int[] pixels = new int[width * height];
for (int j = 0; j < height; j++) {
    for (int i = 0; i < width; i++) {
        if (matrix.get(i, j)) {
            pixels[j * width + i] = Color.BLACK;
        }
    }
}

按列遍历

int width = matrix.getWidth();
int height = matrix.getHeight();
//二维矩阵转为一维像素数组
int[] pixels = new int[width * height];
for (int i = 0; i < width; i++) {
    for (int j = 0; j < height; j++) {
        if (matrix.get(i, j)) {
            pixels[j * width + i] = Color.BLACK;
        }
    }
}

 实现

public Bitmap Create2DCode(String str, int w, int h){
    if (TextUtils.isEmpty(str)) {
        return null;
    }
    if (w < 0 || h < 0) {
        return null;
    }
    /// 1.设置二维码相关配置 ///
    Hashtable hints = new Hashtable<>();
    // 字符转码格式设置
    hints.put(EncodeHintType.CHARACTER_SET, "UTF-8");
    // 容错率设置
    hints.put(EncodeHintType.ERROR_CORRECTION, "L");
    // 空白边距设置
    hints.put(EncodeHintType.MARGIN, "0");
    //生成二维矩阵,编码时指定大小,不要生成了图片以后再进行缩放,这样会模糊导致识别失败
    BitMatrix matrix = new MultiFormatWriter().encode(str, BarcodeFormat.QR_CODE, w,
    int width = matrix.getWidth();
    int height = matrix.getHeight();
    //二维矩阵转为一维像素数组
    int[] pixels = new int[width * height];
    for (int j = 0; j < height; j++) {
        for (int i = 0; i < width; i++) {
            if (matrix.get(i, j)) {
                pixels[j * width + i] = Color.BLACK;
            }
        }
    }
    Bitmap bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888);
    //通过像素数组生成bitmap,具体参考api
    bitmap.setPixels(pixels, 0, width, 0, 0, width, height);
    return bitmap;
}

提示:Android在位矩阵生成一维像素数组时,颜色值直接用16进制的颜色值0xFF000000,不要用getResources().getColor(R.color.black)这种方法,否则转化时间将会多消耗5-6倍

总结 

到此这篇关于zxing二维码位矩阵转换成Bitmap位图的文章就介绍到这了,更多相关zxing二维码位矩阵转Bitmap内容请搜索码农之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持码农之家!


相关文章

  • 最大子矩阵问题实例解析

    发布:2023-02-28

    为网友们分享了关于C++的教程,这篇文章主要介绍了最大子矩阵问题实例解析,分别列举了Java和C语言的相关实现,需要的朋友可以参考下


  • NumPy矩阵乘法的实现

    发布:2023-04-13

    本文主要介绍了NumPy矩阵乘法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧


  • Python3列表、数组、矩阵的相互转换方法

    发布:2019-11-26

    这篇文章主要介绍了Python3 列表,数组,矩阵的相互转换的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学


  • numpy矩阵乘法中的multiply,matmul和dot的使用

    发布:2023-04-09

    本文主要介绍了numpy矩阵乘法中的multiply,matmul和dot的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧


  • 关于jquery二维码生成插件qrcode详解

    发布:2020-02-11

    这篇文章主要为大家详细介绍了基于jquery二维码生成插件qrcode的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下


  • Thinkphp3.2.3整合phpqrcode生成带logo的二维码代码详解

    发布:2020-08-03

    这篇文章主要为大家详细介绍了Thinkphp3.2.3整合phpqrcode生成带logo的二维码的实现方法,感兴趣的小伙伴们可以参考一下


  • 关于pytorch相关部分矩阵变换函数的问题分析

    发布:2022-04-24

    这篇文章主要介绍了pytorch相关部分矩阵变换函数,包括tensor维度顺序变换BCHW顺序的调整,矩阵乘法相关函数,矩阵乘,点乘,求取矩阵对角线元素或非对角线元素的问题,本文给大家介绍的非常详细,需要的朋友可以参考下


  • Python用MyQR制作动态彩色二维码实例

    发布:2019-11-22

    MyQR是一个能够生成自定义二维码的第三方库,你可以根据需要生成普通二维码、带图片的艺术二维码,也可以生成动态二维码。这篇文章主要介绍了Python使用MyQR制作专属动态彩色二维码,需要的


网友讨论