⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 alignmentpattern.java

📁 一款用Java实现QR解码的源代码。
💻 JAVA
字号:
package jp.sourceforge.qrcode.codec.reader.pattern;

import jp.sourceforge.qrcode.codec.reader.*;
import jp.sourceforge.qrcode.codec.exception.AlignmentPatternEdgeNotFoundException;
import jp.sourceforge.qrcode.codec.geom.*;
import jp.sourceforge.qrcode.codec.util.*;

public class AlignmentPattern {
	static final int RIGHT = 1;
	static final int BOTTOM = 2;
	static final int LEFT = 3;
	static final int TOP = 4;

	static DebugCanvas canvas = DebugCanvas.getCanvas();
	Point[][] center;
	//int sqrtCenters; //埵抲崌偣僷僞乕儞偺1曈摉偨傝偺悢
	int patternDistance;
	
	AlignmentPattern(Point[][] center, int patternDistance) {
		this.center = center;
		this.patternDistance = patternDistance;
	}
	
	public static AlignmentPattern findAlignmentPattern(boolean[][] image, FinderPattern finderPattern) 
		throws AlignmentPatternEdgeNotFoundException {

		Point[][] logicalCenters = getLogicalCenter(finderPattern);
		int logicalDistance = logicalCenters[1][0].getX() - logicalCenters[0][0].getX();

		//FinderPattern傪AlignmentPattern偲摨條偵埖偆偨傔偵曄姺偡傞
		Point[][] centers = null;
		try {
			centers = getCenter(image, finderPattern, logicalCenters);
		} catch (AlignmentPatternEdgeNotFoundException e) {
			e.printStackTrace();
			throw e;
		}
		return new AlignmentPattern(centers, logicalDistance);

	}
	
	public Point[][] getCenter() {
		return center;
	}
	
	public int getLogicalDistance() {
		return patternDistance;
	}
	
	static Point[][] getCenter(boolean[][] image, FinderPattern finderPattern, Point[][] logicalCenters) 
			throws AlignmentPatternEdgeNotFoundException {
		int moduleSize = finderPattern.getModuleSize();
		int sin = finderPattern.getAngle()[0];
		int cos = finderPattern.getAngle()[1];

		Axis axis = new Axis(sin, cos, moduleSize);


		int sqrtCenters = logicalCenters.length;

		Point[][] centers = new Point[sqrtCenters][sqrtCenters];
		
		axis.setOrigin(finderPattern.getCenter(FinderPattern.UL));
		centers[0][0] = axis.translate(3, 3);
		//centers[0][0] = finderPattern.getCenter(FinderPattern.UL);
		axis.setOrigin(finderPattern.getCenter(FinderPattern.UR));
		centers[sqrtCenters - 1][0] = axis.translate(-3, 3);
		//centers[sqrtCenters - 1][0] = finderPattern.getCenter(FinderPattern.UR);
		axis.setOrigin(finderPattern.getCenter(FinderPattern.DL));
		centers[0][sqrtCenters - 1] = axis.translate(3, -3);
		//centers[0][sqrtCenters - 1] = finderPattern.getCenter(FinderPattern.DL);

		for (int y = 0; y < sqrtCenters; y++) {
			for (int x = 0; x < sqrtCenters; x++) {
				if (x == 1 && y == 0 && sqrtCenters == 3) { //宆斣7乣13偺拞墰忋偺埵抲崌偣僷僞乕儞
					centers[x][y] = Point.getCenter(centers[0][0], centers[sqrtCenters - 1][0]);
				}
				else if (x == 0 && y == 1 && sqrtCenters == 3) {//宆斣7乣13偺嵍拞墰偺埵抲崌偣僷僞乕儞
					centers[x][y] = Point.getCenter(centers[0][0], centers[0][sqrtCenters - 1]);					
				}
				else if (x >= 1 && y >= 1){

					Line[] additionalLines = { 
							new Line(centers[x - 1][y - 1], centers[x][y - 1]),
							new Line(centers[x - 1][y - 1], centers[x - 1][y])};
					int dx = centers[x - 1][y].getX() - centers[x - 1][y - 1].getX();
					int dy = centers[x - 1][y].getY() - centers[x - 1][y - 1].getY();
					additionalLines[0].translate(dx,dy);
					dx = centers[x][y - 1].getX() - centers[x - 1][y - 1].getX();
					dy = centers[x][y - 1].getY() - centers[x - 1][y - 1].getY();
					additionalLines[1].translate(dx,dy);
					centers[x][y] = Point.getCenter(additionalLines[0].getP2(), additionalLines[1].getP2());
				}
				else // dummy alignment pattern (source is finder pattern)
					continue;
				try {
					centers[x][y] = getPrecisionCenter(image, centers[x][y]);
				} catch (AlignmentPatternEdgeNotFoundException e) {
					e.printStackTrace();
					throw e;
				}
				canvas.drawCross(centers[x][y], Color.LIGHTRED);
			}
			//System.out.println("");
		}
		return centers;
	}

	
	
