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

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

?? cbfile.cpp

?? 赤壁之戰的游戲源代碼
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
	if( !fp )
	{
		ErrorMessage( hwnd, MAP_ERROR_ID+9, "Cannot open animation sequency data file: ", fname );
		return FALSE;
	}
		*/
	// initialize
	memset( MAP_Lib.AniSeq, 0, sizeof( struct MAP_ANISEQ_STRUCT )*MAP_UNIT_LIB_NUM );

	int nNum, nFile, nState;
	FSCAN.l_scan (sscanf (FSCAN.expand_buf,"%d,", &nNum ));
	//fscanf( fp, "%d,", &nNum );
	for( int x = 0; x< nNum; x++ )
	{
		FSCAN.l_scan (sscanf (FSCAN.expand_buf,"%d,", &nFile  ));
		//fscanf( fp, "%d,", &nFile );
		FSCAN.l_scan (sscanf (FSCAN.expand_buf,"%d,", &MAP_Lib.AniSeq[nFile].nMaxState ));
		//fscanf( fp, "%d,", &MAP_Lib.AniSeq[nFile].nMaxState );
		FSCAN.l_scan (sscanf (FSCAN.expand_buf,"%d\n", &MAP_Lib.AniSeq[nFile].nOffset ));
		//fscanf( fp, "%d\n", &MAP_Lib.AniSeq[nFile].nOffset );

		for( int i=0; i< MAP_Lib.AniSeq[nFile].nMaxState; i++ )
		{
			FSCAN.l_scan (sscanf (FSCAN.expand_buf,"%d,", &nState ));
			//fscanf( fp, "%d,", &nState );
			FSCAN.l_scan (sscanf (FSCAN.expand_buf,"%d\n", &MAP_Lib.AniSeq[nFile].nMaxSequence[nState] ));
			//fscanf( fp, "%d\n", &MAP_Lib.AniSeq[nFile].nMaxSequence[nState] );
			for( int j=0; j< MAP_Lib.AniSeq[nFile].nMaxSequence[nState]; j++ )
			{
				FSCAN.l_scan (sscanf (FSCAN.expand_buf,"%d,", &MAP_Lib.AniSeq[nFile].nAniSeq[nState][j] ));
				//fscanf( fp, "%d,", &MAP_Lib.AniSeq[nFile].nAniSeq[nState][j] );
			}
		}
	}
	//fclose( fp );
	FSCAN.scan_close ();
	return TRUE;
}

#else

BOOL MAP_ReadAniSeqFile( HWND hwnd, LPCTSTR filename, LPCTSTR path )
{
	char fname[_MAX_FNAME];
	if( path != 0 )
	{
		strcpy( fname, path );
		strcat( fname, filename );
	}
	else	strcpy( fname, filename );
	FILE * fp = fopen( fname, "rb" );
	if( !fp )
	{
		ErrorMessage( hwnd, MAP_ERROR_ID+4, "Cannot open animation sequency data file: ", fname );
		return FALSE;
	}

	// initialize
	memset( MAP_Lib.AniSeq, 0, sizeof( struct MAP_ANISEQ_STRUCT )*MAP_UNIT_LIB_NUM );

	int nNum, nFile, nState;
	fscanf( fp, "%d,", &nNum );
	for( int x = 0; x< nNum; x++ )
	{
		fscanf( fp, "%d,", &nFile );
		fscanf( fp, "%d\n", &MAP_Lib.AniSeq[nFile].nMaxState );

		for( int i=0; i< MAP_Lib.AniSeq[nFile].nMaxState; i++ )
		{
			fscanf( fp, "%d,", &nState );
			fscanf( fp, "%d\n", &MAP_Lib.AniSeq[nFile].nMaxSequence[nState] );
			for( int j=0; j< MAP_Lib.AniSeq[nFile].nMaxSequence[nState]; j++ )
			{
				fscanf( fp, "%d,%d,", 
					&MAP_Lib.AniSeq[nFile].ptAniSeq[nState][j].x,
					&MAP_Lib.AniSeq[nFile].ptAniSeq[nState][j].y );
			}
		}
	}
	fclose( fp );

	return TRUE;
}
#endif	// _MAP_COMPRESS_

