import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
import javax.imageio.ImageIO;
import com.google.zxing.BarcodeFormat;
import com.google.zxing.BinaryBitmap;
import com.google.zxing.DecodeHintType;
import com.google.zxing.EncodeHintType;
import com.google.zxing.MultiFormatReader;
import com.google.zxing.MultiFormatWriter;
import com.google.zxing.NotFoundException;
import com.google.zxing.Result;
import com.google.zxing.client.j2se.BufferedImageLuminanceSource;
import com.google.zxing.client.j2se.MatrixToImageConfig;
import com.google.zxing.client.j2se.MatrixToImageWriter;
import com.google.zxing.common.BitMatrix;
import com.google.zxing.common.HybridBinarizer;
import com.google.zxing.qrcode.decoder.ErrorCorrectionLevel;
/**
* ZXing工具类
* @see -----------------------------------------------------------------------------------------------------------------------
* @see 首页--https://code.google.com/p/zxing
* @see 介绍--用于解析多种格式条形码(EAN-13)和二维码(QRCode)的开源Java类库,其提供了多种应用的类库,如javase/jruby/cpp/csharp/android
* @see 说明--下载到的ZXing-2.2.zip是它的源码,我们在JavaSE中使用时需用到其core和javase两部分
* @see 可直接引入它俩的源码到项目中,或将它俩编译为jar再引入,这是我编译好的:http://download.csdn.net/detail/jadyer/6245849
* @see -----------------------------------------------------------------------------------------------------------------------
* @see 经测试:用微信扫描GBK编码的中文二维码时出现乱码,用UTF-8编码时微信可正常识别
* @see 并且MultiFormatWriter.encode()时若传入hints参数来指定UTF-8编码中文时,微信压根就不识别所生成的二维码
* @see 所以这里使用的是这种方式new String(content.getBytes("UTF-8"), "ISO-8859-1")
* @see -----------------------------------------------------------------------------------------------------------------------
* @see 将logo图片加入二维码中间时,需注意以下几点
* @see 1)生成二维码的纠错级别建议采用最高等级H,这样可以增加二维码的正确识别能力(我测试过,不设置级别时,二维码工具无法读取生成的二维码图片)
* @see 2)头像大小最好不要超过二维码本身大小的1/5,而且只能放在正中间部位,这是由于二维码本身结构造成的(你就把它理解成图片水印吧)
* @see 3)在仿照腾讯微信在二维码四周增加装饰框,那么一定要在装饰框和二维码之间留出白边,这是为了二维码可被识别
* @see -----------------------------------------------------------------------------------------------------------------------
* @version v1.0
* @history v1.0-->方法新建,目前仅支持二维码的生成和解析,生成二维码时支持添加logo头像
* @editor Sep 10, 2013 9:32:23 PM
* @create Sep 10, 2013 2:08:16 PM
* @author 玄玉<http://blog.csdn.net/jadyer>
*/
public class ZXingUtil {
private ZXingUtil(){}
/**
* 为二维码图片增加logo头像
* @see 其原理类似于图片加水印
* @param imagePath 二维码图片存放路径(含文件名)
* @param logoPath logo头像存放路径(含文件名)
*/
private static void overlapImage(String imagePath, String logoPath) throws IOException {
BufferedImage image = ImageIO.read(new File(imagePath));
int logoWidth = image.getWidth()/5; //设置logo图片宽度为二维码图片的五分之一
int logoHeight = image.getHeight()/5; //设置logo图片高度为二维码图片的五分之一
int logoX = (image.getWidth()-logoWidth)/2; //设置logo图片的位置,这里令其居中
int logoY = (image.getHeight()-logoHeight)/2; //设置logo图片的位置,这里令其居中
Graphics2D graphics = image.createGraphics();
graphics.drawImage(ImageIO.read(new File(logoPath)), logoX, logoY, logoWidth, logoHeight, null);
graphics.dispose();
ImageIO.write(image, imagePath.substring(imagePath.lastIndexOf(".") + 1), new File(imagePath));
}
/**
* 生成二维码
* @param content 二维码内容
* @param charset 编码二维码内容时采用的字符集(传null时默认采用UTF-8编码)
* @param imagePath 二维码图片存放路径(含文件名)
* @param width 生成的二维码图片宽度
* @param height 生成的二维码图片高度
* @param logoPath logo头像存放路径(含文件名,若不加logo则传null即可)
* @return 生成二维码结果(true or false)
*/
public static boolean encodeQRCodeImage(String content, String charset, String imagePath, int width, int height, String logoPath) {
Map<EncodeHintType, Object> hints = new HashMap<EncodeHintType, Object>();
//指定编码格式
//hints.put(EncodeHintType.CHARACTER_SET, "UTF-8");
//指定纠错级别(L--7%,M--15%,Q--25%,H--30%)
hints.put(EncodeHintType.ERROR_CORRECTION, ErrorCorrectionLevel.H);
//编码内容,编码类型(这里指定为二维码),生成图片宽度,生成图片高度,设置参数
BitMatrix bitMatrix = null;
try {
bitMatrix = new MultiFormatWriter().encode(new String(content.getBytes(charset==null?"UTF-8":charset), "ISO-8859-1"), BarcodeFormat.QR_CODE, width, height, hints);
} catch (Exception e) {
System.out.println("编码待生成二维码图片的文本时发生异常,堆栈轨迹如下");
e.printStackTrace();
return false;
}
//生成的二维码图片默认背景为白色,前景为黑色,但是在加入logo图像后会导致logo也变为黑白色,至于是什么原因还没有仔细去读它的源码
//所以这里对其第一个参数黑色将ZXing默认的前景色0xFF000000稍微改了一下0xFF000001,最终效果也是白色背景黑色前景的二维码,且logo颜色保持原有不变
MatrixToImageConfig config = new MatrixToImageConfig(0xFF000001, 0xFFFFFFFF);
//这里要显式指定MatrixToImageConfig,否则还会按照默认处理将logo图像也变为黑白色(如果打算加logo的话,反之则不须传MatrixToImageConfig参数)
try {
MatrixToImageWriter.writeToFile(bitMatrix, imagePath.substring(imagePath.lastIndexOf(".") + 1), new File(imagePath), config);
} catch (IOException e) {
System.out.println("生成二维码图片[" + imagePath + "]时遇到异常,堆栈轨迹如下");
e.printStackTrace();
return false;
}
//此时二维码图片已经生成了,只不过没有logo头像,所以接下来根据传入的logoPath参数来决定是否加logo头像
if(null == logoPath){
return true;
}else{
//如果此时最终生成的二维码不是我们想要的,那么可以扩展MatrixToImageConfig类(反正ZXing提供了源码)
//扩展时可以重写其writeToFile方法,令其返回toBufferedImage()方法所生成的BufferedImage对象(尽管这种做法未必能解决为题,故需根据实际情景测试)
//然后替换这里overlapImage()里面的第一行BufferedImage image = ImageIO.read(new File(imagePath));
//即private static void overlapImage(BufferedImage image, String imagePath, String logoPath)
try {
//这里不需要判断logoPath是否指向了一个具体的文件,因为这种情景下overlapImage会抛IO异常
overlapImage(imagePath, logoPath);
return true;
} catch (IOException e) {
System.out.println("为二维码图片[" + imagePath + "]添加logo头像[" + logoPath + "]时遇到异常,堆栈轨迹如下");
e.printStackTrace();
return false;
}
}
}
/**
* 解析二维码
* @param imagePath 二维码图片存放路径(含文件名)
* @param charset 解码二维码内容时采用的字符集(传null时默认采用UTF-8编码)
* @return 解析成功后返回二维码文本,否则返回空字符串
*/
public static String decodeQRCodeImage(String imagePath, String charset) {
BufferedImage image = null;
try {
image = ImageIO.read(new File(imagePath));
} catch (IOException e) {
e.printStackTrace();
return "";
}
if(null == image){
System.out.println("Could not decode QRCodeImage");
return "";
}
BinaryBitmap bitmap = new BinaryBitmap(new HybridBinarizer(new BufferedImageLuminanceSource(image)));
Map<DecodeHintType, String> hints = new HashMap<DecodeHintType, String>();
hints.put(DecodeHintType.CHARACTER_SET, charset==null ? "UTF-8" : charset);
Result result = null;
try {
result = new MultiFormatReader().decode(bitmap, hints);
return result.getText();
} catch (NotFoundException e) {
System.out.println("二维码图片[" + imagePath + "]解析失败,堆栈轨迹如下");
e.printStackTrace();
return "";
}
}
}
转自【http://www.open-open.com/lib/view/open1379214678162.html】
分享到:
相关推荐
在Java环境下,使用ZXing生成二维码的步骤如下: 1. 引入ZXing库:在项目中添加ZXing的依赖,通常通过Maven或Gradle来管理。对于Maven,可以在pom.xml文件中添加如下依赖: ```xml <groupId>com.google.zxing</...
该工具类目前比较简单,只是实现了普通二维码、logo二维码、彩色二维码和二维码条形码解析几个功能。 根据此工具类可扩展生成LOGO+文字的二维码,暂时不需要没有封装。
【使用ZXing生成二维码的代码示例】 在Java中,你可以使用以下代码生成一个简单的二维码: ```java import com.google.zxing.*; import com.google.zxing.client.j2se.MatrixToImageWriter; import ...
Java后台生成二维码工具类
通过ZXing,开发者可以在Java环境下轻松地实现二维码的生成与解析功能,无论是移动应用还是服务器端程序,都可以利用这一强大的工具来提升用户体验,比如快速分享链接、存储复杂数据或者创建带有企业标识的个性化...
本文将深入探讨如何利用ZXing库在Java环境下创建一个二维码工具类,以及涉及到的相关知识点。 首先,ZXing(Zebra Crossing)是Google发起的一个开源项目,其核心功能是读取和生成多种条码和二维码。在本示例中,...
接下来,我们创建一个简单的Java类来生成二维码。首先,我们需要导入必要的ZXing库: ```java import com.google.zxing.BarcodeFormat; import com.google.zxing.EncodeHintType; import ...
三、使用ZXing生成二维码 1. **Java版**:在Java环境中,可以使用`com.google.zxing.client.j2se.MatrixToImageWriter`类将数据编码为图像。首先,创建一个`BitMatrix`对象来存储编码后的数据,然后调用`...
基于zxing的二维码生成工具类
在标题“利用ZXING生成简易二维码”中,提到的核心知识点是使用ZXing库来创建二维码。ZXing库提供了Java、Android以及命令行工具等多种方式来操作二维码。生成二维码的基本步骤包括: 1. **配置ZXing**: 首先,你...
这个工具类基于ZXing(Zebra Crossing)开源库,版本号为3.1.0,ZXing是一个广泛使用的二维码和条形码解码与编码库。下面我们将详细讨论这个工具类以及其背后的ZXing库。 1. **ZXing库介绍** - ZXing(读作"zebra ...
下面我们将详细介绍如何使用ZXing生成二维码以及相关的知识点。 1. **ZXing概述**: ZXing(又称“Zebra Crossing”)是一个开放源代码的条形码解码库,支持多种格式,包括QR码、Data Matrix、UPC和EAN等一维条形...
以下是使用ZXing生成二维码的基本步骤: 1. 引入ZXing库:将`zxing3.3.1.jar`添加到项目的类路径中,如果是Java项目,可以将其放入`lib`目录下,或者在Maven/Gradle构建工具中配置依赖。 2. 创建BitMatrix对象:这...
三、ZXing生成二维码名片步骤 1. 引入ZXing库:首先,你需要在项目中引入ZXing库。对于Java项目,可以通过Maven或Gradle添加依赖;对于Android项目,可以直接在build.gradle文件中添加ZXing的aar包。 2. 创建二维码...
这个“安卓zxing生成二维码和扫描例子”是一个示例项目,可以帮助开发者快速理解并应用ZXing库。 首先,让我们了解一下二维码(QR Code)的基本概念。二维码是一种二维条形码,可以存储比传统条形码更多、更复杂的...
**谷歌ZXing库生成二维码详解** 谷歌ZXing(Zebra Crossing)是一个开源的、多平台的条码读取和生成库。ZXing.Net是ZXing的.NET版本,它为C#开发者提供了方便的API,使得在.NET平台上生成和读取二维码变得简单易行...
2. 使用自定义函数:由于iReport本身不直接支持ZXing,我们可能需要编写Java代码片段(在iReport中称为“自定义函数”或“脚本”),利用ZXing API生成二维码图像。 3. 插入图像组件:在报表设计中,添加一个图像...
这个助手类是为了简化使用ZXing生成二维码的过程,通常会封装一些常用方法,如设置二维码的内容、大小、纠错级别等。在实际使用时,只需要在项目中复制这个助手类,然后通过调用其提供的方法,就可以快速地生成...
总之,ZXing.NET为C#开发者提供了一种强大的工具,用于处理二维码和条形码。无论是简单的识别还是复杂的集成,都可以借助这个库轻松实现。在实际开发中,结合具体业务需求,合理运用ZXing.NET,可以提升应用的数据...
以下是一个简单的示例代码,演示如何使用ZXing生成二维码: ```java import com.google.zxing.*; import com.google.zxing.common.BitMatrix; import com.google.zxing.qrcode.QRCodeWriter; import ...