复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125compileOnly 'com.google.zxing:core:3.3.0' Bitmap bitmap = QRCodeUtil.createQRCodeBitmap(encryptText, 400, 400); import android.graphics.Bitmap; import android.graphics.Color; import android.text.TextUtils; import androidx.annotation.ColorInt; import androidx.annotation.Nullable; 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.common.CharacterSetECI; import com.google.zxing.qrcode.QRCodeWriter; import com.google.zxing.qrcode.decoder.ErrorCorrectionLevel; import com.inks.inkslibrary.Utils.L; import java.util.HashMap; import java.util.Map; public class QRCodeUtil { /** * 创建二维码位图 * * @param content 字符串内容(支持中文) * @param width 位图宽度(单位:px) * @param height 位图高度(单位:px) * @return */ @Nullable public static Bitmap createQRCodeBitmap(String content, int width, int height){ return createQRCodeBitmap(content, width, height, "UTF-8", "H", "2", Color.BLACK, Color.WHITE); } /** * 创建二维码位图 (支持自定义配置和自定义样式) * * @param content 字符串内容 * @param width 位图宽度,要求>=0(单位:px) * @param height 位图高度,要求>=0(单位:px) * @param character_set 字符集/字符转码格式 (支持格式:{@link CharacterSetECI })。传null时,zxing源码默认使用 "ISO-8859-1" * @param error_correction 容错级别 (支持级别:{@link ErrorCorrectionLevel })。传null时,zxing源码默认使用 "L" * @param margin 空白边距 (可修改,要求:整型且>=0), 传null时,zxing源码默认使用"4"。 * @param color_black 黑色色块的自定义颜色值 * @param color_white 白色色块的自定义颜色值 * @return */ @Nullable public static Bitmap createQRCodeBitmap(String content, int width, int height, @Nullable String character_set, @Nullable String error_correction, @Nullable String margin, @ColorInt int color_black, @ColorInt int color_white){ /** 1.参数合法性判断 */ if(TextUtils.isEmpty(content)){ // 字符串内容判空 return null; } if(width < 0 || height < 0){ // 宽和高都需要>=0 return null; } try { /** 2.设置二维码相关配置,生成BitMatrix(位矩阵)对象 */ Map hints = new HashMap(); //设置UTF-8, 防止中文乱码 hints.put(EncodeHintType.CHARACTER_SET, "UTF-8"); //设置二维码四周白色区域的大小 hints.put(EncodeHintType.MARGIN,0); //设置二维码的容错性 hints.put(EncodeHintType.ERROR_CORRECTION, ErrorCorrectionLevel.H); // Map hints = new HashMap(); // // if(!TextUtils.isEmpty(character_set)) { // hints.put(EncodeHintType.CHARACTER_SET, character_set); // 字符转码格式设置 // } // // if(!TextUtils.isEmpty(error_correction)){ // hints.put(EncodeHintType.ERROR_CORRECTION, error_correction); // 容错级别设置 // } // // if(!TextUtils.isEmpty(margin)){ // hints.put(EncodeHintType.MARGIN, margin); // 空白边距设置 // } BitMatrix bitMatrix = new QRCodeWriter().encode(content, BarcodeFormat.QR_CODE, width, height, hints); /** 3.创建像素数组,并根据BitMatrix(位矩阵)对象为数组元素赋颜色值 */ 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)){ pixels[y * width + x] = color_black; // 黑色色块像素设置 } else { pixels[y * width + x] = color_white; // 白色色块像素设置 } } } /** 4.创建Bitmap对象,根据像素数组设置Bitmap每个像素点的颜色值,之后返回Bitmap对象 */ Bitmap bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888); bitmap.setPixels(pixels, 0, width, 0, 0, width, height); return bitmap; } catch (WriterException e) { L.e("WriterException"); e.printStackTrace(); } return null; } }
最后
以上就是明亮乌龟最近收集整理的关于Android工具类(生成二维码)的全部内容,更多相关Android工具类(生成二维码)内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复