// 讀擴充的單元圖素動畫數據定義文件
// defined in file CBFile.cpp
// hwnd			:	錯誤處理時窗口句柄
// filename		:	單元圖素數據文件名
// path			:	文件路徑
// reutrn value	:	TRUE if succeeded
BOOL MAP_ReadAniSeqFileEx( HWND hwnd, LPCTSTR filename, LPCTSTR path )
{
	char fname[_MAX_FNAME];
	CScan_read FSCAN;

	if( path != 0 )
	{
		strcpy( fname, path );
		strcat( fname, filename );
	}
	else	strcpy( fname, filename );
	/*
	FILE * fp = fopen( fname, "rb" );//ANISEQ02.DAT
	if( !fp )
	{
		ErrorMessage( hwnd, MAP_ERROR_ID+10, "Cannot open animation sequency data extension file: ", fname );
		return FALSE;
	}
	*/
	FSCAN.scan_open (fname);//lwc
	int nNum, nFile;
	FSCAN.l_scan (sscanf (FSCAN.expand_buf,"%d\n", &nNum ));
	//fscanf( fp, "%d\n", &nNum );
	for( int i=0; i< nNum; i++ )
	{
		FSCAN.l_scan (sscanf (FSCAN.expand_buf,"%d,", &nFile ));
		//fscanf( fp, "%d,", &nFile );
		FSCAN.l_scan (sscanf (FSCAN.expand_buf,
			"%d,%d,%d,%d,%d,%d,%d\n", 
			&MAP_Lib.AniSeq[nFile].nDeadDir,	// 死亡的方向,8為8個方向,其它為死亡時所朝向的方向
			&MAP_Lib.AniSeq[nFile].nEventBegin[0],	// 移動
			&MAP_Lib.AniSeq[nFile].nEventBegin[1],	// 死亡
			&MAP_Lib.AniSeq[nFile].nEventBegin[2],	// 攻擊
			&MAP_Lib.AniSeq[nFile].nEventBegin[3],	// 
			&MAP_Lib.AniSeq[nFile].nEventBegin[4],
			&MAP_Lib.AniSeq[nFile].nEventBegin[5] ));
		/*
		fscanf( fp, "%d,%d,%d,%d,%d,%d,%d\n", 
			&MAP_Lib.AniSeq[nFile].nDeadDir,	// 死亡的方向,8為8個方向,其它為死亡時所朝向的方向
			&MAP_Lib.AniSeq[nFile].nEventBegin[0],	// 移動
			&MAP_Lib.AniSeq[nFile].nEventBegin[1],	// 死亡
			&MAP_Lib.AniSeq[nFile].nEventBegin[2],	// 攻擊
			&MAP_Lib.AniSeq[nFile].nEventBegin[3],	// 
			&MAP_Lib.AniSeq[nFile].nEventBegin[4],
			&MAP_Lib.AniSeq[nFile].nEventBegin[5] );
		// 后3項
		// 對于工人,為木材,鐵礦,糧食
		// 對于步將,為下令
		// 對于100人步兵,為滾木,投石
		// 對于100人弓兵,為滾木,投石
		*/

	}
//	fclose( fp );
FSCAN.scan_close ();
	return TRUE;
}
//////////////////////

