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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? 5.txt

?? 坦克大戰(zhàn)源代碼以及原理
?? TXT
字號(hào):
// Plane.cpp: implementation of the CPlane class.
//
//////////////////////////////////////////////////////////////////////

#include <stdio.h>
#include "Plane.h"
#include "Sprite.h"

#define OFFSETX		100
#define OFFSETY		48


//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

CPlane::CPlane()
{
	m_bRiver1 = TRUE;
	m_time = 0;
	m_bProtected = FALSE;
}

CPlane::~CPlane()
{

}


BOOL CPlane::Create( char* filename )
{
	FILE* fp = fopen( filename, "rb" );
	if( !fp )
		return FALSE;

	for( int i = 0; i < PLANE_H; i ++ )
		for( int j = 0; j < PLANE_W; j ++ )
		{
			m_map[i][j].obj = (BYTE)fgetc( fp );
			m_map[i][j].obj --;
			m_map[i][j].mask = 0xffff;
			if( m_map[i][j].obj == OBJ_BRICK ||
				m_map[i][j].obj == OBJ_CONCRETE )
			{
				switch( (BYTE)fgetc( fp ) )
				{
				case 0:
					m_map[i][j].mask = 0xff00;
					break;
				case 1:
					m_map[i][j].mask = 0x00ff;
					break;
				case 2:
					m_map[i][j].mask = 0xcccc;
					break;
				case 3:
					m_map[i][j].mask = 0x3333;
					break;
				}
			}
			else if( m_map[i][j].obj == OBJ_NULL )
				m_map[i][j].mask = 0;
		}

	fclose( fp );
	
	Unprotect();
	return TRUE;
}


int CPlane::HitSurface( CBullet& bullet, BOOL bDestroyConcrete )
{
	int x = (int)bullet.m_x + bullet.m_width/2;
	int y = (int)bullet.m_y + bullet.m_height/2;
	int row = y / TILE_H;
	int col = x / TILE_W;

	int shift;
	WORD mask, flag;
	int hit = OBJ_NULL;
	
	switch( bullet.m_dir )
	{
	case DIR_UP:
	case DIR_DOWN:
		if( !bDestroyConcrete )
			shift = (3 - (y - row*TILE_H) / 8) * 4;
		else
			shift = (1 - (y - row*TILE_H) / 16) * 8;
		
		if( x % TILE_W )
		{
			if( !bDestroyConcrete )
				flag = 0xf << shift;
			else
				flag = 0xff << shift;
			if( m_map[row][col].mask & flag )
			{
				hit = m_map[row][col].obj;
				if( CanDestroy(row, col, bDestroyConcrete) )
					m_map[row][col].mask &= ~flag;
			}
		}
		else
		{
			if( !bDestroyConcrete )
				flag = 0xc << shift;
			else
				flag = 0xcc << shift;
			if( m_map[row][col].mask & flag )
			{
				hit = m_map[row][col].obj;
				if( CanDestroy(row, col, bDestroyConcrete) )
					m_map[row][col].mask &= ~flag;
			}

			if( !bDestroyConcrete )
				flag = 0x3 << shift;
			else
				flag = 0x33 << shift;
			if( col >= 1 && m_map[row][col-1].mask & flag )
			{
				if( !CanHit( hit ) )
					hit = m_map[row][col-1].obj;
				if( CanDestroy(row, col-1, bDestroyConcrete) )
					m_map[row][col-1].mask &= ~flag;
			}
		}
		if( col >= 1 && m_map[row][col-1].mask == 0 )
			m_map[row][col-1].obj = OBJ_NULL;
		break;

	case DIR_LEFT:
	case DIR_RIGHT:
		if( !bDestroyConcrete )
			shift = (x - col*TILE_W) / 8;
		else
			shift = (x - col*TILE_W) / 16;
		if( y % TILE_H )
		{
			if( !bDestroyConcrete )
			{
				if( shift == 0 )
					mask = 0x8888;
				else if( shift == 1 )
					mask = 0x4444;
				else if( shift == 2 )
					mask = 0x2222;
				else
					mask = 0x1111;
			}
			else
			{
				if( shift == 0 )
					mask = 0xcccc;
				else
					mask = 0x3333;
			}
			if( m_map[row][col].mask & mask )
			{
				hit = m_map[row][col].obj;
				if( CanDestroy(row, col, bDestroyConcrete) )
					m_map[row][col].mask &= ~mask;
			}
		}
		else
		{
			if( !bDestroyConcrete )
			{
				if( shift == 0 )
					mask = 0x8800;
				else if( shift == 1 )
					mask = 0x4400;
				else if( shift == 2 )
					mask = 0x2200;
				else
					mask = 0x1100;
			}
			else
			{
				if( shift == 0 )
					mask = 0xcc00;
				else
					mask = 0x3300;
			}
			if( m_map[row][col].mask & mask )
			{
				hit = m_map[row][col].obj;
				if( CanDestroy(row, col, bDestroyConcrete) )
					m_map[row][col].mask &= ~mask;
			}
			mask >>= 8;

			if( row >= 1 && m_map[row-1][col].mask & mask )
			{
				if( !CanHit( hit ) )
					hit = m_map[row-1][col].obj;
				if( CanDestroy(row-1, col, bDestroyConcrete) )
					m_map[row-1][col].mask &= ~mask;
			}
		}
		if( row >= 1 && m_map[row-1][col].mask == 0 )
			m_map[row-1][col].obj = OBJ_NULL;
		break;
	}
	if( m_map[row][col].mask == 0 )
		m_map[row][col].obj = OBJ_NULL;

	if( hit == OBJ_HAWK )
		m_map[12][6].obj = OBJ_STONE;

	return hit;
}


