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

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

?? map.java

?? Java源代碼-主要用于瀏覽器聊天工具端口掃描
?? JAVA
字號:
package kyodai.map;

import java.awt.Point;
import java.util.Random;
import java.util.Vector;

/**
 * 生成連連看方塊的類
*/
public class Map{

	private int level;
	private int map[][];
	int array[];
	private int restBlock;
	private Vector vector;
	AnimateDelete animate;
	private boolean test;

	public Map(){
		level = 28;
		map = new int[10][17];
		array = new int[170];
		restBlock = level * 4;
		vector = new Vector();
		test = false;
		initMap();
	}

	public Map(int level){
		this.level = 28;
		map = new int[10][17];
		array = new int[170];
		restBlock = this.level * 4;
		vector = new Vector();
		test = false;
		this.level = level;
		restBlock = level * 4;
		initMap();
	}

	public void setTest(boolean test){
		this.test = test;
	}

	public void setLevel(int level){
		this.level = level;
		restBlock = level * 4;
		initMap();
	}

	private void initMap(){
		for(int i = 0; i < level; i++){
			array[i * 4] = i + 1;
			array[i * 4 + 1] = i + 1;
			array[i * 4 + 2] = i + 1;
			array[i * 4 + 3] = i + 1;
		}

		random(array);
		for(int i = 0; i < 10; i++){
			for(int j = 0; j < 17; j++)
				map[i][j] = array[i * 17 + j];

		}

	}

	private void random(int array[]){
		Random random = new Random();
		for(int i = array.length; i > 0; i--){
			int j = random.nextInt(i);
			int temp = array[j];
			array[j] = array[i - 1];
			array[i - 1] = temp;
		}

	}

	public void earse(Point a, Point b){
		map[a.x][a.y] = 0;
		map[b.x][b.y] = 0;
		restBlock -= 2;
	}

	public int getCount(){
		return restBlock <= 0 ? 0 : restBlock;
	}

	public void refresh(){
		int count = getCount();
		if(count <= 0)
			return;
		int temp[] = new int[count];
		count = 0;
		for(int row = 0; row < 10; row++){
			for(int col = 0; col < 17; col++)
				if(map[row][col] > 0){
					temp[count] = map[row][col];
					count++;
				}

		}

		random(temp);
		count = 0;
		for(int row = 0; row < 10; row++){
			for(int col = 0; col < 17; col++)
				if(map[row][col] > 0){
					map[row][col] = temp[count];
					count++;
				}

		}

	}

	private boolean horizon(Point a, Point b, boolean recorder){
		if(a.x == b.x && a.y == b.y)
			return false;
		int x_start = a.y <= b.y ? a.y : b.y;
		int x_end = a.y <= b.y ? b.y : a.y;
		for(int x = x_start + 1; x < x_end; x++)
			if(map[a.x][x] != 0)
				return false;

		if(!test && recorder)
			animate = new AnimateDelete(1, a, b);
		return true;
	}

	private boolean vertical(Point a, Point b, boolean recorder){
		if(a.x == b.x && a.y == b.y)
			return false;
		int y_start = a.x <= b.x ? a.x : b.x;
		int y_end = a.x <= b.x ? b.x : a.x;
		for(int y = y_start + 1; y < y_end; y++)
			if(map[y][a.y] != 0)
				return false;

		if(!test && recorder)
			animate = new AnimateDelete(0, a, b);
		return true;
	}

	private boolean oneCorner(Point a, Point b){
		Point c = new Point(a.x, b.y);
		Point d = new Point(b.x, a.y);
		if(map[c.x][c.y] == 0){
			boolean method1 = horizon(a, c, false) && vertical(b, c, false);
			if(method1){
				if(!test)
					animate = new AnimateDelete(1, a, c, b);
				return method1;
			}
		}
		if(map[d.x][d.y] == 0){
			boolean method2 = vertical(a, d, false) && horizon(b, d, false);
			if(method2 && !test)
				animate = new AnimateDelete(0, a, d, b);
			return method2;
		} 
		else{
			return false;
		}
	}

	private Vector scan(Point a, Point b){
		Vector v = new Vector();
		Point c = new Point(a.x, b.y);
		Point d = new Point(b.x, a.y);
		for(int y = a.y; y >= 0; y--)
			if(map[a.x][y] == 0 && map[b.x][y] == 0 && vertical(new Point(a.x, y), new Point(b.x, y), false))
				v.add(new Line(0, new Point(a.x, y), new Point(b.x, y)));

		for(int y = a.y; y < 17; y++)
			if(map[a.x][y] == 0 && map[b.x][y] == 0 && vertical(new Point(a.x, y), new Point(b.x, y), false))
				v.add(new Line(0, new Point(a.x, y), new Point(b.x, y)));

		for(int x = a.x; x >= 0; x--)
			if(map[x][a.y] == 0 && map[x][b.y] == 0 && horizon(new Point(x, a.y), new Point(x, b.y), false))
				v.add(new Line(1, new Point(x, a.y), new Point(x, b.y)));

		for(int x = a.x; x < 10; x++)
			if(map[x][a.y] == 0 && map[x][b.y] == 0 && horizon(new Point(x, a.y), new Point(x, b.y), false))
				v.add(new Line(1, new Point(x, a.y), new Point(x, b.y)));

		return v;
	}