#ifdef	_GAME_
//////////////////////
// 讀取遮擋數據
// read cover file, declared in CBDraw.h
BOOL DRAW_ReadCoverFile( HWND hwnd, LPCTSTR filename, LPCTSTR path )
{
	char fname[_MAX_FNAME];
	CScan_read FSCAN;

	if( path != 0 )
	{
		strcpy( fname, path );
		strcat( fname, filename );
	}
	else	strcpy( fname, filename );
	FSCAN.scan_open (fname);
	/*
	FILE * fp = fopen( fname, "rb" );//cover.dat
	if( !fp )
	{
		ErrorMessage( hwnd, MAP_ERROR_ID+13, "Cannot open cover data file: ", fname );
		return FALSE;
	}
	*/
	memset( &DRAW_CoverLib, 0, sizeof(DRAW_COVER_STRUCT) );

	int i,j;
	for( i=0; i< DRAW_LOCATION_MAX*2; i++ )
	{
		// read covered
		FSCAN.l_scan (sscanf (FSCAN.expand_buf,"%d\n", &DRAW_CoverLib.nCoveredMax[i&1][i>>1] ));
		//fscanf( fp, "%d\n", &DRAW_CoverLib.nCoveredMax[i&1][i>>1] );
		for( j=0; j< DRAW_CoverLib.nCoveredMax[i&1][i>>1]; j++ )
		{
			FSCAN.l_scan (sscanf (FSCAN.expand_buf,"%d,%d,", 
				&DRAW_CoverLib.ptCovered[i&1][i>>1][j].x,
				&DRAW_CoverLib.ptCovered[i&1][i>>1][j].y ));
			/*
			fscanf( fp, "%d,%d,", 
				&DRAW_CoverLib.ptCovered[i&1][i>>1][j].x,
				&DRAW_CoverLib.ptCovered[i&1][i>>1][j].y );
			*/
		}
		// read covering
		FSCAN.l_scan (sscanf (FSCAN.expand_buf,"%d\n", &DRAW_CoverLib.nCoveringMax[i&1][i>>1] ));
		//fscanf( fp, "%d\n", &DRAW_CoverLib.nCoveringMax[i&1][i>>1] );
		for( j=0; j< DRAW_CoverLib.nCoveringMax[i&1][i>>1]; j++ )
		{
			FSCAN.l_scan (sscanf (FSCAN.expand_buf,"%d,%d,", 
				&DRAW_CoverLib.ptCovering[i&1][i>>1][j].x,
				&DRAW_CoverLib.ptCovering[i&1][i>>1][j].y ));
			/*
			fscanf( fp, "%d,%d,", 
				&DRAW_CoverLib.ptCovering[i&1][i>>1][j].x,
				&DRAW_CoverLib.ptCovering[i&1][i>>1][j].y );
			*/
		}
	}
//	fclose( fp );
	FSCAN.scan_close ();
	return TRUE;
}// end of DRAW_ReadCoverFile()

