當前位置: 首頁>>代碼示例>>Java>>正文


Java Matrix4類代碼示例

本文整理匯總了Java中com.ra4king.opengl.util.math.Matrix4的典型用法代碼示例。如果您正苦於以下問題:Java Matrix4類的具體用法?Java Matrix4怎麽用?Java Matrix4使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


Matrix4類屬於com.ra4king.opengl.util.math包,在下文中一共展示了Matrix4類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: loadCube

import com.ra4king.opengl.util.math.Matrix4; //導入依賴的package包/類
public static float[] loadCube(Vector3 sideLength, Vector3 center, boolean interleaved, boolean vec4, Matrix4 modelMatrix) {
	float[] buffer = vec4 ? (interleaved ? cubeVec4interleaved : cubeVec4) : (interleaved ? cubeVec3interleaved : cubeVec3);
	
	for(int a = 0; a < cubeData.length / 2; a += 3) {
		int position = (a / 3) * ((interleaved ? 3 : 0) + (vec4 ? 4 : 3));
		
		Vector4 pos = new Vector4();
		if(modelMatrix == null) {
			pos.set(center.x() + cubeData[a] * sideLength.x(), center.y() + cubeData[a + 1] * sideLength.y(), center.z() + cubeData[a + 2] * sideLength.z(), 1);
		} else {
			modelMatrix.mult4(new Vector4(center.x() + cubeData[a] * sideLength.x(), center.y() + cubeData[a + 1] * sideLength.y(), center.z() + cubeData[a + 2] * sideLength.z(), 1), pos);
		}
		
		buffer[position + 0] = pos.x();
		buffer[position + 1] = pos.y();
		buffer[position + 2] = pos.z();
	}
	
	return buffer;
}
 
開發者ID:ra4king,項目名稱:LWJGL-OpenGL-Utils,代碼行數:21,代碼來源:PolygonLoader.java

示例2: loadPlane

import com.ra4king.opengl.util.math.Matrix4; //導入依賴的package包/類
public static float[] loadPlane(Vector2 sideLength, Vector3 center, boolean interleaved, boolean vec4, Matrix4 modelMatrix) {
	float[] buffer = vec4 ? (interleaved ? planeVec4interleaved : planeVec4) : (interleaved ? planeVec3interleaved : planeVec3);
	
	for(int a = 0; a < planeData.length / 2; a += 3) {
		int position = (a / 3) * ((interleaved ? 3 : 0) + (vec4 ? 4 : 3));
		
		Vector4 pos = new Vector4();
		if(modelMatrix == null) {
			pos.set(center.x() + cubeData[a] * sideLength.x(), center.y() + cubeData[a + 1] * sideLength.y(), center.z() + cubeData[a + 2], 1);
		} else {
			modelMatrix.mult4(new Vector4(center.x() + cubeData[a] * sideLength.x(), center.y() + cubeData[a + 1] * sideLength.y(), center.z() + cubeData[a + 2], 1), pos);
		}
		
		buffer[position + 0] = pos.x();
		buffer[position + 1] = pos.y();
		buffer[position + 2] = pos.z();
	}
	
	return buffer;
}
 
開發者ID:ra4king,項目名稱:LWJGL-OpenGL-Utils,代碼行數:21,代碼來源:PolygonLoader.java

示例3: render

import com.ra4king.opengl.util.math.Matrix4; //導入依賴的package包/類
public void render() {
	glDisable(GL_DEPTH_TEST);
	glDisable(GL_CULL_FACE);
	glDisable(GL_BLEND);
	
	uiProgram.begin();
	
	glUniform4(uiProgram.getUniformLocation("color"), color.toBuffer());
	glUniformMatrix4(uiProgram.getUniformLocation("projectionMatrix"), false, new Matrix4().clearToOrtho(0, RenderUtils.getWidth(), 0, RenderUtils.getHeight(), 0, 1).toBuffer());
	
	RenderUtils.glBindVertexArray(vao);
	glDrawArrays(GL_LINES, 0, graphOffset / 2);
	glDrawArrays(GL_LINE_STRIP, graphOffset / 2, stepCount);
	RenderUtils.glBindVertexArray(0);
	
	uiProgram.end();
	
	glEnable(GL_BLEND);
	glEnable(GL_CULL_FACE);
	glEnable(GL_DEPTH_TEST);
}
 
