亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
极品少妇一区二区| 亚洲电影中文字幕在线观看| 激情欧美日韩一区二区| 欧美一卡2卡3卡4卡| 日韩激情一区二区| 91麻豆精品国产自产在线| 亚洲午夜日本在线观看| 欧美性色欧美a在线播放| 亚洲视频在线观看三级| 91网站最新网址| 日韩伦理av电影| 91免费国产在线观看| 亚洲综合成人在线| 欧美一区二区大片| 国产乱码精品一区二区三| 国产人成亚洲第一网站在线播放 | 国产精品久久久久影院| 国产成人亚洲精品狼色在线| 国产精品家庭影院| 欧美图区在线视频| 麻豆精品久久精品色综合| 国产偷v国产偷v亚洲高清| 国产成人免费视| 中文字幕亚洲成人| 欧美日韩国产美女| 麻豆一区二区在线| 日本一区二区三级电影在线观看| 99久久精品国产一区二区三区| 亚洲图片一区二区| 亚洲精品在线观看视频| 成人av在线影院| 午夜国产精品一区| 精品成人在线观看| 99久久精品一区| 亚洲成a人v欧美综合天堂下载| 日韩欧美一区二区久久婷婷| av影院午夜一区| 蜜臀av性久久久久蜜臀aⅴ | 亚洲女子a中天字幕| 欧美另类z0zxhd电影| 国产乱子伦一区二区三区国色天香| 国产精品麻豆一区二区| 91精品国产日韩91久久久久久| 成人av在线播放网站| 秋霞成人午夜伦在线观看| 国产精品情趣视频| 欧美中文字幕一区二区三区亚洲| 国产一区啦啦啦在线观看| 亚洲综合视频网| 中文字幕巨乱亚洲| 欧美一卡二卡三卡四卡| 在线精品视频一区二区三四| 国产激情视频一区二区三区欧美| 亚洲成a人v欧美综合天堂下载| 久久久亚洲午夜电影| 欧美一区二区三区四区高清| av色综合久久天堂av综合| 日日嗨av一区二区三区四区| 亚洲乱码一区二区三区在线观看| 久久久久久免费毛片精品| 欧美日韩三级视频| 99re成人精品视频| 国产美女视频一区| 久久激情五月激情| 午夜a成v人精品| 亚洲精品ww久久久久久p站| 国产免费久久精品| 精品美女在线播放| 91精品国产综合久久精品| 色婷婷久久一区二区三区麻豆| 国产一区二区三区美女| 六月丁香综合在线视频| 视频一区二区三区入口| 亚洲综合在线第一页| 亚洲精品综合在线| 国产精品乱码一区二区三区软件| 久久九九影视网| 日韩一区二区三区视频在线 | 青草国产精品久久久久久| 亚洲午夜久久久| 亚洲一区二区三区四区在线| 国产精品久久久久久久岛一牛影视| 久久综合久久鬼色| 久久久久青草大香线综合精品| 日韩欧美一区二区三区在线| 欧美tickle裸体挠脚心vk| 777午夜精品免费视频| 欧美精品 国产精品| 91久久国产最好的精华液| 色综合中文字幕国产| 国产91精品一区二区麻豆网站| 国产精品香蕉一区二区三区| 成人自拍视频在线| 成人黄色一级视频| yourporn久久国产精品| 色久优优欧美色久优优| 色哦色哦哦色天天综合| 欧美三级韩国三级日本三斤| 在线播放91灌醉迷j高跟美女| 日韩视频中午一区| 亚洲精品在线观看视频| 精品久久一二三区| 国产精品色呦呦| 亚洲视频图片小说| 亚洲va韩国va欧美va精品| 日韩电影在线免费观看| 青椒成人免费视频| 狠狠色综合色综合网络| 大胆欧美人体老妇| 在线观看欧美精品| 日韩欧美国产精品一区| 国产精品沙发午睡系列990531| 亚洲色图19p| 日韩成人免费在线| 国产在线精品一区二区| 不卡视频一二三| 67194成人在线观看| 国产网站一区二区| 亚洲欧洲中文日韩久久av乱码| 亚洲第一福利视频在线| 看电视剧不卡顿的网站| 成人免费毛片aaaaa**| 欧美天堂一区二区三区| 欧美成人福利视频| 国产精品毛片久久久久久久| 亚洲成a人v欧美综合天堂| 国产一区中文字幕| 欧美在线影院一区二区| 日韩一二三区视频| 国产精品亲子伦对白| 亚洲一区二区影院| 国产一区二区三区四区五区美女 | 国产精品99久久久久久宅男| 在线观看区一区二| 国产欧美日韩另类一区| 日韩av电影一区| av亚洲精华国产精华精华| 精品视频在线免费| 国产精品三级久久久久三级| 日日夜夜免费精品| 91在线精品一区二区三区| 日韩精品一区二区三区在线| 亚洲色图19p| 国产成都精品91一区二区三| 欧美精品在线观看播放| 亚洲美女偷拍久久| 国产精品91一区二区| 91精品黄色片免费大全| 最新国产成人在线观看| 国产在线视视频有精品| 欧美色窝79yyyycom| 国产日本亚洲高清| 久久er99精品| 51久久夜色精品国产麻豆| 亚洲狠狠丁香婷婷综合久久久| 国产精品一级片在线观看| 欧美久久一二三四区| 亚洲欧美国产高清| 福利一区在线观看| 91精品国产综合久久香蕉的特点| 一区二区理论电影在线观看| 成人av影院在线| 国产香蕉久久精品综合网| 免费人成精品欧美精品| 欧美无砖专区一中文字| 亚洲精品中文字幕在线观看| 成人午夜视频福利| 久久久久久久久免费| 狠狠色狠狠色综合| 精品剧情v国产在线观看在线| 美女视频第一区二区三区免费观看网站| 一本色道久久综合亚洲aⅴ蜜桃| 国产精品精品国产色婷婷| 91传媒视频在线播放| 国产91丝袜在线18| 欧美亚洲综合一区| 精品国产伦一区二区三区免费 | 亚洲精品写真福利| 99re在线精品| 18欧美乱大交hd1984| 成人av动漫网站| 国产精品国产三级国产aⅴ入口| 成人avav影音| 中文字幕日韩欧美一区二区三区| av在线不卡电影| 自拍偷拍欧美精品| 91麻豆蜜桃一区二区三区| 亚洲精品乱码久久久久久久久| 日本韩国欧美一区| 日一区二区三区| 欧美一级黄色录像| 久久成人18免费观看| 久久免费看少妇高潮| 国产91精品欧美| 最新不卡av在线| 91福利视频网站| 日本免费新一区视频| 欧美精品一区二区三| 大白屁股一区二区视频| 国产精品国产三级国产aⅴ入口|