///////////
// 讀取縮略圖數據文件
// declared in file CBMAP.cpp
// hwnd			:	錯誤處理時窗口句柄
// filename		:	單元圖素數據文件名
// path			:	文件路徑
// reutrn value	:	TRUE if succeeded
BOOL MAP_ReadMiniFile( HWND hwnd, LPCTSTR filename, LPCTSTR path )
{
	char fname[_MAX_FNAME];
	CScan_read FSCAN;

	if( path != 0 )
	{
		strcpy( fname, path );
		strcat( fname, filename );
	}
	else	strcpy( fname, filename );
	FSCAN.scan_open (fname);
/*	FILE * fp = fopen( fname, "rb" );//minimap.dat
	if( !fp )
	{
		ErrorMessage( hwnd, MAP_ERROR_ID+5, "Cannot open minimap data file: ", fname );
		return FALSE;
	}
*/
	// initialize
	memset( &MINI_Lib, 0, sizeof( struct MAP_MINI_LIB_STRUCT ) );
	MINI_Lib.nType =-1;

	int nNum;

	// read screen rectangle of battlefield
	FSCAN.l_scan (sscanf (FSCAN.expand_buf,"%d,%d,%d,%d\n", 
		&MINI_Lib.rcScreen.left, 
		&MINI_Lib.rcScreen.top,
		&MINI_Lib.rcScreen.right,
		&MINI_Lib.rcScreen.bottom ));
	/*
	fscanf( fp, "%d,%d,%d,%d\n", 
		&MINI_Lib.rcScreen.left, 
		&MINI_Lib.rcScreen.top,
		&MINI_Lib.rcScreen.right,
		&MINI_Lib.rcScreen.bottom );
	*/
	// read position and size of minimap of each type
	FSCAN.l_scan (sscanf (FSCAN.expand_buf,"%d\n", &nNum ));
	//fscanf( fp, "%d\n", &nNum );
	if( nNum > MAP_MINI_TYPE_MAX )
	{
		ErrorMessage( hwnd, MAP_ERROR_ID+6, "read minimap data file error: ", fname );
	}

	// 注意:讀取的不是縮略圖的右下角坐標,而是寬度和高度
	for( int i=0; i< nNum; i++ )
	{
		FSCAN.l_scan (sscanf (FSCAN.expand_buf,"%d,%d,%d,%d\n", 
			&MINI_Lib.rcMap[i].left, 
			&MINI_Lib.rcMap[i].top,
			&MINI_Lib.rcMap[i].right,
			&MINI_Lib.rcMap[i].bottom ));
		/*
		fscanf( fp, "%d,%d,%d,%d\n", 
			&MINI_Lib.rcMap[i].left, 
			&MINI_Lib.rcMap[i].top,
			&MINI_Lib.rcMap[i].right,
			&MINI_Lib.rcMap[i].bottom );
		*/
		MINI_Lib.rcMap[i].right += MINI_Lib.rcMap[i].left;
		MINI_Lib.rcMap[i].bottom += MINI_Lib.rcMap[i].top;
	}

	// read color table
	FSCAN.l_scan (sscanf (FSCAN.expand_buf, "%d\n", &nNum ));
	//fscanf( fp, "%d\n", &nNum );
	if( nNum > MAP_MINI_COLOR_MAX )
	{
		ErrorMessage( hwnd, MAP_ERROR_ID+7, "read minimap data file error: ", fname );
	}
	for( i=0; i< nNum; i++ )
	{
		FSCAN.l_scan (sscanf (FSCAN.expand_buf,"%d,", &MINI_Lib.nColorTable[i] ));
		//fscanf( fp, "%d,", &MINI_Lib.nColorTable[i] );
	}

	//fclose( fp );
	FSCAN.scan_close ();
	return TRUE;
}// end of MAP_ReadMiniFile()
///////////

///////////
BOOL DATA_ReadDATAFile( HWND hwnd, LPCTSTR filename, LPCTSTR path )
{
	char fname[_MAX_FNAME];
	

	if( path != 0 )
	{
		strcpy( fname, path );
		strcat( fname, filename );
	}
	else	strcpy( fname, filename );
	strcpy( DATA_Lib.strDATA, fname );
	BOOL ret = DATA_ReloadDATAFile( hwnd );
	strcpy( DATA_Lib.strDATA, fname );
	return ret;
}// end of DATA_ReadDATAFile()