開發者ID:ra4king,項目名稱:LWJGL-OpenGL-Utils,代碼行數:22,代碼來源:PerformanceGraph.java

示例4: resized

import com.ra4king.opengl.util.math.Matrix4; //導入依賴的package包/類
@Override
public void resized() {
	super.resized();
	
	Matrix4 persMatrix = new Matrix4().clearToPerspectiveDeg(45, getWidth(), getHeight(), 1, 1000);
	
	glBindBuffer(GL_UNIFORM_BUFFER, projectionUniformBuffer);
	glBufferSubData(GL_UNIFORM_BUFFER, 0, persMatrix.toBuffer());
	glBindBuffer(GL_UNIFORM_BUFFER, 0);
	
	unprojectionData.clear();
	unprojectionData.asFloatBuffer().put(persMatrix.inverse().toBuffer());
	unprojectionData.position(16 * 4);
	unprojectionData.asIntBuffer().put(getWidth()).put(getHeight());
	unprojectionData.position(18 * 4).flip();
	
	glBindBuffer(GL_UNIFORM_BUFFER, unprojectionUniformBuffer);
	glBufferSubData(GL_UNIFORM_BUFFER, 0, unprojectionData);
	glBindBuffer(GL_UNIFORM_BUFFER, 0);
}
 
開發者ID:ra4king,項目名稱:LWJGL-OpenGL-Tutorials,代碼行數:21,代碼來源:Example10_3.java

示例5: setupRotateAxis

import com.ra4king.opengl.util.math.Matrix4; //導入依賴的package包/類
private void setupRotateAxis(Matrix4 m) {
	float angle = computeAngle(2);
	float cos = (float)Math.cos(angle);
	float sin = (float)Math.sin(angle);
	float invCos = 1 - cos;
	
	Vector3 v = new Vector3(1, 1, 1).normalize();
	
	m.clearToIdentity()
			.put(0, v.x() * v.x() + (1 - v.x() * v.x()) * cos)
			.put(4, v.x() * v.y() * invCos - v.z() * sin)
			.put(8, v.x() * v.z() * invCos + v.y() * sin)
			
			.put(1, v.y() * v.x() * invCos + v.z() * sin)
			.put(5, v.y() * v.y() + (1 - v.y() * v.y()) * cos)
			.put(9, v.y() * v.z() * invCos - v.x() * sin)
			
			.put(2, v.z() * v.x() * invCos - v.y() * sin)
			.put(6, v.z() * v.y() * invCos + v.x() * sin)
			.put(10, v.z() * v.z() + (1 - v.z() * v.z()) * cos)
			
			.put(12, 5)
			.put(13, -5)
			.put(14, -25);
}
 
開發者ID:ra4king,項目名稱:LWJGL-OpenGL-Tutorials,代碼行數:26,代碼來源:Example6_3.java

示例6: init

import com.ra4king.opengl.util.math.Matrix4; //導入依賴的package包/類
@Override
public void init() {
	glClearColor(0, 0, 0, 0);
	glClearDepth(1);
	
	smoothInterpolation = loadProgram("example14.2.SmoothVertexColors.vert", "example14.2.SmoothVertexColors.frag");
	linearInterpolation = loadProgram("example14.2.NoCorrectVertexColors.vert", "example14.2.NoCorrectVertexColors.frag");
	
	Matrix4 perspectiveMatrix = new Matrix4().clearToPerspectiveDeg(60, 1, 1, 1, 1000);
	
	smoothInterpolation.program.begin();
	glUniformMatrix4(smoothInterpolation.cameraToClipMatrixUniform, false, perspectiveMatrix.toBuffer());
	linearInterpolation.program.begin();
	glUniformMatrix4(linearInterpolation.cameraToClipMatrixUniform, false, perspectiveMatrix.toBuffer());
	linearInterpolation.program.end();
	
	try {
		realHallway = new Mesh(getClass().getResource("example14.2.RealHallway.xml"));
		fauxHallway = new Mesh(getClass().getResource("example14.2.FauxHallway.xml"));
	} catch(Exception exc) {
		exc.printStackTrace();
		destroy();
	}
}
 
