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

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

?? r_alias.c

?? 著名游戲quake2原代碼最新版本(vc6.0可以編譯的)
?? C
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
/*
Copyright (C) 1997-2001 Id Software, Inc.

This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  

See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.

*/
// r_alias.c: routines for setting up to draw alias models

/*
** use a real variable to control lerping
*/
#include "r_local.h"

#define LIGHT_MIN	5		// lowest light value we'll allow, to avoid the
							//  need for inner-loop light clamping

//PGM
extern byte iractive;
//PGM

int				r_amodels_drawn;

affinetridesc_t	r_affinetridesc;

vec3_t			r_plightvec;
vec3_t          r_lerped[1024];
vec3_t          r_lerp_frontv, r_lerp_backv, r_lerp_move;

int				r_ambientlight;
int				r_aliasblendcolor;
float			r_shadelight;


daliasframe_t	*r_thisframe, *r_lastframe;
dmdl_t			*s_pmdl;

float	aliastransform[3][4];
float   aliasworldtransform[3][4];
float   aliasoldworldtransform[3][4];

static float	s_ziscale;
static vec3_t	s_alias_forward, s_alias_right, s_alias_up;


#define NUMVERTEXNORMALS	162

float	r_avertexnormals[NUMVERTEXNORMALS][3] = {
#include "anorms.h"
};


void R_AliasSetUpLerpData( dmdl_t *pmdl, float backlerp );
void R_AliasSetUpTransform (void);
void R_AliasTransformVector (vec3_t in, vec3_t out, float m[3][4] );
void R_AliasProjectAndClipTestFinalVert (finalvert_t *fv);

void R_AliasTransformFinalVerts( int numpoints, finalvert_t *fv, dtrivertx_t *oldv, dtrivertx_t *newv );

void R_AliasLerpFrames( dmdl_t *paliashdr, float backlerp );

/*
================
R_AliasCheckBBox
================
*/
typedef struct {
	int	index0;
	int	index1;
} aedge_t;

static aedge_t	aedges[12] = {
{0, 1}, {1, 2}, {2, 3}, {3, 0},
{4, 5}, {5, 6}, {6, 7}, {7, 4},
{0, 5}, {1, 4}, {2, 7}, {3, 6}
};

#define BBOX_TRIVIAL_ACCEPT 0
#define BBOX_MUST_CLIP_XY   1
#define BBOX_MUST_CLIP_Z    2
#define BBOX_TRIVIAL_REJECT 8

/*
** R_AliasCheckFrameBBox
**
** Checks a specific alias frame bounding box
*/
unsigned long R_AliasCheckFrameBBox( daliasframe_t *frame, float worldxf[3][4] )
{
	unsigned long aggregate_and_clipcode = ~0U, 
		          aggregate_or_clipcode = 0;
	int           i;
	vec3_t        mins, maxs;
	vec3_t        transformed_min, transformed_max;
	qboolean      zclipped = false, zfullyclipped = true;
	float         minz = 9999.0F;

	/*
	** get the exact frame bounding box
	*/
	for (i=0 ; i<3 ; i++)
	{
		mins[i] = frame->translate[i];
		maxs[i] = mins[i] + frame->scale[i]*255;
	}

	/*
	** transform the min and max values into view space
	*/
	R_AliasTransformVector( mins, transformed_min, aliastransform );
	R_AliasTransformVector( maxs, transformed_max, aliastransform );

	if ( transformed_min[2] >= ALIAS_Z_CLIP_PLANE )
		zfullyclipped = false;
	if ( transformed_max[2] >= ALIAS_Z_CLIP_PLANE )
		zfullyclipped = false;

	if ( zfullyclipped )
	{
		return BBOX_TRIVIAL_REJECT;
	}
	if ( zclipped )
	{
		return ( BBOX_MUST_CLIP_XY | BBOX_MUST_CLIP_Z );
	}

	/*
	** build a transformed bounding box from the given min and max
	*/
	for ( i = 0; i < 8; i++ )
	{
		int      j;
		vec3_t   tmp, transformed;
		unsigned long clipcode = 0;

		if ( i & 1 )
			tmp[0] = mins[0];
		else
			tmp[0] = maxs[0];

		if ( i & 2 )
			tmp[1] = mins[1];
		else
			tmp[1] = maxs[1];

		if ( i & 4 )
			tmp[2] = mins[2];
		else
			tmp[2] = maxs[2];

		R_AliasTransformVector( tmp, transformed, worldxf );

		for ( j = 0; j < 4; j++ )
		{
			float dp = DotProduct( transformed, view_clipplanes[j].normal );

			if ( ( dp - view_clipplanes[j].dist ) < 0.0F )
				clipcode |= 1 << j;
		}

		aggregate_and_clipcode &= clipcode;
		aggregate_or_clipcode  |= clipcode;
	}

	if ( aggregate_and_clipcode )
	{
		return BBOX_TRIVIAL_REJECT;
	}
	if ( !aggregate_or_clipcode )
	{
		return BBOX_TRIVIAL_ACCEPT;
	}

	return BBOX_MUST_CLIP_XY;
}

