Qrcode生成二维码,做过很多实验,探索最小规格的二维码到底是多少尺寸,和最高规格的二维码到底是多大尺寸。现在我总结总结:
有两种思路:
1.生成规格高的二维码,然后压缩到自己想要的尺寸的二维码。这种:压缩算法不好的时候会很坑爹。
2.根据调整的参数生成原图,这种图是比较清晰的,打印出来都可以很好的被识别。
先说说第二种吧:根据测试,
1.不设置任何东西时:根据测试
最小的二维码尺寸是45——47:宽高(对于1---14个字符),
第二梯度:54-56:宽高(对于15--26字符)
第三梯度:61-63:宽高(对于27-43字符)
第四题都:。。。。。。。。。。。。。。。。。。
当我设置:setQrcodeVersion(0); 生成的二维码尺寸随存储内容的变化而变化, 不会出现字符串越界的错误。
根据测试:
第一梯度:
1.设置最低排错率L,mode为A时:45-47:宽高(1-25个字符)
2.设置排错率M时,mode为A时,只能存20位(纯数字);
3.设置最低拍错率L,mode为B,时:45-47:宽高(1-17个字符)
如果想存储英文字符,绝对不能使用mode为A,必须使用mode为B
结论mode越大,字符串存储越小,排错率越大,存储字符越少
第二梯度:
最优条件下 26------47个字符占用大小是53-55的宽高;
对于常用的32位字符来说:最优配置是mode=A,排错率=M;占用53---55宽高,既能存储32位字符,又能是排错率更高,且尺寸是最极限。
第三梯度:
尺寸为62--64:最优配置能存储1-78位字符串。
当设置为1时:setQrcodeVersion(1); 如果超过所能存储的长度,将会报错,生成空白图片。
在最优情况下:45---47尺寸能存25个字符,但是如果将排错率改到最高H,那么只能存10位
注意的一点:控制生成的二维码大小跟 gs.fillRect(j * 3 + pixoff, i * 3 + pixoff, 3, 3); 有关系;代表三厘米的二维码,2代表2厘米的二维码,1代表1厘米的二维码。
总之:总结来说:
1.如果需要存储英文的,那么必须设置setQrcodeEncodeMode('B');
2.然后setQrcodeVersion(1);越大,那么生成的码存储信息越多,码越乱。
3.然后可以设置gs.fillRect(j * 3 + pixoff, i * 3 + pixoff, 3, 3);来控制生成二维码的大小。 (只能控制大致范围(最主要的控制),生成的大小还与设置setQrcodeVersion,setOrcodeEncodeMode,setQrcodeErrorCorrect有关. 根据这几个的关系可以调试出适合的二维码。
4.如果啥都不设置的话,那么同等情况下生成的二维码尺寸会比设置为0时更大。
设置的代码:
public class BuilOr { private static BufferedImage qRCodeCommon(String content, String imgType, int size) { BufferedImage bufImg = null; size =10; try { Qrcode qrcodeHandler = new Qrcode(); // // 设置二维码排错率,可选L(7%)、M(15%)、Q(25%)、H(30%),排错率越高可存储的信息越少,但对二维码清晰度的要求越小 qrcodeHandler.setQrcodeErrorCorrect('M'); qrcodeHandler.setQrcodeEncodeMode('B'); // // 设置设置二维码尺寸,取值范围1-40,值越大尺寸越大,可存储的信息越大 qrcodeHandler.setQrcodeVersion(size); // 获得内容的字节数组,设置编码格式 byte[] contentBytes = content.getBytes("utf-8"); int imgSize =178; bufImg = new BufferedImage(imgSize, imgSize, BufferedImage.TYPE_INT_RGB); Graphics2D gs = bufImg.createGraphics(); // 设置背景颜色 gs.setBackground(Color.WHITE); gs.clearRect(0, 0, imgSize, imgSize); // 设定图像颜色> BLACK gs.setColor(Color.BLACK); // 设置偏移量,不设置可能导致解析出错 int pixoff = 2; // 输出内容> 二维码 if (contentBytes.length > 0 && contentBytes.length < 500) { boolean[][] codeOut = qrcodeHandler.calQrcode(contentBytes); for (int i = 0; i < codeOut.length; i++) { for (int j = 0; j < codeOut.length; j++) { if (codeOut[j][i]) { gs.fillRect(j * 2 + pixoff, i * 2 + pixoff, 2, 2); } } } } else { throw new Exception("QRCode content bytes length = " + contentBytes.length + " not in [0, 800]."); } gs.dispose(); bufImg.flush(); } catch (Exception e) { e.printStackTrace(); } return bufImg; }