開發者ID:ra4king,項目名稱:LWJGL-OpenGL-Tutorials,代碼行數:25,代碼來源:Example14_2.java

示例7: offsetOrientation

import com.ra4king.opengl.util.math.Matrix4; //導入依賴的package包/類
private void offsetOrientation(Vector3 axis, float angle) {
	angle = angle * (float)Math.PI / 180;
	
	axis.normalize().mult((float)Math.sin(angle / 2));
	
	Quaternion offset = new Quaternion(axis.x(), axis.y(), axis.z(), (float)Math.cos(angle / 2));
	
	switch(offsetRelative) {
		case MODEL_RELATIVE:
			orientation.mult(offset);
			break;
		case WORLD_RELATIVE:
			orientation = offset.mult(orientation);
			break;
		case CAMERA_RELATIVE:
			Matrix4 camMat = calcLookAtMatrix(resolveCamPosition(), camTarget, new Vector3(0, 1, 0));
			Quaternion viewQuat = camMat.toQuaternion();
			orientation = new Quaternion(viewQuat).conjugate().mult(offset).mult(viewQuat).mult(orientation);
			break;
	}
	
	orientation.normalize();
}
 
開發者ID:ra4king,項目名稱:LWJGL-OpenGL-Tutorials,代碼行數:24,代碼來源:Example8_3.java

示例8: calcMatrix

import com.ra4king.opengl.util.math.Matrix4; //導入依賴的package包/類
@Override
@CopyStruct
public Matrix4 calcMatrix() {
	Matrix4 mat = new Matrix4().clearToIdentity();
	
	mat.translate(0, 0, -currView.radius);
	
	Quaternion fullRotation = Utils.angleAxisDeg(currView.degSpinRotation, new Vector3(0, 0, 1)).mult(currView.orient);
	mat.mult(fullRotation.toMatrix(new Matrix4()));
	
	mat.translate(new Vector3(currView.targetPos).mult(-1));
	
	return mat;
}
 
開發者ID:ra4king,項目名稱:LWJGL-OpenGL-Utils,代碼行數:15,代碼來源:MousePoles.java

示例9: render

import com.ra4king.opengl.util.math.Matrix4; //導入依賴的package包/類
public void render(String variation, Matrix4 baseMatrix) {
	Variant v = variants.get(variation);
	if(v == null)
		throw new IllegalArgumentException("Invalid variation");
	
	render(v, baseMatrix);
}
 
開發者ID:ra4king,項目名稱:LWJGL-OpenGL-Utils,代碼行數:8,代碼來源:Scene.java

示例10: setupPlanes

import com.ra4king.opengl.util.math.Matrix4; //導入依賴的package包/類
public void setupPlanes(Matrix4 matrix) {
	getPlane(matrix, 1, planes[Plane.LEFT.ordinal()]);
	getPlane(matrix, -1, planes[Plane.RIGHT.ordinal()]);
	getPlane(matrix, 2, planes[Plane.BOTTOM.ordinal()]);
	getPlane(matrix, -2, planes[Plane.TOP.ordinal()]);
	getPlane(matrix, 3, planes[Plane.NEAR.ordinal()]);
	getPlane(matrix, -3, planes[Plane.FAR.ordinal()]);
}
 
開發者ID:ra4king,項目名稱:LWJGL-OpenGL-Utils,代碼行數:9,代碼來源:RenderUtils.java

示例11: lookAt

import com.ra4king.opengl.util.math.Matrix4; //導入依賴的package包/類
public static Matrix4 lookAt(Vector3 eye, Vector3 center, Vector3 up) {
	Vector3 f = center.copy().sub(eye).normalize();
	up = up.copy().normalize();
	
	Vector3 s = f.cross(up);
	Vector3 u = s.cross(f);
	
	return new Matrix4(new float[] {
			s.x(), u.x(), -f.x(), 0,
			s.y(), u.y(), -f.y(), 0,
			s.z(), u.z(), -f.z(), 0,
			0, 0, 0, 1
	}).translate(eye.copy().mult(-1));
}
 
