亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? alignmentpattern.java

?? 日本公司的QR CODE 開發JAVA源代碼
?? 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 {
		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;
						}
					}
				}
			}
		}
		int x, lx, rx, y, uy, dy;
		x = lx = rx = targetPoint.getX();
		y = uy = dy = targetPoint.getY();

		while (!isEdge(image, lx, y, lx - 1, y) && lx >= 0)
			lx--;
		while (!isEdge(image, rx, y, rx + 1, y) && lx < image.length)
			rx++;
		while (!isEdge(image, x, uy, x, uy - 1) && uy >= 0)
			uy--;
		while (!isEdge(image, x, dy, x, dy + 1) && dy < image[0].length)
			dy++;
		
		return new Point((lx + rx + 1) / 2, (uy + dy + 1) / 2);
	}
	static boolean isEdge(boolean[][] image, int x, int y, int nx, int ny) {
		if (image[x][y] == QRCodeImageReader.POINT_LIGHT &&
			image[nx][ny] == QRCodeImageReader.POINT_DARK)
			return true;
		else
			return false;
	}
	
	//奺埵抲崌偣僷僞乕儞偺榑棟嵗昗傪摼傞
	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]);
			}
		}
		return logicalCenters;
		
	}
	
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久精品国产观看| 日本午夜一区二区| 成人av中文字幕| 国产日韩精品一区二区三区 | 欧美理论片在线| 亚洲午夜久久久久久久久电影院| 99久久久国产精品免费蜜臀| 亚洲丝袜另类动漫二区| 91视频免费播放| 亚洲最新在线观看| 在线播放亚洲一区| 久久99国产精品免费| 国产欧美一区二区三区在线老狼| 粉嫩绯色av一区二区在线观看| 亚洲日本在线观看| 在线播放/欧美激情| 久草在线在线精品观看| 久久精品夜色噜噜亚洲a∨| 不卡电影免费在线播放一区| 国内精品第一页| 日本一区二区电影| 一本大道av伊人久久综合| 亚洲成人自拍网| 久久这里只有精品6| proumb性欧美在线观看| 五月婷婷欧美视频| 精品国产凹凸成av人网站| 成人高清在线视频| 午夜电影久久久| 国产午夜三级一区二区三| 欧美最猛性xxxxx直播| 美国精品在线观看| 亚洲欧美另类久久久精品2019| 91麻豆精品国产91久久久 | 亚洲成人激情社区| 久久久精品免费网站| 在线精品视频一区二区| 蜜桃视频一区二区三区在线观看| 国产精品网站导航| 69av一区二区三区| 色激情天天射综合网| 九九九精品视频| 伊人色综合久久天天人手人婷| 日韩精品综合一本久道在线视频| 成人av在线资源网| 久久精品久久综合| 亚洲成人av一区二区| 国产精品视频线看| 欧美一区国产二区| 欧美优质美女网站| 粉嫩av一区二区三区| 青青草97国产精品免费观看无弹窗版| 国产精品久久久爽爽爽麻豆色哟哟| 91精品在线观看入口| 色综合久久久久综合99| 国产91清纯白嫩初高中在线观看| 日韩精品亚洲一区| 一区二区三区**美女毛片| 中文字幕第一区综合| 久久久综合网站| 欧美一级午夜免费电影| 91福利小视频| 97se亚洲国产综合在线| 高清不卡在线观看| 国产一区二区免费看| 蜜桃视频免费观看一区| 亚洲一区在线看| 一区二区高清免费观看影视大全| 另类中文字幕网| 婷婷久久综合九色综合绿巨人 | 99久久伊人久久99| 国产精品69毛片高清亚洲| 久久国产精品99久久久久久老狼| 亚洲成人av中文| 亚洲1区2区3区视频| 一区二区三区四区蜜桃 | 樱桃国产成人精品视频| 中文字幕亚洲区| 国产精品美女久久久久高潮| 欧美国产视频在线| 国产精品久久久久精k8| 国产精品灌醉下药二区| 中文字幕亚洲电影| 亚洲欧美aⅴ...| 亚洲一区在线观看网站| 亚洲成人三级小说| 天天操天天综合网| 久久精品国产亚洲5555| 国内久久婷婷综合| 国产东北露脸精品视频| 成人毛片老司机大片| 福利91精品一区二区三区| 成人综合日日夜夜| 91在线国产福利| 欧美在线999| 日韩无一区二区| 久久综合一区二区| 亚洲特黄一级片| 亚洲一区二区三区小说| 日韩国产欧美视频| 国产一区二区在线免费观看| 国产成人av一区二区三区在线| 99精品久久只有精品| 色婷婷综合在线| 欧美精品99久久久**| 久久午夜老司机| 亚洲欧美日韩在线| 婷婷国产v国产偷v亚洲高清| 欧美日韩成人综合天天影院 | 91精品国产色综合久久不卡蜜臀| 欧美二区三区的天堂| 久久在线观看免费| 国产精品久久久久久久久快鸭| 亚洲精品国产第一综合99久久| 日日噜噜夜夜狠狠视频欧美人 | 亚洲人成影院在线观看| 亚洲精品高清在线| 免费成人深夜小野草| 成人激情免费电影网址| 欧美精品日韩综合在线| 久久久精品免费观看| 亚洲第一电影网| 国产不卡免费视频| 欧美精品亚洲一区二区在线播放| 国产无人区一区二区三区| 亚洲欧美激情小说另类| 蜜桃传媒麻豆第一区在线观看| www.亚洲国产| 欧美成人乱码一区二区三区| 亚洲欧美在线视频观看| 久久精品国产精品亚洲红杏| 91在线精品一区二区| www国产亚洲精品久久麻豆| 亚洲一区在线观看视频| 成人午夜视频在线| 欧美一级欧美三级| 亚洲精品美国一| 国产成人精品免费| 欧美一级二级在线观看| 亚洲一区精品在线| 国产白丝精品91爽爽久久| 在线成人免费视频| 亚洲女人小视频在线观看| 久久国产剧场电影| 91精品婷婷国产综合久久性色| 蜜桃久久精品一区二区| 欧美天堂亚洲电影院在线播放| 亚洲国产精品激情在线观看| 裸体在线国模精品偷拍| 欧美午夜不卡在线观看免费| 国产精品国产三级国产三级人妇| 久久99国产精品久久99果冻传媒| 欧美日韩一区二区三区高清| 中文字幕一区免费在线观看| 国产一区二区久久| 精品捆绑美女sm三区| 人妖欧美一区二区| 在线播放亚洲一区| 天天爽夜夜爽夜夜爽精品视频| 91美女蜜桃在线| 成人免费在线播放视频| 成人开心网精品视频| 久久免费午夜影院| 狠狠色综合日日| 精品久久人人做人人爰| 日韩精品亚洲一区| 91精品麻豆日日躁夜夜躁| 一区二区久久久久久| 日本道色综合久久| 亚洲欧美视频一区| 色88888久久久久久影院野外| 亚洲视频中文字幕| 91美女片黄在线观看91美女| 亚洲欧美日韩国产中文在线| 91香蕉视频污| 夜夜操天天操亚洲| 欧美日韩成人激情| 日韩中文字幕麻豆| 欧美成人video| 久久丁香综合五月国产三级网站 | 久久福利视频一区二区| 精品免费国产一区二区三区四区| 麻豆精品视频在线观看| 欧美精品一区二区高清在线观看| 国产最新精品精品你懂的| 久久久久国产精品厨房| 岛国精品一区二区| 亚洲欧美日本在线| 欧美理论电影在线| 国产在线看一区| 亚洲欧洲无码一区二区三区| 91美女片黄在线观看91美女| 午夜精品福利在线| 久久亚洲精品小早川怜子| 99re成人精品视频| 亚洲国产精品久久人人爱| 亚洲美女在线一区| 欧美美女一区二区三区| 国内精品伊人久久久久av一坑 | 秋霞影院一区二区|