	private boolean twoCorner(Point a, Point b){
		vector = scan(a, b);
		if(vector.isEmpty())
			return false;
		for(int index = 0; index < vector.size(); index++){
			Line line = (Line)vector.elementAt(index);
			if(line.direct == 1){
				if(vertical(a, line.a, false) && vertical(b, line.b, false)){
					if(!test)
						animate = new AnimateDelete(0, a, line.a, line.b, b);
					return true;
				}
			} 
			else if(horizon(a, line.a, false) && horizon(b, line.b, false)){
				if(!test)
					animate = new AnimateDelete(1, a, line.a, line.b, b);
				return true;
			}
		}

		return false;
	}

	public boolean test(Point a, Point b){
		if(map[a.x][a.y] != map[b.x][b.y])
			return false;
		if(a.x == b.x && horizon(a, b, true))
			return true;
		if(a.y == b.y && vertical(a, b, true))
			return true;
		if(oneCorner(a, b))
			return true;
		else
			return twoCorner(a, b);
	}

	public Line findNext(Point a){
		Point b = new Point();
		a = findFirst(a);
		if(a.equals(new Point(-1, -1)))
			return new Line(0, a, b);
		for(; !a.equals(new Point(-1, -1)); a = findFirst(a))
			for(b = findSecond(a, b); !b.equals(new Point(-1, -1)); b = findSecond(a, b))
				if(test(a, b))
					return new Line(1, a, b);


		return new Line(0, a, b);
	}

	private Point findFirst(Point a){
		int offset = 0;
		if(a != null)
			offset = a.x * 17 + a.y;
		if(offset < 0)
			offset = -1;
		for(int x = offset + 1; x < 170; x++){
			int row = Math.round(x / 17);
			int col = x - row * 17;
			if(map[row][col] != 0)
				return new Point(row, col);
		}

		return new Point(-1, -1);
	}

	private Point findSecond(Point a, Point b){
		if(a == null)
			return new Point(-1, -1);
		if(a.x + a.y < 0)
			return new Point(-1, -1);
		if(b == null)
			b = new Point(0, 0);
		int offset = Math.max(a.x * 17 + a.y, b.x * 17 + b.y);
		for(int x = offset + 1; x < 170; x++){
			int row = Math.round(x / 17);
			int col = x - row * 17;
			if(map[row][col] == map[a.x][a.y])
				return new Point(row, col);
		}

		return new Point(-1, -1);
	}

