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

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

?? astararray.cpp

?? 路徑探索算法
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
	LARGE_INTEGER tmp1;
	QueryPerformanceCounter(&tmp1);
	
	//
	for(int y=0;y<HEIGHT;y++)
	{
		for(int x=0;x<WIDTH;x++)
		{
			world[(y<<YSHIFT)+x].terrain_cost=vSetup->world[y][x].terrain_cost;
		}
	}
	
	//
	LARGE_INTEGER tmp2;
	QueryPerformanceCounter(&tmp2);
	bigtick.QuadPart += tmp2.QuadPart - tmp1.QuadPart;
}

// this transfers the all the settings in Setup.cpp to here.
void AStarArray::UpdateSettings()
{
	startyx=vSetup->starty*WIDTH+vSetup->startx;
	endyx=vSetup->endy*WIDTH+vSetup->endx;
	
	use_terrain=vSetup->use_terrain;
	distance_method=vSetup->distance_method;
	iterations_per_frame=vSetup->iterations_per_frame;
	directions=vSetup->directions;

	float cost=vSetup->cost;
	float diagonal_cost=vSetup->diagonal_cost;
	float median_terrain_cost=vSetup->median_terrain_cost;
	
	int n;
	if(use_terrain)
	{
		for(n=0;n<4;n++)
		{
			DXY[n].cost_multiplier=median_terrain_cost;
		}
			for(n=4;n<8;n++)
			{
				DXY[n].cost_multiplier=diagonal_cost*median_terrain_cost;
			}
	}
	else
	{
		for(n=0;n<4;n++)
		{
			DXY[n].cost_multiplier=1.0f*cost;
		}
			for(n=4;n<8;n++)
			{
				DXY[n].cost_multiplier=diagonal_cost*cost;
			}
	}
}



///////////////////////////////////////////////////////////////////////////
// TYPE B
void AStarArray::PackRoute()
{
	if(no_path)
	{
		airoute->count=0;
		return;
	}

	//
	memset(airoute->route,0,MAX_ROUTES); //clear routes

	//
	airoute->active=1;
	airoute->compression=0;

	//
	WORD yx=endyx;
	int start=MAX_ROUTES-1;
	BYTE route=NO_ROUTE;
	while(yx!=startyx)
	{
//		route=DXY[world[yx].route].route;
		route=world[yx].route;
		yx+=DXY[DXY[route].route].yx;
		airoute->route[start]=route;
		if(--start<0) start=MAX_ROUTES-1;
	};
	
	airoute->start=start+1;
	airoute->count=MAX_ROUTES-airoute->start;
	
	//
	airoute->startyx=startyx;
	airoute->endyx=endyx;
	
	//
	airoute->walk_point=airoute->start;
	airoute->walk_runlength_step=0;
	
	//     
	if(airoute->start==0) airoute->count=0;
}






