本文整理匯總了Java中android.opengl.GLU.gluUnProject方法的典型用法代碼示例。如果您正苦於以下問題:Java GLU.gluUnProject方法的具體用法?Java GLU.gluUnProject怎麽用?Java GLU.gluUnProject使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類android.opengl.GLU
的用法示例。
在下文中一共展示了GLU.gluUnProject方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: Ray
import android.opengl.GLU; //導入方法依賴的package包/類
public Ray(MatrixGrabber matrixGrabber,int[] viewPort,float xTouch, float yTouch){
float[] temp = new float[4];
float winy =(float)viewPort[3] - yTouch;
int result = GLU.gluUnProject(xTouch, winy, 1f, matrixGrabber.mModelView, 0, matrixGrabber.mProjection, 0, viewPort, 0, temp, 0);
if(result == GL10.GL_TRUE){
farCoords[0] = temp[0] / temp[3] * Cube3.one;
farCoords[1] = temp[1] / temp[3] * Cube3.one;
farCoords[2] = temp[2] / temp[3] * Cube3.one;
}
result = GLU.gluUnProject(xTouch, winy, 0, matrixGrabber.mModelView, 0, matrixGrabber.mProjection, 0, viewPort, 0, temp, 0);
if(result == GL10.GL_TRUE){
nearCoords[0] = temp[0] / temp[3] * Cube3.one;
nearCoords[1] = temp[1] / temp[3] * Cube3.one;
nearCoords[2] = temp[2] / temp[3] * Cube3.one;
}
}
示例2: projectTouchToWorld
import android.opengl.GLU; //導入方法依賴的package包/類
public static Vector3 projectTouchToWorld(int width, int height, float[] modelView, float[] projection, float x, float y) {
int[] view = new int[] {0, 0, width, height};
float[] touch_position = new float[4];
int r = GLU.gluUnProject(x, view[3] - y, 1f,
modelView, 0,
projection, 0,
view, 0,
touch_position, 0);
touch_position[0] /= touch_position[3];
touch_position[1] /= touch_position[3];
touch_position[2] /= touch_position[3];
touch_position[3] /= touch_position[3];
Vector3 rv = new Vector3(touch_position[0], touch_position[1], touch_position[2]);
rv.normalize();
return rv;
}
示例3: getViewRay
import android.opengl.GLU; //導入方法依賴的package包/類
/**
* Get a view {@link com.beyondar.android.util.math.geom.Ray Ray} for the
* screen position (x,y). Use this to object to check if there are any
* {@link com.beyondar.android.world.GeoObject GeoObject} that collide.
*
* @param x
* @param y
* @param ray
*/
public void getViewRay(float x, float y, Ray ray) {
// far eye point
float[] eye = mFloat4ArrayPool.poll();
if (eye == null) {
eye = new float[4];
} else {
eye[0] = eye[1] = eye[2] = eye[3] = 0;
}
GLU.gluUnProject(x, mHeight - y, 0.9f, mMatrixGrabber.mModelView, 0, mMatrixGrabber.mProjection, 0,
viewport, 0, eye, 0);
// fix
if (eye[3] != 0) {
eye[0] = eye[0] / eye[3];
eye[1] = eye[1] / eye[3];
eye[2] = eye[2] / eye[3];
}
// ray vector
ray.setVector((eye[0] - mCameraPosition.x), (eye[1] - mCameraPosition.y),
(eye[2] - mCameraPosition.z));
mFloat4ArrayPool.add(eye);
}
示例4: pointToModelSpace
import android.opengl.GLU; //導入方法依賴的package包/類
private void pointToModelSpace(float x, float y, float[] from, float[] direction) {
float[] mtxMV = new float[16];
Matrix.multiplyMM(mtxMV, 0, renderer.mtxView, 0, cube.mtxModel, 0);
int[] view = {0, 0, getWidth(), getHeight()};
float[] modelSpaceFrom = new float[4], modelSpaceTo = new float[4];
GLU.gluUnProject(x, getHeight() - y, 1.0f, mtxMV, 0,
renderer.mtxProj, 0, view, 0, modelSpaceFrom, 0);
GLU.gluUnProject(x, getHeight() - y, 0.0f, mtxMV, 0,
renderer.mtxProj, 0, view, 0, modelSpaceTo, 0);
for (int i = 0; i < 3; ++i) {
from[i] = modelSpaceFrom[i] / modelSpaceFrom[3];
direction[i] = modelSpaceTo[i] / modelSpaceTo[3] - from[i];
}
}
示例5: Ray
import android.opengl.GLU; //導入方法依賴的package包/類
public Ray(GL10 gl, int width, int height, float xTouch, float yTouch) {
MatrixGrabber matrixGrabber = new MatrixGrabber();
matrixGrabber.getCurrentState(gl);
int[] viewport = {0, 0, width, height};
float[] nearCoOrds = new float[3];
float[] farCoOrds = new float[3];
float[] temp = new float[4];
float[] temp2 = new float[4];
// get the near and far ords for the click
float winx = xTouch, winy = (float) viewport[3] - yTouch;
// Log.d(TAG, "modelView is =" + Arrays.toString(matrixGrabber.mModelView));
// Log.d(TAG, "projection view is =" + Arrays.toString( matrixGrabber.mProjection ));
int result = GLU.gluUnProject(winx, winy, 1.0f, matrixGrabber.mModelView, 0, matrixGrabber.mProjection, 0, viewport, 0, temp, 0);
Matrix.multiplyMV(temp2, 0, matrixGrabber.mModelView, 0, temp, 0);
if (result == GL10.GL_TRUE) {
nearCoOrds[0] = temp2[0] / temp2[3];
nearCoOrds[1] = temp2[1] / temp2[3];
nearCoOrds[2] = temp2[2] / temp2[3];
}
result = GLU.gluUnProject(winx, winy, 0, matrixGrabber.mModelView, 0, matrixGrabber.mProjection, 0, viewport, 0, temp, 0);
Matrix.multiplyMV(temp2, 0, matrixGrabber.mModelView, 0, temp, 0);
if (result == GL10.GL_TRUE) {
farCoOrds[0] = temp2[0] / temp2[3];
farCoOrds[1] = temp2[1] / temp2[3];
farCoOrds[2] = temp2[2] / temp2[3];
}
this.P0 = farCoOrds;
this.P1 = nearCoOrds;
}
示例6: onTouchEvent
import android.opengl.GLU; //導入方法依賴的package包/類
@Override
public boolean onTouchEvent(MotionEvent e) {
switch (e.getAction()) {
case MotionEvent.ACTION_MOVE:
final float screenX = e.getX();
final float screenY = mScreenHeight - e.getY();
final int[] viewport = {
0, 0, mScreenWidth, mScreenHeight
};
float[] resultWorldPos = {
0.0f, 0.0f, 0.0f, 0.0f
};
GLU.gluUnProject(screenX, screenY, 0, mUnprojectViewMatrix, 0, mUnprojectProjMatrix, 0,
viewport, 0, resultWorldPos, 0);
resultWorldPos[0] /= resultWorldPos[3];
resultWorldPos[1] /= resultWorldPos[3];
resultWorldPos[2] /= resultWorldPos[3];
resultWorldPos[3] = 1.0f;
mRenderer.updatePaddlePosition(resultWorldPos[0], resultWorldPos[1]);
break;
case MotionEvent.ACTION_DOWN:
// Only start the game when the user clicks on the screen
State.setGamePaused(false);
break;
}
return true;
}
示例7: setScreenCoordinates
import android.opengl.GLU; //導入方法依賴的package包/類
/**
* Maps screen coordinates to object coordinates
*
* @param x
* @param y
* @param viewportWidth
* @param viewportHeight
* @param eyeZ
*/
public void setScreenCoordinates(float x, float y, int viewportWidth, int viewportHeight, float eyeZ) {
float[] r1 = new float[16];
int[] viewport = new int[]{0, 0, viewportWidth, viewportHeight};
float[] modelMatrix = new float[16];
Matrix.setIdentityM(modelMatrix, 0);
GLU.gluUnProject(x, viewportHeight - y, 0.0f, modelMatrix, 0, mProjMatrix, 0, viewport, 0, r1, 0);
setPosition(r1[0] * eyeZ, r1[1] * -eyeZ, 0);
}
示例8: GetWorldCoords
import android.opengl.GLU; //導入方法依賴的package包/類
/**
* Calculates the transform from screen coordinate
* system to world coordinate system coordinates
* for a specific point, given a camera position.
*
* @param touch Coord point of screen touch, the
* actual position on physical screen (ej: 160, 240)
* @return position in WCS.
*/
public Coord GetWorldCoords(GL10 gl, Coord touch, float z) {
GL11 gl11 = (GL11) gl;
GL11ExtensionPack gl11ext = (GL11ExtensionPack) gl;
int[] viewport = new int[4];
float[] modelview = new float[16];
float[] projection = new float[16];
float winX, winY;
FloatBuffer winZ = FloatBuffer.allocate(4);
gl11.glGetFloatv(gl11.GL_MODELVIEW_MATRIX, modelview, 0); // Retrieve The Modelview Matrix
gl11.glGetFloatv(gl11.GL_PROJECTION_MATRIX, projection, 0);
gl11.glGetIntegerv(gl11.GL_VIEWPORT, viewport, 0);
winX = touch.X;
winY = (float) viewport[3] - touch.Y;
gl11.glReadPixels((int) touch.X, (int) winY, 1, 1, gl11ext.GL_DEPTH_COMPONENT, gl11.GL_FLOAT, winZ);
float[] output = new float[4];
GLU.gluUnProject(winX, winY, winZ.get(), modelview, 0, projection, 0, viewport, 0, output, 0);
//Log.w("WorldCoord", output[0] + " , " + output[1]);
return new Coord(output[0] * Math.abs(transZ), output[1] * Math.abs(transZ));
}
示例9: unproject
import android.opengl.GLU; //導入方法依賴的package包/類
/**
* Get the corresponding near and far vertex for the specified window coordinates
*
* @param mRenderer
* @param rx
* @param ry
* @param rz
* @return the corresponding near and far vertex for the specified window coordinates
*/
public static float[] unproject(ModelRenderer mRenderer, float rx, float ry, float rz) {
float[] xyzw = {0, 0, 0, 0};
ry = (float) mRenderer.getHeight() - ry;
int[] viewport = {0, 0, mRenderer.getWidth(), mRenderer.getHeight()};
GLU.gluUnProject(rx, ry, rz, mRenderer.getModelViewMatrix(), 0, mRenderer.getModelProjectionMatrix(), 0,
viewport, 0, xyzw, 0);
xyzw[0] /= xyzw[3];
xyzw[1] /= xyzw[3];
xyzw[2] /= xyzw[3];
xyzw[3] = 1;
return xyzw;
}
示例10: setScreenCoordinates
import android.opengl.GLU; //導入方法依賴的package包/類
/**
* Maps screen coordinates to object coordinates
*
* @param x
* @param y
* @param viewportWidth
* @param viewportHeight
* @param eyeZ
*/
public void setScreenCoordinates(float x, float y, int viewportWidth, int viewportHeight, float eyeZ) {
float[] r1 = new float[16];
int[] viewport = new int[] { 0, 0, viewportWidth, viewportHeight };
float[] modelMatrix = new float[16];
Matrix.setIdentityM(modelMatrix, 0);
GLU.gluUnProject(x, viewportHeight - y, 0.0f, modelMatrix, 0, mProjMatrix, 0, viewport, 0, r1, 0);
setPosition(r1[0] * eyeZ, r1[1] * -eyeZ, 0);
}