	public int[][] getMap(){
		return map;
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区在线观看视频| 国产精品少妇自拍| 东方欧美亚洲色图在线| 亚洲成人动漫av| 亚洲色图第一区| 精品成人免费观看| 欧美丰满高潮xxxx喷水动漫| 成人免费视频一区| 免费在线观看视频一区| 亚洲一区二区三区中文字幕| 成人免费在线观看入口| 久久久噜噜噜久久中文字幕色伊伊| 欧美精品一二三四| 色综合色狠狠综合色| 国产成人小视频| 麻豆精品视频在线观看免费| 亚洲一二三区不卡| 成人免费在线视频| 国产精品女同互慰在线看| 国产亚洲成av人在线观看导航| 欧美一区二区日韩一区二区| 欧美色爱综合网| 色综合色综合色综合| av亚洲精华国产精华精华 | 裸体健美xxxx欧美裸体表演| 亚洲精品中文在线影院| 国产精品传媒入口麻豆| 国产人成一区二区三区影院| 欧美电影免费提供在线观看| 日韩一级片网址| 欧美精品1区2区| 欧美精品一二三| 欧美日韩国产综合视频在线观看| 在线免费观看成人短视频| 一区二区三区不卡视频在线观看| 欧美日韩一二三| 欧美四级电影在线观看| 欧美专区日韩专区| 色婷婷久久久亚洲一区二区三区| caoporn国产一区二区| 成人综合在线观看| 成人av网站免费| 99久久亚洲一区二区三区青草| 国产高清精品在线| 不卡av免费在线观看| 99v久久综合狠狠综合久久| 波多野结衣视频一区| 波多野结衣在线一区| 91香蕉视频mp4| 91福利在线免费观看| 欧美在线你懂得| 欧美精选午夜久久久乱码6080| 制服丝袜激情欧洲亚洲| 精品欧美久久久| 国产亚洲成aⅴ人片在线观看| 国产精品嫩草久久久久| 樱桃国产成人精品视频| 日本中文字幕一区二区视频 | 午夜精品久久久久久久99樱桃| 亚洲一区二区在线免费观看视频| 日韩中文字幕区一区有砖一区| 日本伊人午夜精品| 国产乱码精品一区二区三| 国产超碰在线一区| 91福利国产精品| 日韩三级av在线播放| 久久久激情视频| 亚洲乱码国产乱码精品精小说 | 日韩欧美电影一二三| 精品免费99久久| 日本一区二区三区高清不卡| 一区二区三区av电影| 麻豆精品久久精品色综合| 粉嫩av一区二区三区在线播放| 91捆绑美女网站| 日韩三级精品电影久久久 | 69堂成人精品免费视频| 2020国产精品自拍| 亚洲卡通动漫在线| 美国毛片一区二区三区| 91污片在线观看| 欧美一区二区三区在线观看视频| 国产精品日韩精品欧美在线| 亚洲一区二区欧美日韩| 国产成人高清在线| 这里只有精品电影| 国产精品久久久久久久岛一牛影视| 亚洲超碰97人人做人人爱| 国产精品1024| 欧美一级高清大全免费观看| 国产欧美日韩精品在线| 日韩国产欧美视频| av一本久道久久综合久久鬼色| 欧美videofree性高清杂交| 亚洲色图19p| 国产精品一区二区你懂的| 欧美性猛片xxxx免费看久爱| 久久精品欧美日韩| 全国精品久久少妇| 精品视频全国免费看| 中文字幕欧美激情| 国产一区日韩二区欧美三区| 制服丝袜在线91| 亚洲午夜在线视频| 国产精品国产三级国产a| 国产精品毛片a∨一区二区三区| 亚洲小少妇裸体bbw| av成人老司机| 久久免费看少妇高潮| 日韩国产成人精品| 在线视频一区二区免费| 国产精品久久久久永久免费观看 | 国产超碰在线一区| 欧美精品丝袜久久久中文字幕| 最新高清无码专区| 国产成a人无v码亚洲福利| 欧美大肚乱孕交hd孕妇| 亚洲超碰97人人做人人爱| 99精品欧美一区| 综合久久久久久久| 国产v综合v亚洲欧| 精品三级在线看| 日本欧美一区二区三区| 91精品欧美福利在线观看| 亚洲图片欧美视频| 91成人看片片| 一区二区三区不卡视频| 91激情在线视频| 亚洲综合一区二区三区| 色欧美片视频在线观看| 亚洲精品乱码久久久久| 91年精品国产| 亚洲精品视频免费看| 日本精品一区二区三区四区的功能| 日韩一区在线播放| 色综合久久综合| 亚洲男同性视频| 日本电影欧美片| 亚洲动漫第一页| 91精品国产色综合久久ai换脸| 日本午夜一本久久久综合| 91精品国产入口| 狠狠色狠狠色合久久伊人| 久久久夜色精品亚洲| 大胆亚洲人体视频| 又紧又大又爽精品一区二区| 欧美在线短视频| 奇米精品一区二区三区四区| 欧美videos大乳护士334| 丁香五精品蜜臀久久久久99网站| 国产精品国产三级国产a| 日本福利一区二区| 欧美96一区二区免费视频| 久久久久国产精品人| 成人午夜精品一区二区三区| 亚洲啪啪综合av一区二区三区| 日本韩国一区二区三区| 水野朝阳av一区二区三区| 精品久久久久久久久久久久包黑料| 狠狠狠色丁香婷婷综合激情| 国产欧美精品一区aⅴ影院| av电影在线观看完整版一区二区| 亚洲精品国产视频| 日韩视频不卡中文| gogo大胆日本视频一区| 亚洲成人高清在线| 国产情人综合久久777777| 色av成人天堂桃色av| 奇米四色…亚洲| 久久精品欧美一区二区三区麻豆| 91久久国产综合久久| 久久se精品一区精品二区| 亚洲欧洲精品一区二区三区| 欧美另类videos死尸| 国产黑丝在线一区二区三区| 亚洲综合自拍偷拍| 久久综合九色综合欧美98| 91黄色在线观看| 国产一区二区三区免费观看| 一区二区在线观看不卡| 国产精品三级av| |精品福利一区二区三区| 91麻豆精品国产91久久久使用方法| 国产精品一区二区x88av| 亚洲国产精品久久人人爱蜜臀| 欧美变态tickle挠乳网站| 一本色道久久综合亚洲91| 精品一区二区免费看| 亚洲品质自拍视频网站| 精品国产欧美一区二区| 欧洲一区二区av| 国产iv一区二区三区| 亚洲妇女屁股眼交7| 国产精品免费网站在线观看| 91精品国产色综合久久不卡电影| 91在线观看污| 国产91精品免费| 久久精品噜噜噜成人88aⅴ| 一区二区免费视频| 国产精品乱码一区二区三区软件|