///////////////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////////////
/*
This is the function that paints the graphics to the screen.
Called by PathFinder.
Localized to respective Setup classes v1.6.
*/
//
void AStarArray::Paint(LPBYTE pwBits, HDC hdc,HWND hWnd)
{
	if(pwBits)
	{
		//
		RECT rt;
		GetClientRect(hWnd, &rt);
		int clientwidth = (rt.right-rt.left);
		
		COLORREF background;
		COLORREF foreground;
		vSetup->get_colorscheme_colors(background,foreground);
		HBRUSH hbrBkGnd = CreateSolidBrush(background);
		FillRect(hdc, &rt, hbrBkGnd);
		DeleteObject(hbrBkGnd);
		SetBkColor(hdc,background);
		SetTextColor(hdc,foreground);
		
		//
		TCHAR szStatusLine[1024];
		_RGBA *p,*ppush;
		_RGBA  *pbegin=(_RGBA *)pwBits;
		register _RGBA *tmp;
		int yx;
		int y,x;
		int n;
		
		//
		float smallest_f, smallest_g, smallest_h;
		float largest_f, largest_g, largest_h;
		smallest_f = smallest_g = smallest_h = 1048576.0f;
		largest_f = largest_g = largest_h = 0.0001f;
		for(int node=1;node<=last_node;node++)
		{
			if(nodes[node].f>largest_f) largest_f=nodes[node].f;
			if(nodes[node].f<smallest_f) smallest_f=nodes[node].f;
			if(nodes[node].g>largest_g) largest_g=nodes[node].g;
			if(nodes[node].g<smallest_g) smallest_g=nodes[node].g;
			if(nodes[node].h>largest_h) largest_h=nodes[node].h;
			if(nodes[node].h<smallest_h) smallest_h=nodes[node].h;
		}
		
		//
		int count=0;
		int tmpnode=current_node;
		while(tmpnode!=EMPTY_NODE)
		{
			tmpnode=nodes[tmpnode].ancestor;
			count++;
		}
		
		
		// statistics
		GetClientRect(hWnd, &rt);
		sprintf(szStatusLine,
			"-- A* Array (v1) --\nf %f ... %f\ng %f ... %f\nh %f ... %f\n\nNodes %d (MAX %d)\nCurrent Node %d\nLast Open Node %d\nLast Index %d\n\npath found? %s\nlength= %d\n\nstart -> current\nf %f -> %f\ng %f -> %f\nh %f -> %f\n%s\n",
			smallest_f, largest_f,
			smallest_g, largest_g,
			smallest_h, largest_h,
			last_node,
			MAX_NODES,
			current_node,
			open_nodes,
			last_index,
			no_path?"NO PATH!":(path_found?"YES!":"Not yet..."),
			count,
			nodes[1].f,nodes[current_node].f,
			nodes[1].g,nodes[current_node].g,
			nodes[1].h,nodes[current_node].h,
			(nodes[current_node].f<=nodes[1].f)?"ADMISSIBLE":"not admissible"
			);
		DrawText(hdc, szStatusLine, strlen(szStatusLine), &rt, DT_RIGHT);
		
		
		// composite
		GetClientRect(hWnd, &rt);
		rt.top=HEIGHT;
		rt.right=WIDTH;
		sprintf(szStatusLine,"shortest path");
		DrawText(hdc, szStatusLine, strlen(szStatusLine), &rt, DT_CENTER);
		p=ppush=pbegin;
		for(y=0;y<HEIGHT;y++)
		{
			for(x=0;x<WIDTH;x++)
			{
				yx=(y<<YSHIFT)+x;
				BYTE b=(BYTE)(255-(world[yx].terrain_cost<<4));
				p->red=b; p->green=b; p->blue=b;
				p++;
			}
			ppush+=clientwidth;
			p=ppush;
		}
		p=pbegin;
		for(y=-1;y<=1;y++)
		{
			for(x=-1;x<=1;x++)
			{
				tmp=(p+((startyx>>YSHIFT)+y)*clientwidth+(startyx&XMASK)+x);
				tmp->red=255;
				tmp->green=0;
				tmp->blue=0;
			}
		}
		for(y=-1;y<=1;y++)
		{
			for(x=-1;x<=1;x++)
			{
				tmp=(p+((endyx>>YSHIFT)+y)*clientwidth+(endyx&XMASK)+x);
				tmp->red=0;
				tmp->green=255;
				tmp->blue=0;
			}
		}
		p=pbegin;
		node=current_node;
		while(node!=EMPTY_NODE)
		{
			tmp=(p+(nodes[node].yx>>YSHIFT)*clientwidth+(nodes[node].yx&XMASK));
			tmp->red=255;
			tmp->green=0;
			tmp->blue=0;
			node=nodes[node].ancestor;
		}
		
		
		// f
		GetClientRect(hWnd, &rt);
		rt.top=HEIGHT;
		rt.left=WIDTH+4;
		rt.right=WIDTH+4+WIDTH;
		sprintf(szStatusLine,"f (red closed/blue open)");
		DrawText(hdc, szStatusLine, strlen(szStatusLine), &rt, DT_CENTER);
		p=pbegin+WIDTH+4;
		for(n=1;n<=last_node;n++)
		{
			if(nodes[n].open)
			{
				tmp=(p+(nodes[n].yx>>YSHIFT)*clientwidth+(nodes[n].yx&XMASK));
				BYTE f=(BYTE)(((float)nodes[n].f/(float)largest_f)*255.0f);
				tmp->red=0;
				tmp->green=0;
				tmp->blue=f;
			}
		}
		for(n=1;n<=last_node;n++)
		{
			if(!nodes[n].open)
			{
				tmp=(p+(nodes[n].yx>>YSHIFT)*clientwidth+(nodes[n].yx&XMASK));
				BYTE f=(BYTE)(((float)nodes[n].f/(float)largest_f)*255.0f);
				tmp->red=f;
				tmp->green=0;
				tmp->blue=0;
			}
		}
		
		
		// open
		GetClientRect(hWnd, &rt);
		rt.top=HEIGHT*2+16;
		rt.left=0;
		rt.right=WIDTH;
		sprintf(szStatusLine,"open nodes %d",open_nodes);
		DrawText(hdc, szStatusLine, strlen(szStatusLine), &rt, DT_CENTER);
		p=pbegin+(HEIGHT+16)*clientwidth;
		for(n=1;n<=last_node;n++)
		{
			if(nodes[n].open)
			{
				BYTE g=(BYTE)(((float)nodes[n].g/(float)largest_g)*255.0f);
				BYTE h=(BYTE)(((float)nodes[n].h/(float)largest_h)*255.0f);
				BYTE f=(BYTE)(((float)nodes[n].f/(float)largest_f)*255.0f);
				tmp=(p+(nodes[n].yx>>YSHIFT)*clientwidth+(nodes[n].yx&XMASK));
				tmp->red=h;
				tmp->green=g;
				tmp->blue=f;
			}
		}
		
		
		// closed
		GetClientRect(hWnd, &rt);
		rt.top=HEIGHT*2+16;
		rt.left=WIDTH+4;
		rt.right=WIDTH+4+WIDTH;
		sprintf(szStatusLine,"closed nodes %d",closed_nodes);
		DrawText(hdc, szStatusLine, strlen(szStatusLine), &rt, DT_CENTER);
		p=pbegin+WIDTH+4+(HEIGHT+16)*clientwidth;
		for(n=1;n<=last_node;n++)
		{
			if(!nodes[n].open)
			{
				BYTE g=(BYTE)(((float)nodes[n].g/(float)largest_g)*255.0f);
				BYTE h=(BYTE)(((float)nodes[n].h/(float)largest_h)*255.0f);
				BYTE f=(BYTE)(((float)nodes[n].f/(float)largest_f)*255.0f);
				tmp=(p+(nodes[n].yx>>YSHIFT)*clientwidth+(nodes[n].yx&XMASK));
				tmp->red=h;
				tmp->green=g;
				tmp->blue=f;
			}
		}
		
	
		// successors
		GetClientRect(hWnd, &rt);
		rt.top=HEIGHT*2+16;
		rt.left=(WIDTH+4)*2;
		rt.right=(WIDTH+4)*2+WIDTH;
		sprintf(szStatusLine,"successors");
		DrawText(hdc, szStatusLine, strlen(szStatusLine), &rt, DT_CENTER);
		p=pbegin+(WIDTH+4)*2+(HEIGHT+16)*clientwidth;
		int diff=(directions==8)?31:63;
		for(node=1;node<=last_node;node++)
		{
			int successors=0;
			for(int i=0;i<directions;i++)
			{
				if(nodes[node].successor[i]!=EMPTY_NODE)
					successors+=diff;
			}
			tmp=(p+(nodes[node].yx>>YSHIFT)*clientwidth+(nodes[node].yx&XMASK));
			tmp->red=(BYTE)successors;
			tmp->green=0;
			tmp->blue=0;
		}
	}
	
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本成人在线不卡视频| 国产综合色视频| 视频一区免费在线观看| 天天综合网天天综合色| 国产欧美一区二区三区网站| 国产精品免费丝袜| 最新国产の精品合集bt伙计| 亚洲精品视频在线看| 亚洲在线视频网站| 亚洲午夜电影在线观看| 日本欧美肥老太交大片| 高清视频一区二区| 色婷婷精品久久二区二区蜜臂av | 中文字幕制服丝袜成人av| 国产欧美日韩在线| 亚洲电影视频在线| 激情综合色综合久久| 91在线无精精品入口| 91麻豆精品国产91久久久使用方法| 久久综合999| 一级特黄大欧美久久久| 精品一区二区久久| 色94色欧美sute亚洲线路一ni| 欧美一二区视频| 国产精品色在线观看| 蜜桃视频一区二区三区在线观看| 成人动漫中文字幕| 欧美一区二区三区不卡| 久久久99久久精品欧美| 婷婷国产在线综合| 99久久精品99国产精品| 欧美精品一区二区三区视频| 夜夜精品视频一区二区 | 中文字幕中文字幕中文字幕亚洲无线| 一区二区成人在线视频| 成人动漫av在线| 久久一区二区视频| 青青草精品视频| 在线国产电影不卡| 日韩毛片精品高清免费| 国产激情偷乱视频一区二区三区| 欧美亚洲一区三区| 国产精品久久久久久妇女6080| 韩国精品主播一区二区在线观看| 欧美精品久久99| 亚洲一区二区三区精品在线| 99re8在线精品视频免费播放| 久久综合九色综合97婷婷女人 | 激情国产一区二区 | 欧美性大战xxxxx久久久| xnxx国产精品| 亚洲国产aⅴ成人精品无吗| 国产乱码精品一区二区三区五月婷| 91福利精品第一导航| 亚洲丝袜另类动漫二区| 国产一区二区三区电影在线观看| 欧美日韩亚洲综合| 亚洲一区在线观看免费| av一区二区不卡| 国产精品欧美经典| 99视频一区二区三区| 亚洲视频在线观看三级| 91小视频免费观看| 一区二区欧美精品| 日本道免费精品一区二区三区| 亚洲人精品午夜| 在线看日韩精品电影| 亚洲综合久久av| 欧美日韩一级片网站| 免费在线观看成人| 亚洲精品一线二线三线无人区| 黄色日韩三级电影| 国产欧美综合在线| 成年人网站91| 亚洲一区二区精品久久av| 欧美日本乱大交xxxxx| 天天色图综合网| 欧美精品一二三| 久久国产精品99精品国产 | 99久久久久久| 一区二区三区四区高清精品免费观看| 在线观看成人免费视频| 奇米精品一区二区三区四区| 精品日韩一区二区三区免费视频| 国产成人精品免费| 一区二区欧美精品| 久久综合999| 91久久精品网| 日韩va亚洲va欧美va久久| 精品国产一区二区三区不卡 | 国产福利一区在线| 亚洲黄色小视频| 69久久99精品久久久久婷婷 | 欧美一级高清片| 激情综合色播五月| 亚洲日本在线观看| 制服丝袜在线91| 国产成人精品免费一区二区| 亚洲综合在线第一页| 日韩三级在线免费观看| 成人激情校园春色| 午夜久久久影院| 国产视频一区二区三区在线观看| 欧美在线观看视频一区二区三区| 久草热8精品视频在线观看| 亚洲欧美综合色| 精品久久久久99| 欧美视频第二页| www.成人在线| 国产一区二区三区四区五区美女 | 韩国精品久久久| 亚洲电影一级片| 国产校园另类小说区| 99久久综合色| 国产视频911| 91精品福利在线一区二区三区 | 中文字幕日韩欧美一区二区三区| 欧美在线综合视频| 成人丝袜高跟foot| 久久成人久久爱| 亚洲国产精品久久不卡毛片 | 欧美国产国产综合| 欧美一区二区三区免费视频| 日韩欧美高清dvd碟片| 884aa四虎影成人精品一区| 日本精品免费观看高清观看| 成人av片在线观看| 成人avav影音| zzijzzij亚洲日本少妇熟睡| 成人av网站在线观看免费| 成人sese在线| 国产在线视频一区二区| aa级大片欧美| 色伊人久久综合中文字幕| www.66久久| 色噜噜狠狠色综合中国| 国模一区二区三区白浆| 菠萝蜜视频在线观看一区| 国产精品1区2区3区| 成人高清免费在线播放| 成人精品国产一区二区4080| a级精品国产片在线观看| 欧美系列在线观看| 欧美日韩视频在线第一区| 欧美日韩免费观看一区二区三区| 欧美吻胸吃奶大尺度电影| 91精品婷婷国产综合久久| 欧美成人一级视频| 国产三级欧美三级日产三级99| 久久久综合激的五月天| 国产精品网曝门| 亚洲精品国久久99热| 久久国产精品色婷婷| 高清国产午夜精品久久久久久| 国产99久久精品| 色香色香欲天天天影视综合网| 粉嫩av亚洲一区二区图片| 精品视频一区二区不卡| 日韩欧美中文字幕公布| 欧美精品一区二区三区一线天视频| 久久影院电视剧免费观看| 一区免费观看视频| 美腿丝袜亚洲综合| 高清在线不卡av| 欧美精品久久99久久在免费线 | 亚洲一区二区三区中文字幕在线| 午夜日韩在线观看| 国产一区二区不卡| 粉嫩绯色av一区二区在线观看| 欧美军同video69gay| 国产性色一区二区| 亚洲成人激情自拍| 国产精品综合二区| 欧美精品在线一区二区三区| 久久久久久免费| 亚洲第一搞黄网站| 成人精品小蝌蚪| 在线电影一区二区三区| 亚洲同性gay激情无套| 久久99日本精品| 欧美性猛片xxxx免费看久爱| 久久久久国产精品厨房| 曰韩精品一区二区| 成人自拍视频在线观看| 欧美日韩精品三区| 国产精品激情偷乱一区二区∴| 日韩高清不卡一区| 不卡av在线网| 国产精品久久福利| 国产呦萝稀缺另类资源| 欧美日韩中文另类| 中文字幕一区二区三| 久久精品国产亚洲高清剧情介绍| 不卡av在线免费观看| 精品99999| 美女任你摸久久| 色偷偷88欧美精品久久久| 中文字幕在线观看不卡| 激情综合网天天干| 日韩写真欧美这视频|