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

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

?? aas_file.c

?? 3D 游戲界的大牛人 John Carmack 終于放出了 Q3 的源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
	header.ident = LittleLong(header.ident);
	if (header.ident != AASID)
	{
		AAS_Error("%s is not an AAS file\n", filename);
		fclose(fp);
		return false;
	} //end if
	//check the version
	header.version = LittleLong(header.version);
	if (header.version != AASVERSION_OLD && header.version != AASVERSION)
	{
		AAS_Error("%s is version %i, not %i\n", filename, header.version, AASVERSION);
		fclose(fp);
		return false;
	} //end if
	//
	if (header.version == AASVERSION)
	{
		AAS_DData((unsigned char *) &header + 8, sizeof(aas_header_t) - 8);
	} //end if
	aasworld.bspchecksum = LittleLong(header.bspchecksum);
	//load the lumps:
	//bounding boxes
	offset = fpoffset + LittleLong(header.lumps[AASLUMP_BBOXES].fileofs);
	length = LittleLong(header.lumps[AASLUMP_BBOXES].filelen);
	aasworld.bboxes = (aas_bbox_t *) AAS_LoadAASLump(fp, offset, length, aasworld.bboxes);
	if (!aasworld.bboxes) return false;
	aasworld.numbboxes = length / sizeof(aas_bbox_t);
	//vertexes
	offset = fpoffset + LittleLong(header.lumps[AASLUMP_VERTEXES].fileofs);
	length = LittleLong(header.lumps[AASLUMP_VERTEXES].filelen);
	aasworld.vertexes = (aas_vertex_t *) AAS_LoadAASLump(fp, offset, length, aasworld.vertexes);
	if (!aasworld.vertexes) return false;
	aasworld.numvertexes = length / sizeof(aas_vertex_t);
	//planes
	offset = fpoffset + LittleLong(header.lumps[AASLUMP_PLANES].fileofs);
	length = LittleLong(header.lumps[AASLUMP_PLANES].filelen);
	aasworld.planes = (aas_plane_t *) AAS_LoadAASLump(fp, offset, length, aasworld.planes);
	if (!aasworld.planes) return false;
	aasworld.numplanes = length / sizeof(aas_plane_t);
	//edges
	offset = fpoffset + LittleLong(header.lumps[AASLUMP_EDGES].fileofs);
	length = LittleLong(header.lumps[AASLUMP_EDGES].filelen);
	aasworld.edges = (aas_edge_t *) AAS_LoadAASLump(fp, offset, length, aasworld.edges);
	if (!aasworld.edges) return false;
	aasworld.numedges = length / sizeof(aas_edge_t);
	//edgeindex
	offset = fpoffset + LittleLong(header.lumps[AASLUMP_EDGEINDEX].fileofs);
	length = LittleLong(header.lumps[AASLUMP_EDGEINDEX].filelen);
	aasworld.edgeindex = (aas_edgeindex_t *) AAS_LoadAASLump(fp, offset, length, aasworld.edgeindex);
	if (!aasworld.edgeindex) return false;
	aasworld.edgeindexsize = length / sizeof(aas_edgeindex_t);
	//faces
	offset = fpoffset + LittleLong(header.lumps[AASLUMP_FACES].fileofs);
	length = LittleLong(header.lumps[AASLUMP_FACES].filelen);
	aasworld.faces = (aas_face_t *) AAS_LoadAASLump(fp, offset, length, aasworld.faces);
	if (!aasworld.faces) return false;
	aasworld.numfaces = length / sizeof(aas_face_t);
	//faceindex
	offset = fpoffset + LittleLong(header.lumps[AASLUMP_FACEINDEX].fileofs);
	length = LittleLong(header.lumps[AASLUMP_FACEINDEX].filelen);
	aasworld.faceindex = (aas_faceindex_t *) AAS_LoadAASLump(fp, offset, length, aasworld.faceindex);
	if (!aasworld.faceindex) return false;
	aasworld.faceindexsize = length / sizeof(int);
	//convex areas
	offset = fpoffset + LittleLong(header.lumps[AASLUMP_AREAS].fileofs);
	length = LittleLong(header.lumps[AASLUMP_AREAS].filelen);
	aasworld.areas = (aas_area_t *) AAS_LoadAASLump(fp, offset, length, aasworld.areas);
	if (!aasworld.areas) return false;
	aasworld.numareas = length / sizeof(aas_area_t);
	//area settings
	offset = fpoffset + LittleLong(header.lumps[AASLUMP_AREASETTINGS].fileofs);
	length = LittleLong(header.lumps[AASLUMP_AREASETTINGS].filelen);
	aasworld.areasettings = (aas_areasettings_t *) AAS_LoadAASLump(fp, offset, length, aasworld.areasettings);
	if (!aasworld.areasettings) return false;
	aasworld.numareasettings = length / sizeof(aas_areasettings_t);
	//reachability list
	offset = fpoffset + LittleLong(header.lumps[AASLUMP_REACHABILITY].fileofs);
	length = LittleLong(header.lumps[AASLUMP_REACHABILITY].filelen);
	aasworld.reachability = (aas_reachability_t *) AAS_LoadAASLump(fp, offset, length, aasworld.reachability);
	if (length && !aasworld.reachability) return false;
	aasworld.reachabilitysize = length / sizeof(aas_reachability_t);
	//nodes
	offset = fpoffset + LittleLong(header.lumps[AASLUMP_NODES].fileofs);
	length = LittleLong(header.lumps[AASLUMP_NODES].filelen);
	aasworld.nodes = (aas_node_t *) AAS_LoadAASLump(fp, offset, length, aasworld.nodes);
	if (!aasworld.nodes) return false;
	aasworld.numnodes = length / sizeof(aas_node_t);
	//cluster portals
	offset = fpoffset + LittleLong(header.lumps[AASLUMP_PORTALS].fileofs);
	length = LittleLong(header.lumps[AASLUMP_PORTALS].filelen);
	aasworld.portals = (aas_portal_t *) AAS_LoadAASLump(fp, offset, length, aasworld.portals);
	if (length && !aasworld.portals) return false;
	aasworld.numportals = length / sizeof(aas_portal_t);
	//cluster portal index
	offset = fpoffset + LittleLong(header.lumps[AASLUMP_PORTALINDEX].fileofs);
	length = LittleLong(header.lumps[AASLUMP_PORTALINDEX].filelen);
	aasworld.portalindex = (aas_portalindex_t *) AAS_LoadAASLump(fp, offset, length, aasworld.portalindex);
	if (length && !aasworld.portalindex) return false;
	aasworld.portalindexsize = length / sizeof(aas_portalindex_t);
	//clusters
	offset = fpoffset + LittleLong(header.lumps[AASLUMP_CLUSTERS].fileofs);
	length = LittleLong(header.lumps[AASLUMP_CLUSTERS].filelen);
	aasworld.clusters = (aas_cluster_t *) AAS_LoadAASLump(fp, offset, length, aasworld.clusters);
	if (length && !aasworld.clusters) return false;
	aasworld.numclusters = length / sizeof(aas_cluster_t);
	//swap everything
	AAS_SwapAASData();
	//aas file is loaded
	aasworld.loaded = true;
	//close the file
	fclose(fp);
	return true;
} //end of the function AAS_LoadAASFile
//===========================================================================
//
// Parameter:				-
// Returns:					-
// Changes Globals:		-
//===========================================================================
int AAS_WriteAASLump(FILE *fp, aas_header_t *h, int lumpnum, void *data, int length)
{
	aas_lump_t *lump;

	lump = &h->lumps[lumpnum];
	
	lump->fileofs = LittleLong(ftell(fp));
	lump->filelen = LittleLong(length);

	if (length > 0)
	{
		if (fwrite(data, length, 1, fp) < 1)
		{
			Log_Print("error writing lump %s\n", lumpnum);
			fclose(fp);
			return false;
		} //end if
	} //end if
	return true;
} //end of the function AAS_WriteAASLump
//===========================================================================
//
// Parameter:				-
// Returns:					-
// Changes Globals:		-
//===========================================================================
void AAS_ShowNumReachabilities(int tt, char *name)
{
	int i, num;

	num = 0;
	for (i = 0; i < aasworld.reachabilitysize; i++)
	{
		if ((aasworld.reachability[i].traveltype & TRAVELTYPE_MASK) == tt)
			num++;
	} //end for
	Log_Print("%6d %s\n", num, name);
} //end of the function AAS_ShowNumReachabilities
//===========================================================================
//
// Parameter:				-
// Returns:					-
// Changes Globals:		-
//===========================================================================
void AAS_ShowTotals(void)
{
	Log_Print("numvertexes = %d\r\n", aasworld.numvertexes);
	Log_Print("numplanes = %d\r\n", aasworld.numplanes);
	Log_Print("numedges = %d\r\n", aasworld.numedges);
	Log_Print("edgeindexsize = %d\r\n", aasworld.edgeindexsize);
	Log_Print("numfaces = %d\r\n", aasworld.numfaces);
	Log_Print("faceindexsize = %d\r\n", aasworld.faceindexsize);
	Log_Print("numareas = %d\r\n", aasworld.numareas);
	Log_Print("numareasettings = %d\r\n", aasworld.numareasettings);
	Log_Print("reachabilitysize = %d\r\n", aasworld.reachabilitysize);
	Log_Print("numnodes = %d\r\n", aasworld.numnodes);
	Log_Print("numportals = %d\r\n", aasworld.numportals);
	Log_Print("portalindexsize = %d\r\n", aasworld.portalindexsize);
	Log_Print("numclusters = %d\r\n", aasworld.numclusters);
	AAS_ShowNumReachabilities(TRAVEL_WALK, "walk");
	AAS_ShowNumReachabilities(TRAVEL_CROUCH, "crouch");
	AAS_ShowNumReachabilities(TRAVEL_BARRIERJUMP, "barrier jump");
	AAS_ShowNumReachabilities(TRAVEL_JUMP, "jump");
	AAS_ShowNumReachabilities(TRAVEL_LADDER, "ladder");
	AAS_ShowNumReachabilities(TRAVEL_WALKOFFLEDGE, "walk off ledge");
	AAS_ShowNumReachabilities(TRAVEL_SWIM, "swim");
	AAS_ShowNumReachabilities(TRAVEL_WATERJUMP, "water jump");
	AAS_ShowNumReachabilities(TRAVEL_TELEPORT, "teleport");
	AAS_ShowNumReachabilities(TRAVEL_ELEVATOR, "elevator");
	AAS_ShowNumReachabilities(TRAVEL_ROCKETJUMP, "rocket jump");
	AAS_ShowNumReachabilities(TRAVEL_BFGJUMP, "bfg jump");
	AAS_ShowNumReachabilities(TRAVEL_GRAPPLEHOOK, "grapple hook");
	AAS_ShowNumReachabilities(TRAVEL_DOUBLEJUMP, "double jump");
	AAS_ShowNumReachabilities(TRAVEL_RAMPJUMP, "ramp jump");
	AAS_ShowNumReachabilities(TRAVEL_STRAFEJUMP, "strafe jump");
	AAS_ShowNumReachabilities(TRAVEL_JUMPPAD, "jump pad");
	AAS_ShowNumReachabilities(TRAVEL_FUNCBOB, "func bob");
} //end of the function AAS_ShowTotals
//===========================================================================
// aas data is useless after writing to file because it is byte swapped
//
// Parameter:				-
// Returns:					-
// Changes Globals:		-
//===========================================================================
qboolean AAS_WriteAASFile(char *filename)
{
	aas_header_t header;
	FILE *fp;

	Log_Print("writing %s\n", filename);
	AAS_ShowTotals();
	//swap the aas data
	AAS_SwapAASData();
	//initialize the file header
	memset(&header, 0, sizeof(aas_header_t));
	header.ident = LittleLong(AASID);
	header.version = LittleLong(AASVERSION);
	header.bspchecksum = LittleLong(aasworld.bspchecksum);
	//open a new file
	fp = fopen(filename, "wb");
	if (!fp)
	{
		Log_Print("error opening %s\n", filename);
		return false;
	} //end if
	//write the header
	if (fwrite(&header, sizeof(aas_header_t), 1, fp) < 1)
	{
		fclose(fp);
		return false;
	} //end if
	//add the data lumps to the file
	if (!AAS_WriteAASLump(fp, &header, AASLUMP_BBOXES, aasworld.bboxes,
		aasworld.numbboxes * sizeof(aas_bbox_t))) return false;
	if (!AAS_WriteAASLump(fp, &header, AASLUMP_VERTEXES, aasworld.vertexes,
		aasworld.numvertexes * sizeof(aas_vertex_t))) return false;
	if (!AAS_WriteAASLump(fp, &header, AASLUMP_PLANES, aasworld.planes,
		aasworld.numplanes * sizeof(aas_plane_t))) return false;
	if (!AAS_WriteAASLump(fp, &header, AASLUMP_EDGES, aasworld.edges,
		aasworld.numedges * sizeof(aas_edge_t))) return false;
	if (!AAS_WriteAASLump(fp, &header, AASLUMP_EDGEINDEX, aasworld.edgeindex,
		aasworld.edgeindexsize * sizeof(aas_edgeindex_t))) return false;
	if (!AAS_WriteAASLump(fp, &header, AASLUMP_FACES, aasworld.faces,
		aasworld.numfaces * sizeof(aas_face_t))) return false;
	if (!AAS_WriteAASLump(fp, &header, AASLUMP_FACEINDEX, aasworld.faceindex,
		aasworld.faceindexsize * sizeof(aas_faceindex_t))) return false;
	if (!AAS_WriteAASLump(fp, &header, AASLUMP_AREAS, aasworld.areas,
		aasworld.numareas * sizeof(aas_area_t))) return false;
	if (!AAS_WriteAASLump(fp, &header, AASLUMP_AREASETTINGS, aasworld.areasettings,
		aasworld.numareasettings * sizeof(aas_areasettings_t))) return false;
	if (!AAS_WriteAASLump(fp, &header, AASLUMP_REACHABILITY, aasworld.reachability,
		aasworld.reachabilitysize * sizeof(aas_reachability_t))) return false;
	if (!AAS_WriteAASLump(fp, &header, AASLUMP_NODES, aasworld.nodes,
		aasworld.numnodes * sizeof(aas_node_t))) return false;
	if (!AAS_WriteAASLump(fp, &header, AASLUMP_PORTALS, aasworld.portals,
		aasworld.numportals * sizeof(aas_portal_t))) return false;
	if (!AAS_WriteAASLump(fp, &header, AASLUMP_PORTALINDEX, aasworld.portalindex,
		aasworld.portalindexsize * sizeof(aas_portalindex_t))) return false;
	if (!AAS_WriteAASLump(fp, &header, AASLUMP_CLUSTERS, aasworld.clusters,
		aasworld.numclusters * sizeof(aas_cluster_t))) return false;
	//rewrite the header with the added lumps
	fseek(fp, 0, SEEK_SET);
	AAS_DData((unsigned char *) &header + 8, sizeof(aas_header_t) - 8);
	if (fwrite(&header, sizeof(aas_header_t), 1, fp) < 1)
	{
		fclose(fp);
		return false;
	} //end if
	//close the file
	fclose(fp);
	return true;
} //end of the function AAS_WriteAASFile

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产夜色精品一区二区av| 91精品国产综合久久久蜜臀图片 | 日韩在线一区二区| 亚洲精品乱码久久久久久久久 | 男女激情视频一区| 日韩成人午夜电影| 久久精品久久久精品美女| 蜜臀av亚洲一区中文字幕| 日本视频免费一区| 国产一区在线精品| 成人激情免费电影网址| 一本色道久久综合亚洲91| 欧美在线你懂得| 欧美剧情电影在线观看完整版免费励志电影| 色乱码一区二区三区88| 欧美另类高清zo欧美| 91精品国产手机| 久久精品视频一区二区三区| 欧美激情一区不卡| 亚洲午夜电影在线观看| 久久国产福利国产秒拍| 成人网页在线观看| 成人动漫一区二区三区| 91国产成人在线| 日韩精品一区二区三区在线播放| 久久久久久久久久看片| 一区二区三区免费在线观看| 欧美aaaaaa午夜精品| proumb性欧美在线观看| 欧美日韩一区二区在线视频| 欧美一区日本一区韩国一区| 国产精品电影院| 日本不卡123| 91亚洲男人天堂| 欧美午夜片在线观看| 日韩精品一区二区三区中文精品| 国产精品区一区二区三区| 亚洲一区二区三区四区中文字幕| 精品一二线国产| 在线观看一区二区视频| 久久精品一区四区| 日韩精品一区第一页| 99视频精品在线| 久久综合色播五月| 天天综合日日夜夜精品| jizzjizzjizz欧美| 欧美大胆人体bbbb| 亚洲国产裸拍裸体视频在线观看乱了 | 三级久久三级久久久| 国产suv精品一区二区6| 欧美一二三在线| 亚洲主播在线观看| 91在线观看免费视频| 久久久久亚洲蜜桃| 久久精品国产成人一区二区三区| 在线免费观看日韩欧美| 一区二区中文字幕在线| 国产成人午夜高潮毛片| 欧美xxx久久| 裸体健美xxxx欧美裸体表演| 欧美日韩一区二区三区在线看| 亚洲色图丝袜美腿| 99久久免费视频.com| 欧美国产禁国产网站cc| 国产一区二区女| 久久亚洲影视婷婷| 国产在线精品免费av| 精品国产自在久精品国产| 免费黄网站欧美| 欧美精品123区| 青青青伊人色综合久久| 91精品国产乱码| 午夜视频在线观看一区二区三区| 欧美日韩高清在线播放| 日韩极品在线观看| 日韩一区二区三区在线| 狠狠色综合播放一区二区| 精品国产123| 国产成人综合在线| 日本一区二区三区四区在线视频| 国产激情偷乱视频一区二区三区| 久久精品人人爽人人爽| 成人蜜臀av电影| 亚洲日本免费电影| 欧美亚洲综合在线| 性做久久久久久久久| 日韩免费电影网站| 国产成人在线视频网站| 亚洲色图制服丝袜| 欧美日韩精品欧美日韩精品一| 蜜桃视频一区二区三区在线观看| 欧美大度的电影原声| 国产999精品久久久久久 | 欧美主播一区二区三区| 视频在线观看国产精品| 久久亚洲综合色一区二区三区| 国产成人精品午夜视频免费 | 日韩电影在线免费观看| 精品电影一区二区三区| 国产成人精品三级| 亚洲一区二区三区视频在线播放| 欧美一区二区成人| 成人激情小说乱人伦| 亚洲一二三四在线观看| 久久亚洲二区三区| 91色porny在线视频| 久久精品国产免费看久久精品| 国产精品久久久久久久久晋中 | 精品日韩欧美在线| 91在线精品秘密一区二区| 日韩专区在线视频| 中文字幕av一区二区三区免费看| 欧美亚洲综合在线| 国产福利一区在线| 天堂精品中文字幕在线| 欧美国产日韩一二三区| 欧美一级二级三级乱码| 91蝌蚪porny| 精品一区二区在线看| 一区二区三区精品久久久| 精品国产一区二区三区av性色| 日本高清视频一区二区| 国产精品白丝av| 青青草原综合久久大伊人精品优势| 中文字幕久久午夜不卡| 日韩欧美色综合网站| 色一情一伦一子一伦一区| 国产一区在线观看麻豆| 奇米影视7777精品一区二区| 一区二区三区久久久| 中文字幕第一区| 久久亚洲精品国产精品紫薇| 91精品一区二区三区在线观看| 色综合天天做天天爱| 国产成人午夜99999| 精品中文字幕一区二区小辣椒| 午夜视频在线观看一区二区三区| 亚洲天堂a在线| 国产精品久久久久精k8| 久久精品视频在线看| 精品国产91久久久久久久妲己| 337p亚洲精品色噜噜噜| 欧美精品在线视频| 欧美日韩午夜影院| 欧美日韩成人综合天天影院| 日本韩国精品一区二区在线观看| 91老师片黄在线观看| 91网站最新地址| 色综合网站在线| 色94色欧美sute亚洲13| 日本乱人伦aⅴ精品| 91色porny| 欧美视频一区二区三区在线观看| 欧美影院一区二区| 欧美在线三级电影| 欧美日韩精品一区视频| 欧美精品aⅴ在线视频| 日韩一二三区视频| 精品国产污污免费网站入口 | 日韩欧美www| 精品sm在线观看| 欧美国产精品v| 亚洲另类在线视频| 性欧美大战久久久久久久久| 日韩高清在线观看| 九九九精品视频| 盗摄精品av一区二区三区| 国产mv日韩mv欧美| 97se亚洲国产综合自在线| 色婷婷一区二区三区四区| 欧美日韩在线电影| 精品乱码亚洲一区二区不卡| 久久久久久久综合日本| 亚洲欧美激情视频在线观看一区二区三区| 亚洲黄色av一区| 麻豆91在线看| 99久久99久久精品免费观看| 欧美性视频一区二区三区| 日韩一级在线观看| 中国av一区二区三区| 亚洲最快最全在线视频| 蜜桃91丨九色丨蝌蚪91桃色| 成人午夜视频网站| 欧美精品一卡两卡| 国产精品久久精品日日| 午夜精品久久久久久久久久| 国产精品原创巨作av| 欧美性视频一区二区三区| 精品久久久久久无| 伊人一区二区三区| 国产九色sp调教91| 欧美日韩一级二级| 欧美国产日韩a欧美在线观看| 亚洲国产精品久久人人爱 | 成人欧美一区二区三区| 日本中文字幕一区二区视频| 99国产精品视频免费观看| 日韩欧美国产麻豆| 亚洲精品欧美二区三区中文字幕| 国产一区二区调教|