在Android配置文件build.gradle(app)中直接implementation的zxing.core。
implementation 'com.google.zxing:core:3.5.1'
在网上找到个代码,可以创建PDF417码制的二维码。
public static Bitmap createPdf417(String text, int size) {
try {
Hashtable<EncodeHintType, Object> hints = new Hashtable<EncodeHintType, Object>();
hints.put(EncodeHintType.CHARACTER_SET, "utf-8");
// hints.put(EncodeHintType.ERROR_CORRECTION,"2");
hints.put(EncodeHintType.MARGIN, 1);
BitMatrix bitMatrix = new PDF417Writer().encode(text,
BarcodeFormat.PDF_417, size, size, hints);
// int[] pixels = new int[size * size];
int bitWidth = bitMatrix.getWidth();
int bitHeight = bitMatrix.getHeight();
int[] pixels = new int[bitWidth * bitHeight];
//遍历bitmatrix,为像素矩阵按一行行(横列)设置像素颜色。
for (int y = 0; y < bitHeight; y++) {//遍历一行一行像素
for (int x = 0; x < bitWidth; x++) {
if (bitMatrix.get(x, y)) {
pixels[y * bitWidth + x] = 0xff000000;
} else {
pixels[y * bitWidth + x] = 0xffffffff;
}
}
}
Bitmap bitmap = Bitmap.createBitmap(bitWidth, bitHeight,
Bitmap.Config.ARGB_8888);
bitmap.setPixels(pixels, 0, bitWidth, 0, 0, bitWidth, bitHeight);
return bitmap;
} catch (WriterException e) {
e.printStackTrace();
return null;
}
//return null;
}
使用:自己的类.createPdf417(String text, int size)
text为二维码的内容,size为大小。
用了pdf417的办法,压缩,紧凑,不失真–都不行。
发现是个老bug老bug,具体的原因就是在增加hints的时候加上了UTF-8的标准。但是zxing库这个默认的标准是iso_8859_1。
而且追了下发现是先是iso然后又转成了UTF-8,所以出现了BUG。但是如果不加utf-8的话,就直接是iso标准,就不会有前面是A的方法了。
不过如果要求是utf-8那还是蛮麻烦的。
public static Bitmap createPdf417(String text, int size) {
try {
Hashtable<EncodeHintType, Object> hints = new Hashtable<EncodeHintType, Object>();
// hints.put(EncodeHintType.ERROR_CORRECTION,"2");
hints.put(EncodeHintType.MARGIN, 1);
BitMatrix bitMatrix = new PDF417Writer().encode(text,
BarcodeFormat.PDF_417, size, size, hints);
// int[] pixels = new int[size * size];
int bitWidth = bitMatrix.getWidth();
int bitHeight = bitMatrix.getHeight();
int[] pixels = new int[bitWidth * bitHeight];
//遍历bitmatrix,为像素矩阵按一行行(横列)设置像素颜色。
for (int y = 0; y < bitHeight; y++) {//遍历一行一行像素
for (int x = 0; x < bitWidth; x++) {
if (bitMatrix.get(x, y)) {
pixels[y * bitWidth + x] = 0xff000000;
} else {
pixels[y * bitWidth + x] = 0xffffffff;
}
}
}
Bitmap bitmap = Bitmap.createBitmap(bitWidth, bitHeight,
Bitmap.Config.ARGB_8888);
bitmap.setPixels(pixels, 0, bitWidth, 0, 0, bitWidth, bitHeight);
return bitmap;
} catch (WriterException e) {
e.printStackTrace();
return null;
}
//return null;
}
追了好久的源码,也没有找到到底那里转换错了。时间紧迫,就先这样改了。