BOOL CPlane::GetSurface( int row, int col, RECT& rcTank, int a, int b)
{
	char obj = m_map[row][col].obj;
	if( obj == OBJ_NULL || obj == OBJ_TREE )
		return FALSE;
	
	WORD mask = m_map[row][col].mask;
	WORD flag;
	for( int i = 0; i < 4; i ++ )
	{
		if( (i == a || i == b) ||
			(a == -1 && b == -1) )
		{
			RECT rc, temp;
			rc.left = col * TILE_W + i % 2 * 16;
			rc.right = rc.left + 16;
			rc.top = row * TILE_H + i / 2 * 16;
			rc.bottom = rc.top + 16;
			switch( i )
			{
			case 0:
				flag = 0xcc00;
				break;
			case 1:
				flag = 0x3300;
				break;
			case 2:
				flag = 0x00cc;
				break;
			case 3:
				flag = 0x0033;
			}
			if( (mask & flag) && 
				IntersectRect( &temp, &rcTank, &rc ) )
				return TRUE;
		}
	}
	return FALSE;
}


int CPlane::GetSurface( CTank& tank )
{
	int x1 = (int)tank.m_x;
	int y1 = (int)tank.m_y;
	int x2 = x1 + tank.m_width;
	int y2 = y1 + tank.m_height;
	int x = x1 + tank.m_width/2;
	int y = y1 + tank.m_height/2;
	int row, col;
	RECT rcTank;
	rcTank.left = (int)tank.m_x;
	rcTank.right = rcTank.left + tank.m_width;
	rcTank.top = (int)tank.m_y;
	rcTank.bottom = rcTank.top + tank.m_height;

	if( tank.m_dir == DIR_UP || tank.m_dir == DIR_DOWN )
	{
		col = x / TILE_W;
		if( tank.m_dir == DIR_UP )
			row = y1 / TILE_H;
		else
			row = y2 / TILE_H;
		if( x % TILE_W )
		{
			if( GetSurface( row, col, rcTank, -1, -1 ) )
				return m_map[row][col].obj;
		}
		else
		{
			if( GetSurface( row, col-1, rcTank, 1, 3 ) )
				return m_map[row][col-1].obj;
			if( GetSurface( row, col, rcTank, 0, 2 ) )
				return m_map[row][col].obj;
		}
	}
	else
	{
		row = y / TILE_H;
		if( tank.m_dir == DIR_LEFT )
			col = x1 / TILE_W;
		else
			col = x2 / TILE_W;
		if( y % TILE_H )
		{
			if( GetSurface( row, col, rcTank, -1, -1 ) )
				return m_map[row][col].obj;
		}
		else
		{
			if( GetSurface( row-1, col, rcTank, 2, 3 ) )
				return m_map[row-1][col].obj;
			if( GetSurface( row, col, rcTank, 0, 1 ) )
				return m_map[row][col].obj;
		}
	}
	return OBJ_NULL;
}