qboolean R_AliasCheckBBox (void)
{
	unsigned long ccodes[2] = { 0, 0 };

	ccodes[0] = R_AliasCheckFrameBBox( r_thisframe, aliasworldtransform );

	/*
	** non-lerping model
	*/
	if ( currententity->backlerp == 0 )
	{
		if ( ccodes[0] == BBOX_TRIVIAL_ACCEPT )
			return BBOX_TRIVIAL_ACCEPT;
		else if ( ccodes[0] & BBOX_TRIVIAL_REJECT )
			return BBOX_TRIVIAL_REJECT;
		else
			return ( ccodes[0] & ~BBOX_TRIVIAL_REJECT );
	}

	ccodes[1] = R_AliasCheckFrameBBox( r_lastframe, aliasoldworldtransform );

	if ( ( ccodes[0] | ccodes[1] ) == BBOX_TRIVIAL_ACCEPT )
		return BBOX_TRIVIAL_ACCEPT;
	else if ( ( ccodes[0] & ccodes[1] ) & BBOX_TRIVIAL_REJECT )
		return BBOX_TRIVIAL_REJECT;
	else
		return ( ccodes[0] | ccodes[1] ) & ~BBOX_TRIVIAL_REJECT;
}


/*
================
R_AliasTransformVector
================
*/
void R_AliasTransformVector(vec3_t in, vec3_t out, float xf[3][4] )
{
	out[0] = DotProduct(in, xf[0]) + xf[0][3];
	out[1] = DotProduct(in, xf[1]) + xf[1][3];
	out[2] = DotProduct(in, xf[2]) + xf[2][3];
}


/*
================
R_AliasPreparePoints

General clipped case
================
*/
typedef struct
{
	int          num_points;
	dtrivertx_t *last_verts;   // verts from the last frame
	dtrivertx_t *this_verts;   // verts from this frame
	finalvert_t *dest_verts;   // destination for transformed verts
} aliasbatchedtransformdata_t;

aliasbatchedtransformdata_t aliasbatchedtransformdata;