開發者ID:ra4king,項目名稱:LWJGL-OpenGL-Tutorials,代碼行數:15,代碼來源:Utils.java

示例12: lookAt

import com.ra4king.opengl.util.math.Matrix4; //導入依賴的package包/類
@CopyStruct
public static Matrix4 lookAt(Vector3 eye, Vector3 center, Vector3 up) {
	Vector3 w = new Vector3(center).sub(eye).normalize();
	up = new Vector3(up).normalize();
	
	Vector3 u = w.cross(up, new Vector3());
	Vector3 v = u.cross(w, new Vector3());
	
	return new Matrix4(new float[] {
			u.x(), v.x(), -w.x(), 0,
			u.y(), v.y(), -w.y(), 0,
			u.z(), v.z(), -w.z(), 0,
			0, 0, 0, 1
	}).translate(new Vector3(eye).mult(-1));
}
 
開發者ID:ra4king,項目名稱:LWJGL-OpenGL-Utils,代碼行數:16,代碼來源:Utils.java

示例13: getBulletLightData

import com.ra4king.opengl.util.math.Matrix4; //導入依賴的package包/類
public int getBulletLightData(Matrix4 viewMatrix, FloatBuffer bulletData, int maxBulletCount) {
	final float bulletK = 1f, nonSolidBulletK = 1f;
	
	BulletVectorPair[] bulletVectorPairs = new BulletVectorPair[bulletManager.getBullets().size()];
	for(int a = 0; a < bulletVectorPairs.length; a++)
		bulletVectorPairs[a] = new BulletVectorPair(null, new Vector3());
	sort(bulletManager.getBullets(), viewMatrix, bulletVectorPairs);
	
	int count = 0;
	
	for(int a = bulletVectorPairs.length - 1; a >= 0 && count < maxBulletCount; a--) {
		Bullet b = bulletVectorPairs[a].bullet;
		Vector3 v = bulletVectorPairs[a].vector;
		
		if(v.z() >= 0) {
			continue;
		}
		
		bulletData.put(v.toBuffer());
		bulletData.put(b.getRange());
		bulletData.put(b.getColor().toBuffer());
		bulletData.put((b.isSolid() ? bulletK / (0.1f * b.getSize()) : nonSolidBulletK) / b.getAlpha());
		
		count++;
	}
	
	return count;
}
 
開發者ID:ra4king,項目名稱:OpenGL-Worlds,代碼行數:29,代碼來源:BulletRenderer.java

示例14: sort

import com.ra4king.opengl.util.math.Matrix4; //導入依賴的package包/類
private static void sort(List<Bullet> bullets, Matrix4 viewMatrix, BulletVectorPair[] sortedBullets) {
	if(bullets.size() != sortedBullets.length) {
		throw new IllegalArgumentException("sortedBullets array is invalid length!");
	}
	
	for(int a = 0; a < bullets.size(); a++) {
		Bullet b = bullets.get(a);
		sortedBullets[a].bullet = bullets.get(a);
		viewMatrix.mult3(b.getPosition(), 1.0f, sortedBullets[a].vector);
	}
	
	Arrays.sort(sortedBullets);
}
 
開發者ID:ra4king,項目名稱:OpenGL-Worlds,代碼行數:14,代碼來源:BulletRenderer.java

示例15: render

import com.ra4king.opengl.util.math.Matrix4; //導入依賴的package包/類
public void render(Matrix4 projectionMatrix, MatrixStack modelViewMatrix, FrustumCulling culling) {
	BulletVectorPair[] bulletVectorPairs = new BulletVectorPair[bulletManager.getBullets().size()];
	for(int a = 0; a < bulletVectorPairs.length; a++)
		bulletVectorPairs[a] = new BulletVectorPair(null, new Vector3());
	
	sort(bulletManager.getBullets(), modelViewMatrix.getTop(), bulletVectorPairs);
	
	render(projectionMatrix, modelViewMatrix, bulletVectorPairs, culling);
}
 
開發者ID:ra4king,項目名稱:OpenGL-Worlds,代碼行數:10,代碼來源:BulletRenderer.java


注:本文中的com.ra4king.opengl.util.math.Matrix4類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。