void CPlane::Draw( LPDIRECTDRAWSURFACE pdds )
{
	for( int i = 0; i < PLANE_H; i ++ )
		for( int j = 0; j < PLANE_W; j ++ )
		{
			int x = j * TILE_W + OFFSETX;
			int y = i * TILE_H + OFFSETY;
			int obj = m_map[i][j].obj;
			WORD mask = m_map[i][j].mask;
			if( obj == OBJ_NULL || obj == OBJ_TREE )
				continue;

			RECT rc;
			rc.left = obj * TILE_W;
			rc.right = rc.left + TILE_W;
			rc.top = 0;
			rc.bottom = TILE_H;

			if( mask == 0xffff )
			{
				if( obj == OBJ_RIVER && !m_bRiver1 )
				{
					RECT rcRiver;
					rcRiver.left = rc.left + TILE_W;
					rcRiver.right = rcRiver.left + TILE_W;
					rcRiver.top = 0;
					rcRiver.bottom = TILE_H;
					pdds->BltFast( x, y, m_bmp, &rcRiver, DDBLTFAST_SRCCOLORKEY | DDBLTFAST_WAIT );
				}
				else
					pdds->BltFast( x, y, m_bmp, &rc, DDBLTFAST_SRCCOLORKEY | DDBLTFAST_WAIT );
			}
			else
			{
				for( int cnt = 0; cnt < 16; cnt ++ )
				{
					if( mask & 0x8000 )
					{	
						rc.left = obj * TILE_W + cnt % 4 * 8;
						rc.top = cnt / 4 * 8;
						rc.right = rc.left + 8;
						rc.bottom = rc.top + 8;
						pdds->BltFast( x + cnt%4*8, y + cnt/4*8,
							m_bmp, &rc, DDBLTFAST_SRCCOLORKEY | DDBLTFAST_WAIT );
					}
					mask <<= 1;
				}
			}
		}
	if( timeGetTime() - m_time > 500 )
	{
		m_bRiver1 = !m_bRiver1;
		m_time = timeGetTime();
	}

	if( m_bProtected &&
		timeGetTime() - m_protectTime > 20000 )
	{
		Unprotect();
	}
}


void CPlane::DrawTree( LPDIRECTDRAWSURFACE pdds )
{
	for( int i = 0; i < PLANE_H; i ++ )
		for( int j = 0; j < PLANE_W; j ++ )
		{
			int obj = m_map[i][j].obj;
			if( obj == OBJ_TREE )
			{
				int x = j * TILE_W + OFFSETX;
				int y = i * TILE_H + OFFSETY;
				RECT rc;
				rc.left = obj * TILE_W;
				rc.right = rc.left + TILE_W;
				rc.top = 0;
				rc.bottom = TILE_H;
				pdds->BltFast( x, y, m_bmp, &rc, DDBLTFAST_SRCCOLORKEY | DDBLTFAST_WAIT );
			}
		}
}



void CPlane::Protect()
{
	m_map[12][5].obj = OBJ_CONCRETE;
	m_map[12][5].mask = 0x3333;
	m_map[11][5].obj = OBJ_CONCRETE;
	m_map[11][5].mask = 0x0033;
	m_map[11][6].obj = OBJ_CONCRETE;
	m_map[11][6].mask = 0x00ff;
	m_map[11][7].obj = OBJ_CONCRETE;
	m_map[11][7].mask = 0x00cc;
	m_map[12][7].obj = OBJ_CONCRETE;
	m_map[12][7].mask = 0xcccc;

	m_protectTime = timeGetTime();
	m_bProtected = TRUE;
}