void R_AliasPreparePoints (void)
{
	int			i;
	dstvert_t	*pstverts;
	dtriangle_t	*ptri;
	finalvert_t	*pfv[3];
	finalvert_t	finalverts[MAXALIASVERTS +
						((CACHE_SIZE - 1) / sizeof(finalvert_t)) + 3];
	finalvert_t	*pfinalverts;

//PGM
	iractive = (r_newrefdef.rdflags & RDF_IRGOGGLES && currententity->flags & RF_IR_VISIBLE);
//	iractive = 0;
//	if(r_newrefdef.rdflags & RDF_IRGOGGLES && currententity->flags & RF_IR_VISIBLE)
//		iractive = 1;
//PGM

	// put work vertexes on stack, cache aligned
	pfinalverts = (finalvert_t *)
			(((long)&finalverts[0] + CACHE_SIZE - 1) & ~(CACHE_SIZE - 1));

	aliasbatchedtransformdata.num_points = s_pmdl->num_xyz;
	aliasbatchedtransformdata.last_verts = r_lastframe->verts;
	aliasbatchedtransformdata.this_verts = r_thisframe->verts;
	aliasbatchedtransformdata.dest_verts = pfinalverts;

	R_AliasTransformFinalVerts( aliasbatchedtransformdata.num_points,
		                        aliasbatchedtransformdata.dest_verts,
								aliasbatchedtransformdata.last_verts,
								aliasbatchedtransformdata.this_verts );

// clip and draw all triangles
//
	pstverts = (dstvert_t *)((byte *)s_pmdl + s_pmdl->ofs_st);
	ptri = (dtriangle_t *)((byte *)s_pmdl + s_pmdl->ofs_tris);

	if ( ( currententity->flags & RF_WEAPONMODEL ) && ( r_lefthand->value == 1.0F ) )
	{
		for (i=0 ; i<s_pmdl->num_tris ; i++, ptri++)
		{
			pfv[0] = &pfinalverts[ptri->index_xyz[0]];
			pfv[1] = &pfinalverts[ptri->index_xyz[1]];
			pfv[2] = &pfinalverts[ptri->index_xyz[2]];

			if ( pfv[0]->flags & pfv[1]->flags & pfv[2]->flags )
				continue;		// completely clipped

			// insert s/t coordinates
			pfv[0]->s = pstverts[ptri->index_st[0]].s << 16;
			pfv[0]->t = pstverts[ptri->index_st[0]].t << 16;

			pfv[1]->s = pstverts[ptri->index_st[1]].s << 16;
			pfv[1]->t = pstverts[ptri->index_st[1]].t << 16;

			pfv[2]->s = pstverts[ptri->index_st[2]].s << 16;
			pfv[2]->t = pstverts[ptri->index_st[2]].t << 16;

			if ( ! (pfv[0]->flags | pfv[1]->flags | pfv[2]->flags) )
			{	// totally unclipped
				aliastriangleparms.a = pfv[2];
				aliastriangleparms.b = pfv[1];
				aliastriangleparms.c = pfv[0];

				R_DrawTriangle();
			}
			else
			{
				R_AliasClipTriangle (pfv[2], pfv[1], pfv[0]);
			}
		}
	}
	else
	{
		for (i=0 ; i<s_pmdl->num_tris ; i++, ptri++)
		{
			pfv[0] = &pfinalverts[ptri->index_xyz[0]];
			pfv[1] = &pfinalverts[ptri->index_xyz[1]];
			pfv[2] = &pfinalverts[ptri->index_xyz[2]];

			if ( pfv[0]->flags & pfv[1]->flags & pfv[2]->flags )
				continue;		// completely clipped

			// insert s/t coordinates
			pfv[0]->s = pstverts[ptri->index_st[0]].s << 16;
			pfv[0]->t = pstverts[ptri->index_st[0]].t << 16;

			pfv[1]->s = pstverts[ptri->index_st[1]].s << 16;
			pfv[1]->t = pstverts[ptri->index_st[1]].t << 16;

			pfv[2]->s = pstverts[ptri->index_st[2]].s << 16;
			pfv[2]->t = pstverts[ptri->index_st[2]].t << 16;

			if ( ! (pfv[0]->flags | pfv[1]->flags | pfv[2]->flags) )
			{	// totally unclipped
				aliastriangleparms.a = pfv[0];
				aliastriangleparms.b = pfv[1];
				aliastriangleparms.c = pfv[2];

				R_DrawTriangle();
			}
			else		
			{	// partially clipped
				R_AliasClipTriangle (pfv[0], pfv[1], pfv[2]);
			}
		}
	}
}


