亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
国产成人8x视频一区二区| 日韩女优制服丝袜电影| 欧美精品乱码久久久久久| 亚洲精品在线三区| 日韩国产欧美在线观看| av网站免费线看精品| 久久一区二区三区四区| 亚洲成人免费在线| 91免费观看视频在线| 国产午夜精品美女毛片视频| 午夜精品免费在线| 欧美午夜精品一区| 亚洲视频资源在线| 99精品久久99久久久久| 国产免费久久精品| 国产真实乱对白精彩久久| 91精品国产麻豆| 日韩avvvv在线播放| 欧美亚洲图片小说| 亚洲免费观看高清完整版在线| 国产一区二区精品久久| 欧美一区二区黄色| 视频一区在线播放| 欧美日韩免费电影| 亚洲一区二区欧美激情| 欧美亚洲综合在线| 亚洲一区二区三区中文字幕在线| 97精品电影院| 亚洲精品自拍动漫在线| 91免费看视频| 亚洲男人的天堂在线观看| 97精品久久久午夜一区二区三区| 欧美激情在线一区二区| 成人免费电影视频| 亚洲私人影院在线观看| 91在线视频18| 亚洲午夜激情网页| 6080日韩午夜伦伦午夜伦| 日本亚洲一区二区| 久久综合九色综合欧美亚洲| 国产一区二区三区四| 欧美国产禁国产网站cc| 99天天综合性| 亚洲成人激情自拍| 日韩亚洲欧美一区二区三区| 久久国产精品露脸对白| 国产精品丝袜黑色高跟| 一本大道久久精品懂色aⅴ| 亚洲1区2区3区视频| 91精品国产综合久久国产大片| 强制捆绑调教一区二区| 久久毛片高清国产| av一二三不卡影片| 亚洲va欧美va国产va天堂影院| 91精品国产综合久久久久 | 日韩亚洲电影在线| 精品一区二区三区的国产在线播放 | 久久先锋影音av| 9色porny自拍视频一区二区| 樱花草国产18久久久久| 精品久久久久久久久久久院品网| 成人午夜私人影院| 日韩精品免费视频人成| 国产欧美日韩另类一区| 欧美日韩久久久久久| 国产在线视视频有精品| 亚洲欧美日韩国产综合在线| 91精品久久久久久久91蜜桃| 911精品产国品一二三产区| 精品写真视频在线观看| 一区二区在线免费| 欧美精品一区二区三区蜜桃| 91亚洲国产成人精品一区二区三| 美女国产一区二区| 亚洲一区二区三区影院| 国产精品私人自拍| 精品国产伦一区二区三区观看方式| 成人高清免费在线播放| 青青草原综合久久大伊人精品优势| 国产精品卡一卡二| 欧美v日韩v国产v| 欧美日韩日日摸| 不卡的av电影| 国产一区啦啦啦在线观看| 亚洲自拍都市欧美小说| 国产精品久久福利| 欧美精品一区二区三区蜜臀| 欧美丝袜丝nylons| 成人av电影免费观看| 久久 天天综合| 水蜜桃久久夜色精品一区的特点| 国产精品视频第一区| 日韩免费高清av| 精品视频在线免费观看| 99re热视频这里只精品| 国产精品一区一区三区| 麻豆国产精品官网| 日本免费新一区视频| 亚洲一区二区精品视频| 亚洲四区在线观看| 亚洲丝袜自拍清纯另类| 国产精品久久久久久久久图文区| 久久久久国色av免费看影院| 欧美xxxx在线观看| 2017欧美狠狠色| 精品国产一区二区三区忘忧草 | 99久久99久久免费精品蜜臀| 国产乱一区二区| 国产精品乡下勾搭老头1| 国产呦萝稀缺另类资源| 国产一区高清在线| 国产精品一区专区| 欧美日韩三级一区二区| 欧美日韩中文字幕一区二区| 欧美优质美女网站| 欧美高清dvd| 在线不卡一区二区| 日韩网站在线看片你懂的| 日韩你懂的在线观看| 日韩三级免费观看| 欧美精品一区二区高清在线观看| 精品裸体舞一区二区三区| 久久久久国产一区二区三区四区| 欧美国产一区二区在线观看| 国产精品不卡视频| 亚洲一区二区中文在线| 日韩主播视频在线| 国产在线精品一区二区夜色 | 国产精品女人毛片| 亚洲欧洲性图库| 亚洲成人综合网站| 蜜臀久久99精品久久久画质超高清| 麻豆免费精品视频| 国产成人av影院| 色哟哟在线观看一区二区三区| 在线观看日韩一区| 日韩一区二区在线看| 精品国产免费人成电影在线观看四季| 久久久久久毛片| 中文字幕在线免费不卡| 亚洲国产欧美日韩另类综合 | 一本久久a久久精品亚洲| 欧美日韩黄视频| 26uuu亚洲综合色| 国产精品亲子伦对白| 亚洲一区中文在线| 国产综合成人久久大片91| 精品免费国产一区二区三区四区| 欧美精品一区二区久久婷婷| 亚洲欧美福利一区二区| 免费成人你懂的| 99精品国产热久久91蜜凸| 欧美妇女性影城| 综合自拍亚洲综合图不卡区| 青椒成人免费视频| 97精品电影院| 国产日韩一级二级三级| 亚洲影院久久精品| 成人黄色av电影| 欧美成人性福生活免费看| 亚洲裸体xxx| 国产一区二三区好的| 欧美精品自拍偷拍动漫精品| 国产精品激情偷乱一区二区∴| 性做久久久久久久久| 91色视频在线| 久久久久久99久久久精品网站| 天堂蜜桃一区二区三区| 91一区在线观看| 国产午夜精品一区二区三区四区| 日韩和欧美一区二区| 日本高清不卡一区| 国产精品无圣光一区二区| 日韩av在线免费观看不卡| 91蝌蚪porny| 国产精品女人毛片| 国产高清在线精品| 日韩精品一区二区三区中文不卡| 一区二区三区四区高清精品免费观看| 国产精品一区三区| 欧美电影免费提供在线观看| 亚洲超丰满肉感bbw| 色呦呦日韩精品| 亚洲女女做受ⅹxx高潮| 成人黄色777网| 国产精品视频第一区| 国产精品亚洲午夜一区二区三区 | 欧美精品一区视频| 无吗不卡中文字幕| 欧美日韩不卡视频| 亚洲成a人片在线不卡一二三区| 北条麻妃一区二区三区| 欧美国产欧美亚州国产日韩mv天天看完整 | 欧美一区二区三区免费观看视频| 一区二区欧美视频| 欧美日韩在线免费视频| 亚洲一区二区三区四区在线免费观看| 91在线视频免费观看| 一区二区三区在线免费观看| 一本到一区二区三区|