BOOL DATA_ReloadDATAFile( HWND hwnd )
{
	char fname[_MAX_FNAME];
	strcpy( fname, DATA_Lib.strDATA );
	CScan_read FSCAN;
	FSCAN.scan_open (fname);
	/*
	FILE * fp = fopen( fname, "rb" );//data.dat
	if( !fp )
	{
		ErrorMessage( hwnd, MAP_ERROR_ID+8, "Cannot open DATA file: ", fname );
		return FALSE;
	}
	*/
	// initialize
	memset( &DATA_Lib, 0, sizeof(DATA_STRUCT) );
	strcpy( DATA_Lib.strDATA, fname );

	int nNum, i, nNum2;

	// read grade data
	FSCAN.l_scan (sscanf (FSCAN.expand_buf, "%d\n", &nNum ));
	//fscanf( fp, "%d\n", &nNum );
	for( i=0; i< nNum; i++ )
	{
		FSCAN.l_scan (sscanf (FSCAN.expand_buf, "%s %d %d %d\n",
							  DATA_Lib.Grade[i].strName,
							  &DATA_Lib.Grade[i].nAddWuLi,
							  &DATA_Lib.Grade[i].nAddZhiLi,
							  &DATA_Lib.Grade[i].nGrade
							  ));

		for( int j=0; j<(int)strlen(DATA_Lib.Grade[i].strName); j++ )
		{
			if( DATA_Lib.Grade[i].strName[j] == '$' )
				DATA_Lib.Grade[i].strName[j] = ' ';
		}
		/*
		fscanf( fp, "%s %d %d %d\n",
			DATA_Lib.Grade[i].strName,
			&DATA_Lib.Grade[i].nAddWuLi,
			&DATA_Lib.Grade[i].nAddZhiLi,
			&DATA_Lib.Grade[i].nGrade
			);
		*/
	}

	// read building data
	FSCAN.l_scan (sscanf (FSCAN.expand_buf,"%d\n", &nNum ));
	//fscanf( fp, "%d\n", &nNum );
	//int nsss;
	for( i=0; i< nNum; i++ )
	{
		FSCAN.l_scan (sscanf (FSCAN.expand_buf,
			"%d %s %d %d %d %d %d %d %d %d %d %d %d %d %d\n",
			&DATA_Lib.Unit[i].nID,
			DATA_Lib.Unit[i].strName,
			&DATA_Lib.Unit[i].dwLife,
			&DATA_Lib.Unit[i].nFarAttack,
			&DATA_Lib.Unit[i].nNearDefend,
			&DATA_Lib.Unit[i].nFarDefend,
			&DATA_Lib.Unit[i].nViewRange,
			&DATA_Lib.Unit[i].nFightRange,
			&DATA_Lib.Unit[i].nFightSpeed,
			&DATA_Lib.Unit[i].nCreateIron,

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人永久免费视频| 蜜臀av性久久久久蜜臀av麻豆| 丰满亚洲少妇av| 久久久综合精品| 国产麻豆视频一区| 国产亚洲精品中文字幕| 成人夜色视频网站在线观看| 亚洲婷婷综合久久一本伊一区| 91同城在线观看| 日韩在线卡一卡二| 精品美女一区二区| 成人av网在线| 亚洲一区二区欧美| 欧美成人一级视频| 成人app软件下载大全免费| 亚洲精品视频观看| 日韩一级片在线观看| 国产一区不卡在线| 亚洲精品国产a久久久久久| 91精品国产美女浴室洗澡无遮挡| 国产主播一区二区三区| 成人欧美一区二区三区白人| 欧美日韩一区三区| 国产一区二区免费视频| 亚洲免费在线观看视频| 欧美一级欧美三级| 懂色中文一区二区在线播放| 悠悠色在线精品| 欧美精品一区二区久久婷婷| 99久久精品久久久久久清纯| 首页国产丝袜综合| 亚洲精品国久久99热| 在线播放亚洲一区| 成人v精品蜜桃久久一区| 五月综合激情网| 国产欧美一二三区| 欧美一区二区三区视频在线 | 欧美在线一区二区| 国内精品视频一区二区三区八戒 | 欧美日韩高清不卡| 国产精品18久久久久久vr| 亚洲专区一二三| 久久精品人人做人人综合| 欧美精品免费视频| 成人性生交大片免费看中文| 蜜桃精品视频在线观看| 亚洲人成在线播放网站岛国| 欧美精品一区二区不卡 | 成人黄色小视频| 奇米888四色在线精品| 亚洲人成网站在线| 国产精品日韩精品欧美在线| 欧美v亚洲v综合ⅴ国产v| 欧美在线视频日韩| 99精品国产91久久久久久| 国产米奇在线777精品观看| 爽好多水快深点欧美视频| 一区二区三区鲁丝不卡| 国产欧美一区二区三区鸳鸯浴| 91精品国产一区二区| 欧美日韩一级视频| 在线免费av一区| 色综合网站在线| www.欧美.com| 亚洲成av人片在www色猫咪| 一区二区三区在线观看欧美| 日韩免费电影网站| 成人听书哪个软件好| 国产传媒久久文化传媒| 久久久午夜精品| 在线电影院国产精品| 91福利区一区二区三区| 成人18精品视频| 91在线观看高清| 色婷婷国产精品综合在线观看| 高清av一区二区| 99精品一区二区| 91女厕偷拍女厕偷拍高清| 99免费精品在线| 91丨九色porny丨蝌蚪| 99综合电影在线视频| 99re66热这里只有精品3直播| 成人免费视频caoporn| 国产91清纯白嫩初高中在线观看| 成人中文字幕在线| 99久久伊人久久99| 99精品欧美一区二区三区综合在线| 99视频在线精品| 91福利精品第一导航| 欧美日韩国产小视频| 日韩欧美在线一区二区三区| 精品福利在线导航| 日韩免费电影一区| 国产欧美日韩中文久久| 最新不卡av在线| 亚洲一区电影777| 免费欧美在线视频| 国产乱码精品1区2区3区| av一区二区三区黑人| 欧美三区在线观看| 欧美一区二区三区男人的天堂| 精品国产一区二区三区不卡| 日本一区二区综合亚洲| 亚洲视频一区在线| 三级一区在线视频先锋| 国产一区欧美日韩| 99久久国产综合精品色伊| 欧美亚男人的天堂| 精品国产欧美一区二区| 国产精品视频看| 亚洲线精品一区二区三区八戒| 精品一区二区三区免费毛片爱| 成人精品免费网站| 欧美日韩一区久久| 国产日产精品1区| 色偷偷88欧美精品久久久| 精品视频在线视频| 欧美经典一区二区| 国产ts人妖一区二区| 99久久精品免费观看| 欧美日韩一区小说| 精品欧美一区二区三区精品久久| 日韩一区二区视频| 欧美国产精品v| 天堂资源在线中文精品| 卡一卡二国产精品 | 国产激情偷乱视频一区二区三区| 国产91对白在线观看九色| 欧美日韩成人激情| 一区精品在线播放| 久久精品国产亚洲a| 99re成人在线| 国产亚洲短视频| 日韩精品福利网| 91视频你懂的| 久久久国产精品麻豆| 午夜精品久久久久久| 菠萝蜜视频在线观看一区| 欧美一区二区三区电影| 一区二区三区在线高清| 国产成人自拍高清视频在线免费播放| 欧美伦理电影网| 亚洲精品乱码久久久久久黑人| 国产精品99久久久久久宅男| 欧美一区二区三区四区高清| 亚洲激情图片一区| av男人天堂一区| 国产精品入口麻豆九色| 精品一区二区三区视频| 日韩欧美在线影院| 日本中文一区二区三区| 欧美偷拍一区二区| 亚洲精品精品亚洲| 91小视频免费观看| 中文字幕在线观看不卡| 国产不卡视频在线观看| 欧美激情中文字幕一区二区| 国产高清不卡一区| 精品福利一区二区三区免费视频| 日本大胆欧美人术艺术动态| 欧美日韩国产小视频在线观看| 亚洲一区二区三区自拍| 日韩 欧美一区二区三区| 日韩精品在线看片z| 国产精品18久久久久| av色综合久久天堂av综合| 欧美韩国日本不卡| 粉嫩嫩av羞羞动漫久久久| 欧美国产丝袜视频| 成人精品免费网站| 中文字幕一区二区三区av| 91在线无精精品入口| 中文字幕永久在线不卡| 成人av午夜电影| 亚洲免费观看高清在线观看| 色综合视频一区二区三区高清| 亚洲女与黑人做爰| 91国产丝袜在线播放| 亚洲国产精品久久人人爱蜜臀| 日韩欧美亚洲国产另类| 日韩免费看的电影| 国产精品电影一区二区三区| 欧美最新大片在线看| 韩国一区二区在线观看| 亚洲天堂av一区| 国产日韩欧美高清在线| 欧美一级艳片视频免费观看| www.99精品| 国产精品18久久久久久久久| 婷婷中文字幕一区三区| 国产精品精品国产色婷婷| 中文字幕日本不卡| 成人久久视频在线观看| 精品免费99久久| 成人av中文字幕| 亚洲精品va在线观看| 日韩一区二区三免费高清| 国产精品一区在线观看你懂的| 综合电影一区二区三区| 欧美日本一道本在线视频|