/*
================
R_AliasSetUpTransform
================
*/
void R_AliasSetUpTransform (void)
{
	int				i;
	static float	viewmatrix[3][4];
	vec3_t			angles;

// TODO: should really be stored with the entity instead of being reconstructed
// TODO: should use a look-up table
// TODO: could cache lazily, stored in the entity
// 
	angles[ROLL] = currententity->angles[ROLL];
	angles[PITCH] = currententity->angles[PITCH];
	angles[YAW] = currententity->angles[YAW];
	AngleVectors( angles, s_alias_forward, s_alias_right, s_alias_up );

// TODO: can do this with simple matrix rearrangement

	memset( aliasworldtransform, 0, sizeof( aliasworldtransform ) );
	memset( aliasoldworldtransform, 0, sizeof( aliasworldtransform ) );

	for (i=0 ; i<3 ; i++)
	{
		aliasoldworldtransform[i][0] = aliasworldtransform[i][0] =  s_alias_forward[i];
		aliasoldworldtransform[i][0] = aliasworldtransform[i][1] = -s_alias_right[i];
		aliasoldworldtransform[i][0] = aliasworldtransform[i][2] =  s_alias_up[i];
	}

	aliasworldtransform[0][3] = currententity->origin[0]-r_origin[0];
	aliasworldtransform[1][3] = currententity->origin[1]-r_origin[1];
	aliasworldtransform[2][3] = currententity->origin[2]-r_origin[2];

	aliasoldworldtransform[0][3] = currententity->oldorigin[0]-r_origin[0];
	aliasoldworldtransform[1][3] = currententity->oldorigin[1]-r_origin[1];
	aliasoldworldtransform[2][3] = currententity->oldorigin[2]-r_origin[2];

// FIXME: can do more efficiently than full concatenation
//	memcpy( rotationmatrix, t2matrix, sizeof( rotationmatrix ) );

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品国产入口| 国产拍欧美日韩视频二区| 国产毛片精品视频| 伊人开心综合网| 精品久久久久久无| 欧美男男青年gay1069videost | 欧美一区二区三区在线视频| 不卡电影免费在线播放一区| 免费三级欧美电影| 亚洲在线成人精品| 国产精品久线观看视频| 日韩免费高清av| 欧美乱妇15p| 日本高清不卡在线观看| 丁香六月综合激情| 狠狠色丁香久久婷婷综| 日本91福利区| 亚洲成在人线免费| 亚洲日本免费电影| 国产精品嫩草影院com| 久久先锋影音av鲁色资源网| 91麻豆精品国产91久久久| 色综合久久天天综合网| 成人一区二区三区| 国产成人精品三级麻豆| 精品一区二区三区免费| 久久国产综合精品| 六月丁香婷婷色狠狠久久| 午夜精品一区二区三区电影天堂| 一区二区三区久久久| 一区二区三区中文字幕电影| 亚洲精品一二三四区| 亚洲天堂网中文字| 亚洲欧美自拍偷拍色图| 中文字幕一区二区三区视频| 中文字幕精品三区| 国产精品久久久久久久蜜臀| 国产精品久久久久久久久快鸭 | 欧美日韩免费一区二区三区 | 色婷婷av一区| 成人一区二区三区在线观看| 激情av综合网| 免费一级片91| 久久精品久久99精品久久| 日韩中文字幕91| 日精品一区二区三区| 亚洲国产精品尤物yw在线观看| 伊人一区二区三区| 亚洲丝袜自拍清纯另类| 1024国产精品| 亚洲人成网站在线| 一区二区三区欧美日韩| 国产精品人成在线观看免费| 日韩美女啊v在线免费观看| 中文字幕制服丝袜成人av | 亚洲女爱视频在线| 中文字幕中文字幕中文字幕亚洲无线 | 亚洲精品国产精品乱码不99| 日韩亚洲欧美在线| 在线精品视频一区二区| 欧美无人高清视频在线观看| 欧美日本免费一区二区三区| 欧美日韩视频第一区| 欧美日韩午夜在线| 欧美日韩免费观看一区三区| 欧美日韩国产美| 91麻豆精品91久久久久久清纯| 91精品免费在线观看| 精品久久久久久综合日本欧美| 精品国产欧美一区二区| 国产亚洲精品bt天堂精选| 国产精品青草久久| 亚洲精品成人天堂一二三| 亚洲免费在线看| 亚洲精品欧美专区| 日韩高清在线电影| 精品亚洲成a人| 成人在线视频一区二区| 色综合天天做天天爱| 欧美视频在线不卡| 日韩欧美国产不卡| 中文字幕巨乱亚洲| 亚洲国产日韩a在线播放性色| 日本vs亚洲vs韩国一区三区二区| 国产一区二区精品在线观看| av影院午夜一区| 欧美在线三级电影| 亚洲精品一区二区三区精华液| 综合自拍亚洲综合图不卡区| 亚洲成a天堂v人片| 国产在线一区二区综合免费视频| 99这里只有久久精品视频| 欧美性猛交xxxxxxxx| 亚洲精品在线观看网站| 亚洲乱码精品一二三四区日韩在线| 亚洲成a人在线观看| 国产精品自拍网站| 欧美三级电影网| 日韩精品一区二区三区蜜臀| 国产精品灌醉下药二区| 日韩电影免费在线| eeuss国产一区二区三区| 欧美午夜视频网站| 91精品国产色综合久久ai换脸| 亚洲少妇30p| 久久99精品国产麻豆不卡| av电影在线观看一区| 欧美一级一区二区| 韩国v欧美v亚洲v日本v| 色综合天天综合网天天看片| 欧美亚洲国产一卡| 欧美国产日本韩| 丝袜美腿亚洲色图| 91热门视频在线观看| 欧美高清视频一二三区 | 欧洲国产伦久久久久久久| 欧美色视频在线| 国产欧美一区二区精品婷婷| 久久成人18免费观看| 欧美tickling挠脚心丨vk| 美女任你摸久久| 欧美一级日韩不卡播放免费| 日本va欧美va欧美va精品| 欧美成人在线直播| 国产美女娇喘av呻吟久久| 国产亚洲婷婷免费| 国产精品一区免费视频| 国产色综合久久| 成人午夜免费电影| 亚洲图片你懂的| 在线一区二区观看| 日韩主播视频在线| 精品国产不卡一区二区三区| 国产一区二区三区综合| 日本一区二区三区视频视频| 国产真实乱偷精品视频免| 中文字幕一区不卡| 91国产免费观看| 奇米在线7777在线精品| 精品国产电影一区二区| 成人免费黄色大片| 亚洲精品精品亚洲| 欧美日韩国产高清一区二区三区| 免费成人在线观看视频| 欧美精品一区二区三区四区| 国产老肥熟一区二区三区| 国产精品伦理在线| 欧美伊人久久大香线蕉综合69| 日韩精品电影一区亚洲| 亚洲精品一线二线三线| 国产乱码字幕精品高清av| 国产午夜亚洲精品午夜鲁丝片| 9l国产精品久久久久麻豆| 婷婷久久综合九色综合绿巨人 | 精品视频在线免费| 蜜臀久久久久久久| 国产农村妇女毛片精品久久麻豆| 国产高清一区日本| 欧美激情自拍偷拍| 欧美最猛黑人xxxxx猛交| 久久精品国产**网站演员| 国产精品入口麻豆九色| 欧美午夜在线观看| 国产一区二区剧情av在线| 亚洲精品免费视频| 日韩欧美在线不卡| 成人av资源站| 极品瑜伽女神91| 一区二区三区日韩| 久久久美女毛片| 欧美午夜精品久久久久久孕妇| 国产一区三区三区| 亚洲一区在线播放| 国产亚洲精品7777| 欧美性受极品xxxx喷水| 成人国产精品免费观看视频| 日韩精品国产欧美| 亚洲天堂网中文字| 337p日本欧洲亚洲大胆精品| 欧洲国内综合视频| 成人免费毛片a| 精品一区二区日韩| 首页国产丝袜综合| 国产精品第13页| 精品盗摄一区二区三区| 日韩视频一区二区三区| 日本韩国一区二区三区| 成人精品视频.| 久久精品国产亚洲一区二区三区| 一区二区三区精品在线| 国产精品色哟哟网站| 精品久久人人做人人爱| 在线不卡一区二区| 91在线一区二区三区| 国产一区 二区| 日本美女一区二区三区| 天天综合色天天| 亚洲黄网站在线观看| 国产精品不卡在线| 国产精品无码永久免费888|