	static Point getPrecisionCenter(boolean[][] image, Point targetPoint) 
			throws AlignmentPatternEdgeNotFoundException {
		//傕偟僗僞乕僩抧揰偑柧揰偺応崌丄堦斣嬤偄埫揰傪targetPoint偲偡傞
		if (image[targetPoint.getX()][targetPoint.getY()] == QRCodeImageReader.POINT_LIGHT) {
			int scope = 0;
			boolean notFound = true;
			while (notFound) {
				scope++;
				for (int dy = scope; dy > -scope; dy--) {
					for (int dx = scope; dx > -scope; dx--) {
						if (image[targetPoint.getX() + dx][targetPoint.getY() + dy] == QRCodeImageReader.POINT_DARK) {
							targetPoint = new Point(targetPoint.getX() + dx,targetPoint.getY() + dy);
							notFound = false;
						}
					}
				}
			}
		}
		
		Point pointEdgeRight = null,
					pointEdgeBottom = null,
					pointEdgeLeft = null,
					pointEdgeTop = null;

		try {
			pointEdgeRight = getEdge(image, targetPoint, RIGHT);
			pointEdgeBottom = getEdge(image, targetPoint, BOTTOM);
			pointEdgeLeft = getEdge(image, targetPoint, LEFT);
			pointEdgeTop = getEdge(image, targetPoint, TOP);
		} catch (AlignmentPatternEdgeNotFoundException e) {
			e.printStackTrace();
			throw e;
		}
		int x = Point.getCenter(pointEdgeLeft, pointEdgeRight).getX();
		int y = Point.getCenter(pointEdgeTop, pointEdgeBottom).getY();
		return new Point(x, y);
	}

	
	//奺埵抲崌偣僷僞乕儞偺榑棟嵗昗傪摼傞
	static Point[][] getLogicalCenter(FinderPattern finderPattern) {
		int version = finderPattern.getVersion();
		Point[][] logicalCenters = new Point[1][1];
		int[] logicalSeeds = new int[1];

		//憡懳嵗昗偺尦偵側傞楍嵗昗,峴嵗昗偺嶌惉
		if (version == 1)
			return null;
		else if (version >= 2 && version <= 6) {
			logicalSeeds = new int[2];
			logicalSeeds[0] = 6;
			logicalSeeds[1] = 10 + 4 * version;
			logicalCenters = new Point[logicalSeeds.length][logicalSeeds.length];
		}
		else if (version >= 7 && version <= 13) {
			logicalSeeds = new int[3];
			logicalSeeds[0] = 6;
			logicalSeeds[1] = 8 + 2 * version;
			logicalSeeds[2] = 10 + 4 * version;
			logicalCenters = new Point[logicalSeeds.length][logicalSeeds.length];
		}
//		else if (version >= 14 && version <= 20) {
//			//canvas.println("logical center v14-20");
//			logicalSeeds = new int[4];
//			logicalSeeds[0] = 6;
//			logicalSeeds[1] = 26 + ((version - 14) / 3) * 4;
//			logicalSeeds[2] = 18 + 2 * version;
//			logicalSeeds[3] = 10 + 4 * version;
//			logicalCenters = new Point[logicalSeeds.length][logicalSeeds.length];
//		}
		
		//幚嵺偺憡懳嵗昗偺嶌惉
		for (int col = 0; col < logicalCenters.length; col++) { //楍丂
			for (int row = 0; row < logicalCenters.length; row++) { //峴
				logicalCenters[row][col] = new Point(logicalSeeds[row], logicalSeeds[col]);
				//System.out.print(logicalCenters[row][col]);
			}
			//System.out.println("");
		}
		return logicalCenters;
		
	}
	
	


	static Point getEdge(boolean[][] image, Point startPoint, int direction) 
			throws AlignmentPatternEdgeNotFoundException {
		int imageWidth = image.length;
		int imageHeight = image[0].length;
		int targetX = startPoint.getX();
		int targetY = startPoint.getY();
		boolean currentElement = QRCodeImageReader.POINT_DARK;
		boolean lastElement = QRCodeImageReader.POINT_DARK;
		int dx = 0;
		int dy = 0;

		if (direction == RIGHT)
			dx = 1;
		else if (direction == BOTTOM)
			dy = 1;
		else if (direction == LEFT)
			dx = -1;
		else if (direction == TOP)
			dy = -1;

		do {
			currentElement = image[targetX][targetY];
			if (lastElement == QRCodeImageReader.POINT_LIGHT && currentElement == QRCodeImageReader.POINT_DARK) //柧揰偐傜埫揰傊堏峴偟偨傜
				return new Point(targetX - dx, targetY - dy); //捈慜偺揰(敀偄巐妏宍偺暎傪曉偡)
			else {
				targetX += dx;
				targetY += dy;
			}
			lastElement = currentElement;
		} while ((targetX >= 0 && targetX < imageWidth) && (targetY >= 0 && targetY < imageHeight));
		
//		if(direction == TOP)
//	    return new Point(targetX, 0);
//		if(direction == BOTTOM)
//	    return new Point(targetX, imageHeight - 1);
//		if(direction == LEFT)
//	    return new Point(0, targetY);
//		else //right
//	    return new Point(imageWidth - 1, targetY);
		throw new AlignmentPatternEdgeNotFoundException();
			
	}
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -