ZXing-core QR코드 생성 방법 및 해석
사실 주로 goggle에서 발표한jar를 이용하여 이 기능을 사용합니다.
1. QR코드의 생성
Zxing-core.jar 패키지를classpath에 추가합니다.
QR코드의 생성은 Matrix To Image Writer 클래스를 사용해야 합니다. 이 클래스는 Google에서 제공한 것입니다. 이 클래스를 원본 코드로 복사할 수 있습니다. 여기서 이 클래스의 원본 코드를 붙여서 직접 사용할 수 있습니다.
QR코드를 직접 생성할 수 있는 코드
public void test1() throws Exception{ 
String content = "www.baidu.com"; 
String path = "d://"; 
MultiFormatWriter multiFormatWriter = new MultiFormatWriter();//Zxing Google  
Map hints = new HashMap(); 
hints.put(EncodeHintType.CHARACTER_SET, "UTF-8"); 
BitMatrix bitMatrix = multiFormatWriter.encode(content, BarcodeFormat.QR_CODE, 400, 400,hints);//  
File file1 = new File(path,"my.jpg"); 
MatrixToImageWriter.writeToFile(bitMatrix, "jpg", file1); 
System.out.println(" "); 
} 
import com.google.zxing.common.BitMatrix; 
import javax.imageio.ImageIO; 
import java.io.File; 
import java.io.OutputStream; 
import java.io.IOException; 
import java.awt.image.BufferedImage; 
public final class MatrixToImageWriter { 
private static final int BLACK = 0xFF000000; 
private static final int WHITE = 0xFFFFFFFF; 
private MatrixToImageWriter() {} 
public static BufferedImage toBufferedImage(BitMatrix matrix) { 
int width = matrix.getWidth(); 
int height = matrix.getHeight(); 
BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB); 
for (int x = 0; x < width; x++) { 
for (int y = 0; y < height; y++) { 
image.setRGB(x, y, matrix.get(x, y) ? BLACK : WHITE); 
} 
} 
return image; 
} 
public static void writeToFile(BitMatrix matrix, String format, File file) 
throws IOException { 
BufferedImage image = toBufferedImage(matrix); 
if (!ImageIO.write(image, format, file)) { 
throw new IOException("Could not write an image of format " + format + " to " + file); 
} 
} 
public static void writeToStream(BitMatrix matrix, String format, OutputStream stream) 
throws IOException { 
BufferedImage image = toBufferedImage(matrix); 
if (!ImageIO.write(image, format, stream)) { 
throw new IOException("Could not write an image of format " + format); 
} 
} 
} QR코드 해석
생성과 마찬가지로, 우리는 보조 클래스(Buffered Image Luminance Source)가 필요합니다. 같은 종류의 Google도 제공했습니다. 여기에서 저는 이 클래스의 원본 코드를 붙여서 직접 복사해서 사용할 수 있습니다. 찾기의 번거로움을 줄일 수 있습니다.
BufferedImageLuminanceSource 
import com.google.zxing.LuminanceSource; 
import java.awt.Graphics2D; 
import java.awt.geom.AffineTransform; 
import java.awt.image.BufferedImage; 
public final class BufferedImageLuminanceSource extends LuminanceSource { 
private final BufferedImage image; 
private final int left; 
private final int top; 
public BufferedImageLuminanceSource(BufferedImage image) { 
this(image, 0, 0, image.getWidth(), image.getHeight()); 
} 
public BufferedImageLuminanceSource(BufferedImage image, int left, int top, int width, int height) { 
super(width, height); 
int sourceWidth = image.getWidth(); 
int sourceHeight = image.getHeight(); 
if (left + width > sourceWidth || top + height > sourceHeight) { 
throw new IllegalArgumentException("Crop rectangle does not fit within image data."); 
} 
for (int y = top; y < top + height; y++) { 
for (int x = left; x < left + width; x++) { 
if ((image.getRGB(x, y) & 0xFF000000) == 0) { 
image.setRGB(x, y, 0xFFFFFFFF); // = white 
} 
} 
} 
this.image = new BufferedImage(sourceWidth, sourceHeight, BufferedImage.TYPE_BYTE_GRAY); 
this.image.getGraphics().drawImage(image, 0, 0, null); 
this.left = left; 
this.top = top; 
} 
@Override 
public byte[] getRow(int y, byte[] row) { 
if (y < 0 || y >= getHeight()) { 
throw new IllegalArgumentException("Requested row is outside the image: " + y); 
} 
int width = getWidth(); 
if (row == null || row.length < width) { 
row = new byte[width]; 
} 
image.getRaster().getDataElements(left, top + y, width, 1, row); 
return row; 
} 
@Override 
public byte[] getMatrix() { 
int width = getWidth(); 
int height = getHeight(); 
int area = width * height; 
byte[] matrix = new byte[area]; 
image.getRaster().getDataElements(left, top, width, height, matrix); 
return matrix; 
} 
@Override 
public boolean isCropSupported() { 
return true; 
} 
@Override 
public LuminanceSource crop(int left, int top, int width, int height) { 
return new BufferedImageLuminanceSource(image, this.left + left, this.top + top, width, height); 
} 
@Override 
public boolean isRotateSupported() { 
return true; 
} 
@Override 
public LuminanceSource rotateCounterClockwise() { 
int sourceWidth = image.getWidth(); 
int sourceHeight = image.getHeight(); 
AffineTransform transform = new AffineTransform(0.0, -1.0, 1.0, 0.0, 0.0, sourceWidth); 
BufferedImage rotatedImage = new BufferedImage(sourceHeight, sourceWidth, BufferedImage.TYPE_BYTE_GRAY); 
Graphics2D g = rotatedImage.createGraphics(); 
g.drawImage(image, transform, null); 
g.dispose(); 
int width = getWidth(); 
return new BufferedImageLuminanceSource(rotatedImage, top, sourceWidth - (left + width), getHeight(), width); 
} 
} 
MultiFormatReader formatReader = new MultiFormatReader(); 
String filePath = " "; 
File file = new File(filePath); 
BufferedImage image = ImageIO.read(file);; 
LuminanceSource source = new BufferedImageLuminanceSource(image); 
Binarizer binarizer = new HybridBinarizer(source); 
BinaryBitmap binaryBitmap = new BinaryBitmap(binarizer); 
Map hints = new HashMap(); 
hints.put(EncodeHintType.CHARACTER_SET, "UTF-8"); 
Result result = formatReader.decode(binaryBitmap,hints); 
System.out.println("result = "+ result.toString()); 
System.out.println("resultFormat = "+ result.getBarcodeFormat()); 
System.out.println("resultText = "+ result.getText()); 
tch (Exception e) { 
e.printStackTrace(); 위에서 말한 것은 여러분이 소개해 드린 ZXing-core의 QR코드 생성 방법과 해석에 관한 지식입니다. 여러분께 도움이 되었으면 좋겠습니다. 궁금한 점이 있으면 저에게 메시지를 남겨 주시면 제때에 답장해 드리겠습니다.여기에서도 저희 사이트에 대한 지지에 감사드립니다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Android에서 바코드 스캐너 구현카메라나 GPS등 하드웨어 의존의 기능을 만들 때, 스마트폰은 편리하네요. 앱판 밖에 없는 기능을 담는 것으로, Web판과의 차별화도 할 수 있습니다. 이번에는 Android에서 バーコードスキャナー 기능을 구현하고 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.