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

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

?? mesh.java

?? JAKE2用JAVA寫的queck2的3D游戲開發引擎
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
/* * Mesh.java * Copyright (C) 2003 * * $Id: Mesh.java,v 1.8 2005/06/08 21:27:10 cawe Exp $ *//*Copyright (C) 1997-2001 Id Software, Inc.This program is free software; you can redistribute it and/ormodify it under the terms of the GNU General Public Licenseas published by the Free Software Foundation; either version 2of 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 ofMERCHANTABILITY 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 Licensealong with this program; if not, write to the Free SoftwareFoundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.*/package jake2.render.lwjgl;import jake2.Defines;import jake2.client.VID;import jake2.client.entity_t;import jake2.qcommon.qfiles;import jake2.render.image_t;import jake2.util.Math3D;import java.nio.FloatBuffer;import java.nio.IntBuffer;import org.lwjgl.BufferUtils;import org.lwjgl.opengl.GL11;/** * Mesh *   * @author cwei */public abstract class Mesh extends Light {	// g_mesh.c: triangle model functions	/*	=============================================================	  ALIAS MODELS	=============================================================	*/	static final int NUMVERTEXNORMALS =	162;	float[][] r_avertexnormals = Anorms.VERTEXNORMALS;	float[] shadevector = {0, 0, 0};	float[] shadelight = {0, 0, 0};	// precalculated dot products for quantized angles	static final int SHADEDOT_QUANT = 16;	float[][]	r_avertexnormal_dots = Anorms.VERTEXNORMAL_DOTS;	float[] shadedots = r_avertexnormal_dots[0];	/**	 * GL_LerpVerts	 * @param nverts	 * @param ov	 * @param verts	 * @param move	 * @param frontv	 * @param backv	 */	void GL_LerpVerts(int nverts, int[] ov, int[] v, float[] move, float[] frontv, float[] backv )	{		FloatBuffer lerp = vertexArrayBuf;		lerp.limit((nverts << 2) - nverts); // nverts * 3		int ovv, vv;			//PMM -- added RF_SHELL_DOUBLE, RF_SHELL_HALF_DAM		if ( (currententity.flags & ( Defines.RF_SHELL_RED | Defines.RF_SHELL_GREEN | Defines.RF_SHELL_BLUE | Defines.RF_SHELL_DOUBLE | Defines.RF_SHELL_HALF_DAM)) != 0 )		{			float[] normal;			int j = 0;			for (int i=0 ; i < nverts; i++/* , v++, ov++, lerp+=4 */)			{				vv = v[i];				normal = r_avertexnormals[(vv >>> 24 ) & 0xFF];				ovv = ov[i];				lerp.put(j, move[0] + (ovv & 0xFF)* backv[0] + (vv & 0xFF) * frontv[0] + normal[0] * Defines.POWERSUIT_SCALE);				lerp.put(j + 1, move[1] + ((ovv >>> 8) & 0xFF) * backv[1] + ((vv >>> 8) & 0xFF) * frontv[1] + normal[1] * Defines.POWERSUIT_SCALE);				lerp.put(j + 2, move[2] + ((ovv >>> 16) & 0xFF) * backv[2] + ((vv >>> 16) & 0xFF) * frontv[2] + normal[2] * Defines.POWERSUIT_SCALE); 				j += 3;			}		}		else		{			int j = 0;			for (int i=0 ; i < nverts; i++ /* , v++, ov++, lerp+=4 */)			{				ovv = ov[i];				vv = v[i];								lerp.put(j, move[0] + (ovv & 0xFF)* backv[0] + (vv & 0xFF)*frontv[0]);				lerp.put(j + 1, move[1] + ((ovv >>> 8) & 0xFF)* backv[1] + ((vv >>> 8) & 0xFF)*frontv[1]);				lerp.put(j + 2, move[2] + ((ovv >>> 16) & 0xFF)* backv[2] + ((vv >>> 16) & 0xFF)*frontv[2]);				j += 3;			}		}	}	FloatBuffer colorArrayBuf = BufferUtils.createFloatBuffer(qfiles.MAX_VERTS * 4);	FloatBuffer vertexArrayBuf = BufferUtils.createFloatBuffer(qfiles.MAX_VERTS * 3);	FloatBuffer textureArrayBuf = BufferUtils.createFloatBuffer(qfiles.MAX_VERTS * 2);	boolean isFilled = false;	float[] tmpVec = {0, 0, 0};	float[][] vectors = {		{0, 0, 0}, {0, 0, 0}, {0, 0, 0} // 3 mal vec3_t	};		// stack variable	private final float[] move = {0, 0, 0}; // vec3_t			private final float[] frontv = {0, 0, 0}; // vec3_t	private final float[] backv = {0, 0, 0}; // vec3_t	/**	 * GL_DrawAliasFrameLerp	 * 	 * interpolates between two frames and origins	 * FIXME: batch lerp all vertexes	 */	void GL_DrawAliasFrameLerp(qfiles.dmdl_t paliashdr, float backlerp)	{		qfiles.daliasframe_t frame = paliashdr.aliasFrames[currententity.frame];		int[] verts = frame.verts;		qfiles.daliasframe_t oldframe = paliashdr.aliasFrames[currententity.oldframe];		int[] ov = oldframe.verts;		float	alpha;		if ((currententity.flags & Defines.RF_TRANSLUCENT) != 0)			alpha = currententity.alpha;		else			alpha = 1.0f;		// PMM - added double shell		if ( (currententity.flags & ( Defines.RF_SHELL_RED | Defines.RF_SHELL_GREEN | Defines.RF_SHELL_BLUE | Defines.RF_SHELL_DOUBLE | Defines.RF_SHELL_HALF_DAM)) != 0)			gl.glDisable( GL11.GL_TEXTURE_2D );		float frontlerp = 1.0f - backlerp;		// move should be the delta back to the previous frame * backlerp		Math3D.VectorSubtract (currententity.oldorigin, currententity.origin, frontv);		Math3D.AngleVectors (currententity.angles, vectors[0], vectors[1], vectors[2]);		move[0] = Math3D.DotProduct (frontv, vectors[0]);	// forward		move[1] = -Math3D.DotProduct (frontv, vectors[1]);	// left		move[2] = Math3D.DotProduct (frontv, vectors[2]);	// up		Math3D.VectorAdd (move, oldframe.translate, move);		for (int i=0 ; i<3 ; i++)		{			move[i] = backlerp*move[i] + frontlerp*frame.translate[i];			frontv[i] = frontlerp*frame.scale[i];			backv[i] = backlerp*oldframe.scale[i];		}				// ab hier wird optimiert		GL_LerpVerts( paliashdr.num_xyz, ov, verts, move, frontv, backv );				//gl.glEnableClientState( GL11.GL_VERTEX_ARRAY );		gl.glVertexPointer( 3, 0, vertexArrayBuf );		// PMM - added double damage shell		if ( (currententity.flags & ( Defines.RF_SHELL_RED | Defines.RF_SHELL_GREEN | Defines.RF_SHELL_BLUE | Defines.RF_SHELL_DOUBLE | Defines.RF_SHELL_HALF_DAM)) != 0)		{			gl.glColor4f( shadelight[0], shadelight[1], shadelight[2], alpha );		}		else		{			gl.glEnableClientState( GL11.GL_COLOR_ARRAY );			gl.glColorPointer( 4, 0, colorArrayBuf );			//			// pre light everything			//			FloatBuffer color = colorArrayBuf;			float l;			int size = paliashdr.num_xyz;			int j = 0;			for (int i = 0; i < size; i++ )			{				l = shadedots[(verts[i] >>> 24) & 0xFF];				color.put(j,  l * shadelight[0]);				color.put(j + 1, l * shadelight[1]);				color.put(j + 2, l * shadelight[2]);				color.put(j + 3, alpha);				j += 4;			}		}		gl.glClientActiveTextureARB(GL_TEXTURE0);		gl.glTexCoordPointer( 2, 0, textureArrayBuf);		//gl.glEnableClientState( GL11.GL_TEXTURE_COORD_ARRAY);		int pos = 0;		int[] counts = paliashdr.counts;				IntBuffer srcIndexBuf = null;		FloatBuffer dstTextureCoords = textureArrayBuf;		FloatBuffer srcTextureCoords = paliashdr.textureCoordBuf;		int dstIndex = 0;		int srcIndex = 0;		int count;		int mode;		int size = counts.length;		for (int j = 0; j < size; j++) {			// get the vertex count and primitive type			count = counts[j];			if (count == 0)				break;		// done							srcIndexBuf = paliashdr.indexElements[j];						mode = GL11.GL_TRIANGLE_STRIP;			if (count < 0) {				mode = GL11.GL_TRIANGLE_FAN;				count = -count;			}			srcIndex = pos << 1;			srcIndex--;			for (int k = 0; k < count; k++) {				dstIndex = srcIndexBuf.get(k) << 1;				dstTextureCoords.put(dstIndex, srcTextureCoords.get(++srcIndex));				dstTextureCoords.put(++dstIndex, srcTextureCoords.get(++srcIndex));			}							gl.glDrawElements(mode, srcIndexBuf);			pos += count;		}		// PMM - added double damage shell		if ( (currententity.flags & ( Defines.RF_SHELL_RED | Defines.RF_SHELL_GREEN | Defines.RF_SHELL_BLUE | Defines.RF_SHELL_DOUBLE | Defines.RF_SHELL_HALF_DAM)) != 0 )			gl.glEnable( GL11.GL_TEXTURE_2D );		gl.glDisableClientState( GL11.GL_COLOR_ARRAY );	}				private final float[] point = {0, 0, 0};	/**	 * GL_DrawAliasShadow	 */	void GL_DrawAliasShadow(qfiles.dmdl_t paliashdr, int posenum)	{		float lheight = currententity.origin[2] - lightspot[2];		qfiles.daliasframe_t frame = paliashdr.aliasFrames[currententity.frame];		int[] order = paliashdr.glCmds;		float height = -lheight + 1.0f;				int orderIndex = 0;		int index = 0;		// TODO shadow drawing with vertex arrays		int count;		while (true)		{			// get the vertex count and primitive type			count = order[orderIndex++];			if (count == 0)				break;		// done			if (count < 0)			{				count = -count;				gl.glBegin (GL11.GL_TRIANGLE_FAN);			}			else				gl.glBegin (GL11.GL_TRIANGLE_STRIP);			do			{				index = order[orderIndex + 2] * 3;				point[0] = vertexArrayBuf.get(index);				point[1] = vertexArrayBuf.get(index + 1);				point[2] = vertexArrayBuf.get(index + 2);									point[0] -= shadevector[0]*(point[2]+lheight);				point[1] -= shadevector[1]*(point[2]+lheight);				point[2] = height;				gl.glVertex3f(point[0], point[1], point[2]);				orderIndex += 3;			} while (--count != 0);			gl.glEnd ();		}		}//	TODO sync with jogl renderer. hoz	// stack variable	private final float[] mins = { 0, 0, 0 };	private final float[] maxs = { 0, 0, 0 };	/**	 * R_CullAliasModel	*/	boolean R_CullAliasModel(entity_t e) {		qfiles.dmdl_t paliashdr = (qfiles.dmdl_t) currentmodel.extradata;		if ((e.frame >= paliashdr.num_frames) || (e.frame < 0)) {			VID.Printf(Defines.PRINT_ALL, "R_CullAliasModel " + currentmodel.name + ": no such frame " + e.frame + '\n');			e.frame = 0;		}		if ((e.oldframe >= paliashdr.num_frames) || (e.oldframe < 0)) {			VID.Printf(Defines.PRINT_ALL, "R_CullAliasModel " + currentmodel.name + ": no such oldframe " + e.oldframe + '\n');			e.oldframe = 0;		}		qfiles.daliasframe_t pframe = paliashdr.aliasFrames[e.frame];		qfiles.daliasframe_t poldframe = paliashdr.aliasFrames[e.oldframe];		/*		** compute axially aligned mins and maxs		*/		if (pframe == poldframe) {			for (int i = 0; i < 3; i++) {				mins[i] = pframe.translate[i];				maxs[i] = mins[i] + pframe.scale[i] * 255;			}		} else {			float thismaxs, oldmaxs;			for (int i = 0; i < 3; i++) {				thismaxs = pframe.translate[i] + pframe.scale[i] * 255;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美在线观看你懂的| 国产曰批免费观看久久久| 99re66热这里只有精品3直播| 国产欧美日本一区视频| 91玉足脚交白嫩脚丫在线播放| 中文字幕视频一区| 在线观看91视频| 爽爽淫人综合网网站 | 成人蜜臀av电影| 国产精品伦一区二区三级视频| 91在线一区二区三区| 亚洲一区二区欧美日韩| 欧美日韩国产综合一区二区 | 国产欧美日韩在线看| 99久久综合狠狠综合久久| 亚洲一区二区在线视频| 宅男在线国产精品| 国产精品一区二区久激情瑜伽| 中文字幕一区免费在线观看| 欧美伊人精品成人久久综合97| 青青草97国产精品免费观看| 欧美极品另类videosde| 欧美性xxxxxx少妇| 国产激情视频一区二区在线观看| 亚洲欧美日韩中文字幕一区二区三区| 欧美日韩一区二区三区视频| 久久国产免费看| 亚洲精选免费视频| 精品电影一区二区| 在线看日本不卡| 国产乱国产乱300精品| 一区二区在线观看免费 | 高清不卡一区二区在线| 一区二区三区在线免费视频 | 国产亚洲人成网站| 在线亚洲精品福利网址导航| 久久国产麻豆精品| 亚洲六月丁香色婷婷综合久久 | 欧美一级免费观看| 成人av网站大全| 免费成人深夜小野草| 国产精品国产馆在线真实露脸 | 尤物在线观看一区| 国产视频一区在线观看| 欧美裸体bbwbbwbbw| 高清成人免费视频| 久久精品国产一区二区三| 亚洲午夜成aⅴ人片| 国产精品无圣光一区二区| 日韩一级片网站| 欧美麻豆精品久久久久久| 97精品久久久午夜一区二区三区| 狠狠色丁香久久婷婷综| 日韩极品在线观看| 一区二区三区四区亚洲| 中文字幕乱码日本亚洲一区二区 | 国产精品国产三级国产a| www欧美成人18+| 91精品在线免费| 91久久一区二区| av一二三不卡影片| 国产成人精品一区二| 国内外精品视频| 免费成人av在线播放| 五月激情六月综合| 亚洲小说春色综合另类电影| 亚洲免费高清视频在线| 亚洲免费电影在线| 亚洲精品v日韩精品| 亚洲精品乱码久久久久久黑人 | 丝袜国产日韩另类美女| 亚洲电影在线免费观看| 亚洲狠狠爱一区二区三区| 亚洲自拍偷拍av| 亚洲一区在线播放| 亚洲成人综合网站| 视频一区中文字幕国产| 亚洲高清视频在线| 天堂蜜桃一区二区三区 | 国产精品不卡在线| 国产精品你懂的在线欣赏| 国产三级精品视频| 国产精品天天摸av网| 亚洲欧洲www| 亚洲永久免费av| 天天影视涩香欲综合网| 美国欧美日韩国产在线播放| 免费成人在线网站| 国产高清精品网站| 成人黄色av电影| 色综合色综合色综合色综合色综合 | 亚洲视频一区二区在线| 成人免费在线观看入口| 亚洲一级不卡视频| 蜜臀av性久久久久蜜臀av麻豆 | 亚洲色大成网站www久久九九| 国产精品国产三级国产普通话蜜臀| 亚洲欧美日韩国产另类专区| 亚洲最新视频在线观看| 全国精品久久少妇| 国产精品资源站在线| 95精品视频在线| 91精品国产麻豆国产自产在线| 久久久午夜精品理论片中文字幕| 久久久久久免费| 亚洲乱码精品一二三四区日韩在线| 亚洲午夜精品17c| 国产在线视频不卡二| 成人h动漫精品一区二| 欧美日韩一区二区三区四区| 精品美女一区二区| 亚洲天堂免费看| 亚洲成年人影院| 久久91精品国产91久久小草| 成人美女在线视频| 91精品蜜臀在线一区尤物| 国产视频一区在线观看 | 欧美videofree性高清杂交| 久久久久久久久99精品| 亚洲欧美日韩在线不卡| 激情综合网av| 欧洲精品在线观看| 国产日韩影视精品| 天堂成人国产精品一区| 不卡视频在线看| 欧美一级二级三级蜜桃| 亚洲男人天堂av网| 久久精品国产色蜜蜜麻豆| 日本韩国一区二区| 久久久久97国产精华液好用吗| 亚洲www啪成人一区二区麻豆| 国产精品亚洲а∨天堂免在线| 欧美色窝79yyyycom| 亚洲国产成人午夜在线一区| 青青草原综合久久大伊人精品 | 国产精品乱码久久久久久| 日本特黄久久久高潮| 99v久久综合狠狠综合久久| 欧美www视频| 日本最新不卡在线| 欧美亚一区二区| 国产精品超碰97尤物18| 国产精品综合在线视频| 日韩欧美一级精品久久| 亚洲一区二区在线免费观看视频| 国产大陆精品国产| 精品91自产拍在线观看一区| 日韩有码一区二区三区| 欧美做爰猛烈大尺度电影无法无天| 中文字幕高清一区| 国产福利一区二区| 久久久久99精品一区| 极品美女销魂一区二区三区免费| 制服.丝袜.亚洲.另类.中文| 亚洲一二三四久久| 欧美影院午夜播放| 一区二区视频在线看| 95精品视频在线| 亚洲视频一二三区| 99国产麻豆精品| 亚洲美女视频在线| 91视频免费看| 亚洲精品成人在线| 欧美性淫爽ww久久久久无| 一区二区三区在线不卡| 色婷婷国产精品综合在线观看| 亚洲少妇30p| 在线观看日韩精品| 亚洲国产精品天堂| 欧美日韩电影一区| 日韩av在线免费观看不卡| 欧美福利电影网| 蜜臀久久99精品久久久久宅男 | 欧美xxxx在线观看| 国产综合色精品一区二区三区| 欧美精品一区二区三区在线| 国产美女娇喘av呻吟久久| 欧美精品一区二区三区四区| 黄色精品一二区| 国产精品入口麻豆九色| 成人晚上爱看视频| 中文字幕一区二区三区av| 91小宝寻花一区二区三区| 亚洲一区二区三区影院| 91精品国产欧美一区二区| 激情综合五月天| 中文字幕在线不卡一区 | 久久99精品久久久久久| 国产清纯在线一区二区www| 99久久精品免费| 亚洲二区在线视频| 久久综合狠狠综合久久激情| jizzjizzjizz欧美| 午夜精品免费在线观看| 欧美电影免费观看高清完整版在线| 国模冰冰炮一区二区| 国产精品高清亚洲| 欧美浪妇xxxx高跟鞋交| 国产精品综合一区二区三区| 亚洲免费毛片网站|