0

gl.glTranslatef(0.0f,(float)Math.sin(mTransY), -3.0f);この場合、描画しないだけでこのストロークの四角形を取り除くと、なぜこの場合に理解できませんか? ここに完全なコードがあります(キリル文字のコメントは無視してください-各機能が何をするかを自分で書いただけです)

MainActivity クラス

package opengl.tutorial.one;

import android.app.Activity;
import android.opengl.GLSurfaceView;
import android.os.Bundle;
import android.view.WindowManager;
public class MainActivity extends Activity
{
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
            getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
                WindowManager.LayoutParams.FLAG_FULLSCREEN);
                GLSurfaceView view = new GLSurfaceView(this);
                view.setRenderer(new SquareRenderer(true));
                setContentView(view);
    }
}

スクエアクラス

package opengl.tutorial.one;

import java.nio.ByteBuffer;
import java.nio.ByteOrder;
import java.nio.FloatBuffer;
import java.nio.IntBuffer;
import javax.microedition.khronos.opengles.GL10; //1
import javax.microedition.khronos.opengles.GL11;

public class Square {

    private FloatBuffer mFVertexBuffer;
    private ByteBuffer mColorBuffer;
    private ByteBuffer mIndexBuffer;

    public Square(){

        float vertices[] = {
            -1.0f, -1.0f,//0
            1.0f, -1.0f, //1
            -1.0f, 1.0f, //2
            1.0f, 1.0f  //3
        };//задали положение веришн квадрата по координатам

        byte maxColor=(byte)255;

        byte colors[] = //задали цвет веришнам
        {
            maxColor,maxColor, 0,maxColor,
            maxColor,maxColor, 0,maxColor,
            maxColor,maxColor, 0,maxColor,
            maxColor,maxColor, 0,maxColor,
        };

        byte indices[] = //порядок построения треугольников вершинами
        {
            0, 3, 1, //первый
            0, 2, 3  //второй
        };

        ByteBuffer vbb = ByteBuffer.allocateDirect(vertices.length * 4); //5
        vbb.order(ByteOrder.nativeOrder());

        mFVertexBuffer = vbb.asFloatBuffer();
        mFVertexBuffer.put(vertices);
        mFVertexBuffer.position(0);

        mColorBuffer = ByteBuffer.allocateDirect(colors.length);
        mColorBuffer.put(colors);
        mColorBuffer.position(0);

        mIndexBuffer = ByteBuffer.allocateDirect(indices.length);
        mIndexBuffer.put(indices);
        mIndexBuffer.position(0);
    }

    public void draw(GL10 gl) //6
    {
        gl.glFrontFace(GL11.GL_CW); //выводит полигон по заданной ориентации к экрану. CW - по часовой
        gl.glVertexPointer(2, GL11.GL_FLOAT, 0, mFVertexBuffer); //Установка массива для вершинных координат 
        gl.glColorPointer(4, GL11.GL_UNSIGNED_BYTE, 0, mColorBuffer); //9
        gl.glDrawElements(GL11.GL_TRIANGLES, 6,GL11.GL_UNSIGNED_BYTE, mIndexBuffer);
        gl.glFrontFace(GL11.GL_CCW); //выводит полигон по заданной ориентации к экрану. СCW - против часовой
    }

}

クラス SquareRenderer

パッケージopengl.tutorial.one;

import javax.microedition.khronos.egl.EGL10; //1
import javax.microedition.khronos.egl.EGLConfig;
import javax.microedition.khronos.opengles.GL10;
import android.opengl.GLSurfaceView.Renderer;

import java.lang.Math;

public class SquareRenderer implements Renderer  {

    private boolean mTranslucentBackground;
    private Square mSquare;
    private float mTransY;
    private float mAngle;

    public SquareRenderer(boolean useTranslucentBackground)
    {
        mTranslucentBackground = useTranslucentBackground;//прозрачный фон
        mSquare = new Square(); //новый объект типа квадрат
    }

    public void onDrawFrame(GL10 gl) //4
    {
        gl.glClear(GL10.GL_COLOR_BUFFER_BIT | GL10.GL_DEPTH_BUFFER_BIT); //5
        gl.glMatrixMode(GL10.GL_MODELVIEW); //6
        gl.glLoadIdentity(); //7
        gl.glTranslatef(0.0f,(float)Math.sin(mTransY), -3.0f); //8
        gl.glEnableClientState(GL10.GL_VERTEX_ARRAY); //9
        gl.glEnableClientState(GL10.GL_COLOR_ARRAY);
        mSquare.draw(gl); //10
        mTransY += 0f;
    }

    public void onSurfaceChanged(GL10 gl, int width, int height) //11
    {
        gl.glViewport(0, 0, width, height); //12
        float ratio = (float) width / height;
        gl.glMatrixMode(GL10.GL_PROJECTION); //13
        gl.glLoadIdentity();
        gl.glFrustumf(-ratio, ratio, -1, 1, 1, 10); //14
    }

    public void onSurfaceCreated(GL10 gl, EGLConfig config) //15
    {
        gl.glDisable(GL10.GL_DITHER); //16
        gl.glHint(GL10.GL_PERSPECTIVE_CORRECTION_HINT, GL10.GL_FASTEST);
        if (mTranslucentBackground) //18
        {

        }
        else
        {
            gl.glClearColor(1,1,1,1);
        }
        gl.glEnable(GL10.GL_CULL_FACE); //19
        gl.glShadeModel(GL10.GL_SMOOTH); //20
        gl.glEnable(GL10.GL_DEPTH_TEST); //21
    }

}
4

1 に答える 1

2

正方形全体が z=0 平面にあります。glTranslatef は、z 軸によって視点 3.0 を定義します。この呼び出しがないと、視点の座標は z=0 になるため、正方形自体の内側にある正方形を見ていることになります。

glTranslatef 座標で遊んで、何が起こるか見てみましょう。すべての OpenGL 関数の意味を理解する最善の方法は、それを除外/含めて (まあ、これは既に行っています...)、異なるパラメーター値を設定することです。

glTranslatef の y パラメータは、y 軸を中心とした回転効果を与えます。

于 2012-07-14T14:38:44.253 に答える