void CPlane::Unprotect()
{
	m_map[12][5].obj = OBJ_BRICK;
	m_map[12][5].mask = 0x3333;
	m_map[11][5].obj = OBJ_BRICK;
	m_map[11][5].mask = 0x0033;
	m_map[11][6].obj = OBJ_BRICK;
	m_map[11][6].mask = 0x00ff;
	m_map[11][7].obj = OBJ_BRICK;
	m_map[11][7].mask = 0x00cc;
	m_map[12][7].obj = OBJ_BRICK;
	m_map[12][7].mask = 0xcccc;
	m_bProtected = FALSE;
}


void CPlane::Bare()
{
	m_map[12][5].obj = OBJ_NULL;
	m_map[12][5].mask = 0;
	m_map[11][5].obj = OBJ_NULL;
	m_map[11][5].mask = 0;
	m_map[11][6].obj = OBJ_NULL;
	m_map[11][6].mask = 0;
	m_map[11][7].obj = OBJ_NULL;
	m_map[11][7].mask = 0;
	m_map[12][7].obj = OBJ_NULL;
	m_map[12][7].mask = 0;
	m_bProtected = FALSE;
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久久久久久久久久女国产乱 | 久久99精品久久久久久久久久久久| 国产精品护士白丝一区av| 日韩欧美一区二区久久婷婷| 欧美亚洲一区三区| 99久久99久久免费精品蜜臀| 国产精品一区二区男女羞羞无遮挡| 视频一区二区三区在线| 亚洲午夜影视影院在线观看| 亚洲欧洲精品一区二区三区不卡| 国产欧美一区视频| 精品成人在线观看| 精品成a人在线观看| 精品少妇一区二区三区视频免付费 | 日韩国产精品久久久久久亚洲| 亚洲一级二级在线| 亚洲综合一二区| 一区二区三区视频在线观看| 亚洲柠檬福利资源导航| 亚洲欧洲av在线| 亚洲蜜臀av乱码久久精品 | 国产美女视频一区| 久久er精品视频| 国模大尺度一区二区三区| 日韩电影在线观看一区| 午夜欧美电影在线观看| 天堂午夜影视日韩欧美一区二区| 亚洲777理论| 蜜桃视频免费观看一区| 美日韩一区二区| 狠狠色综合色综合网络| 国产成人免费视频网站| 成人免费电影视频| 成人av资源站| 色综合久久综合网欧美综合网| 色噜噜狠狠成人中文综合| 色久综合一二码| 欧美精品 国产精品| 日韩女优电影在线观看| 日韩精品中文字幕一区二区三区| 欧美美女一区二区| 欧美成人在线直播| 欧美国产丝袜视频| 一区二区理论电影在线观看| 亚洲第一久久影院| 精品中文字幕一区二区| 国产酒店精品激情| 99亚偷拍自图区亚洲| 精品视频123区在线观看| 欧美大肚乱孕交hd孕妇| 国产欧美日韩视频在线观看| 亚洲摸摸操操av| 日韩国产在线一| 国产一区二区三区电影在线观看| 国产盗摄视频一区二区三区| 色欧美88888久久久久久影院| 欧美私模裸体表演在线观看| 日韩精品一区二区三区在线 | 色婷婷综合久色| 制服视频三区第一页精品| 欧美精品一区二区在线观看| 日韩美女视频19| 日韩av电影一区| 成人午夜视频免费看| 在线一区二区三区| 精品成人在线观看| 亚洲黄色免费电影| 精品无人区卡一卡二卡三乱码免费卡| 成人福利视频在线| 色偷偷88欧美精品久久久| 欧美一级片免费看| 久久免费国产精品| 视频一区二区不卡| 精品亚洲成a人在线观看| 日本道免费精品一区二区三区| 4438x亚洲最大成人网| 中文字幕va一区二区三区| 日韩国产欧美视频| 成人精品在线视频观看| 欧美高清视频在线高清观看mv色露露十八 | 夜色激情一区二区| 国产精品99久久久久| 在线播放中文字幕一区| 中文字幕综合网| 国产成人欧美日韩在线电影| 欧美日韩国产不卡| 中文字幕日韩一区| 国产在线视频不卡二| 欧美日韩久久久| 久久久久99精品国产片| 秋霞电影一区二区| 欧美色老头old∨ideo| 成人免费在线播放视频| 国产一区欧美一区| 欧美一区二区三区日韩视频| 亚洲品质自拍视频| 高清不卡在线观看| 日韩视频永久免费| 午夜电影久久久| 懂色av一区二区三区蜜臀| 欧美精品在线观看播放| 伊人色综合久久天天人手人婷| 成人综合在线网站| 欧美经典三级视频一区二区三区| 美腿丝袜亚洲一区| 欧美福利一区二区| 曰韩精品一区二区| 91丨九色丨尤物| 国产精品久久久久久久久果冻传媒 | 91色在线porny| 国产精品国产三级国产aⅴ无密码| 另类中文字幕网| 精品入口麻豆88视频| 老色鬼精品视频在线观看播放| 欧美精品在线观看播放| 亚洲v中文字幕| 欧美日韩成人高清| 亚洲一线二线三线视频| 色婷婷久久99综合精品jk白丝| 精品久久一区二区三区| 久草精品在线观看| 日韩亚洲欧美一区| 日日夜夜精品视频天天综合网| 欧美亚洲免费在线一区| 亚洲成人av资源| 欧美精品第一页| 蜜臀av性久久久久蜜臀av麻豆| 91精品麻豆日日躁夜夜躁| 免费在线观看日韩欧美| 日韩欧美一区二区视频| 韩国三级电影一区二区| 国产日韩欧美高清在线| 成人激情视频网站| 亚洲欧美视频一区| 欧美午夜精品一区二区三区| 亚洲一区二区三区不卡国产欧美| 在线视频欧美精品| 天堂久久一区二区三区| 日韩一本二本av| 美女被吸乳得到大胸91| 欧美成人精品3d动漫h| 蜜臀久久99精品久久久画质超高清| 欧美剧情片在线观看| 久久不见久久见免费视频1| 久久美女高清视频| 99久久婷婷国产| 亚洲成人精品一区| 欧美大片日本大片免费观看| 国产福利不卡视频| **网站欧美大片在线观看| 色先锋资源久久综合| 日本不卡一区二区三区高清视频| 精品久久久久久久久久久院品网| 国产suv一区二区三区88区| 亚洲激情六月丁香| 精品国产乱码久久久久久久 | 国产一级精品在线| 亚洲视频中文字幕| 91精品国产综合久久香蕉麻豆| 国产一区二区三区黄视频| 1024成人网| 欧美一级高清片| 国产成人在线观看免费网站| 亚洲视频一区二区免费在线观看| 欧美日韩一区在线| 国产成人精品综合在线观看 | 亚洲男人都懂的| 久久亚洲二区三区| 在线不卡免费av| 91极品美女在线| 成人污视频在线观看| 久久国产精品无码网站| 亚洲国产另类av| 中文字幕不卡在线| 久久亚洲精华国产精华液 | 日韩专区中文字幕一区二区| 中文字幕在线不卡一区二区三区| 精品国产91亚洲一区二区三区婷婷| 色妞www精品视频| 国产91精品在线观看| 韩国精品久久久| 日韩激情视频网站| 亚洲第一久久影院| 亚洲制服丝袜一区| 亚洲欧美另类图片小说| 国产精品三级av在线播放| 亚洲精品在线观看网站| 欧美日韩高清一区二区不卡 | 国产精品久久一卡二卡| 欧美精品一区二区三区蜜桃视频| 欧美群妇大交群中文字幕| 欧美亚洲高清一区二区三区不卡| 成人污污视频在线观看| 丰满岳乱妇一区二区三区| 国产精品亚洲一区二区三区在线| 免费高清在线一区| 免费欧美高清视频| 免费日韩伦理电影| 久久se精品一区精品二区| 久久精品国产秦先生|