Android OpenGL教程 二 2D形状画画

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Android OpenGL教程 二 2D形状画画相关的知识,希望对你有一定的参考价值。

首先画个三角形

    private float[] mTriangleArray={
            0.0f,1.0f,0.0f,
            1.0f,-1.0f,0.0f,
            -1.0f,-1.0f,0.0f
    };

gl.glDrawArrays(GL10.GL_TRIANGLES, 0, mTriangleArray.length/3);

然后画个两个三角形拼成一个正方形,把之前的坐标换一下就好了

    private float[] mTriangleArray={
            1.0f,1.0f,0.0f,
            1.0f,-1.0f,0.0f,
            -1.0f,-1.0f,0.0f,
            -1.0f,-1.0f,0.0f,
            -1.0f,1.0f,0.0f,
            1.0f,1.0f,0.0f
    };

看来glDrawArrays是三个三个坐标来画的

我现在使用glDrawElements这个函数来画正方形,这函数不仅可以画多方形,而且还可以画3D

    private float[] mTriangleArray={
            1.0f,1.0f,0.0f,
            1.0f,-1.0f,0.0f,
            -1.0f,-1.0f,0.0f,
            -1.0f,1.0f,0.0f
    };

    private float[] mColor ={
            1.0f,0.0f,0.0f,1.0f,
            1.0f,0.0f,0.0f,1.0f,
            1.0f,0.0f,0.0f,1.0f,
            1.0f,0.0f,0.0f,1.0f
    };
    private byte[] cubeFacets = new byte[]{
            0, 1, 2,
            0, 2, 3
    };

        gl.glVertexPointer(3, GL10.GL_FLOAT, 0, mTriangleBuffer);
        gl.glColorPointer(4, GL10.GL_FLOAT, 0, mColorBuffer);
        gl.glDrawElements(GL10.GL_TRIANGLE_STRIP
                , cubeFacetsBuffer.remaining(),
                GL10.GL_UNSIGNED_BYTE, cubeFacetsBuffer);

这函数的意思是你传他画三个点的坐标组的位置(第一个从0开始,一个坐标组有三个float),比如这个cubeFacets就是说0、1、2三个坐标连起来画个三角形,然后0、2、3坐标画个三角形。

以下是完整代码

public class MainActivity extends Activity {
private GLSurfaceView mGLView;

public void onCreate(Bundle savedInstanceState){
    super.onCreate(savedInstanceState);
    mGLView = new GLSurfaceView(this); //这里使用的是自定义的GLSurfaceView的子类
    mGLView.setRenderer(new GLRenderer());
    setContentView(mGLView);
}

public void onPause(){
    super.onPause();
    mGLView.onPause();
}

public void onResume(){
    super.onResume();
    mGLView.onResume();
}

public class GLRenderer implements GLSurfaceView.Renderer {

    private float[] mTriangleArray={
            1.0f,1.0f,0.0f,
            1.0f,-1.0f,0.0f,
            -1.0f,-1.0f,0.0f,
            -1.0f,1.0f,0.0f
    };

    private float[] mColor ={
            1.0f,0.0f,0.0f,1.0f,
            1.0f,0.0f,0.0f,1.0f,
            1.0f,0.0f,0.0f,1.0f,
            1.0f,0.0f,0.0f,1.0f
    };
    private byte[] cubeFacets = new byte[]{
            0, 1, 2,
            0, 2, 3
    };
    private FloatBuffer mTriangleBuffer;
    private FloatBuffer mColorBuffer;
    ByteBuffer cubeFacetsBuffer;
    public GLRenderer() {

        mTriangleBuffer = floatBufferUtil(mTriangleArray);
        mColorBuffer = floatBufferUtil(mColor);
        cubeFacetsBuffer = ByteBuffer.wrap(cubeFacets);

    }

    @Override
    public void onDrawFrame(GL10 gl) {

        // 清除屏幕和深度缓存
        gl.glClear(GL10.GL_COLOR_BUFFER_BIT | GL10.GL_DEPTH_BUFFER_BIT);

        // 设置当前矩阵模式为模型视图。
        gl.glMatrixMode(GL10.GL_MODELVIEW);
        // 允许设置顶点
        //GL10.GL_VERTEX_ARRAY顶点数组
        gl.glEnableClientState(GL10.GL_VERTEX_ARRAY);
        // 允许设置颜色
        //GL10.GL_COLOR_ARRAY颜色数组
        gl.glEnableClientState(GL10.GL_COLOR_ARRAY);

        // 重置当前的模型观察矩阵
        gl.glLoadIdentity();
        //将三角形在z轴上移动
        gl.glTranslatef(0f, 0.0f, -2.0f);

        // 设置三角形
        gl.glVertexPointer(3, GL10.GL_FLOAT, 0, mTriangleBuffer);
        // 设置三角形颜色
        gl.glColorPointer(4, GL10.GL_FLOAT, 0, mColorBuffer);
        // 绘制三角形
        gl.glDrawElements(GL10.GL_TRIANGLE_STRIP
                , cubeFacetsBuffer.remaining(),
                GL10.GL_UNSIGNED_BYTE, cubeFacetsBuffer);

        // 取消颜色设置
        gl.glDisableClientState(GL10.GL_COLOR_ARRAY);
        // 取消顶点设置
        gl.glDisableClientState(GL10.GL_VERTEX_ARRAY);

        //绘制结束
        gl.glFinish();

    }

    @Override
    public void onSurfaceChanged(GL10 gl, int width, int height) {
        float ratio = (float) width / height;
        // 设置OpenGL场景的大小,(0,0)表示窗口内部视口的左下角,(w,h)指定了视口的大小
        gl.glViewport(0, 0, width, height);
        // 设置投影矩阵
        gl.glMatrixMode(GL10.GL_PROJECTION);
        // 重置投影矩阵
        gl.glLoadIdentity();
        // 设置视口的大小
        gl.glFrustumf(-ratio, ratio, -1, 1, 1, 10);
        //以下两句声明,以后所有的变换都是针对模型(即我们绘制的图形)
        gl.glMatrixMode(GL10.GL_MODELVIEW);
        gl.glLoadIdentity();

    }

    @Override
    public void onSurfaceCreated(GL10 gl, EGLConfig config) {
        // 设置白色为清屏
        gl.glClearColor(1, 1, 1, 1);

    }
}
// 定义一个工具方法,将float[]数组转换为OpenGL ES所需的FloatBuffer
private FloatBuffer floatBufferUtil(float[] arr)
{
    FloatBuffer mBuffer;
    // 初始化ByteBuffer,长度为arr数组的长度*4,因为一个int占4个字节
    ByteBuffer qbb = ByteBuffer.allocateDirect(arr.length * 4);
    // 数组排列用nativeOrder
    qbb.order(ByteOrder.nativeOrder());
    mBuffer = qbb.asFloatBuffer();
    mBuffer.put(arr);
    mBuffer.position(0);
    return mBuffer;
}

}

以上是关于Android OpenGL教程 二 2D形状画画的主要内容,如果未能解决你的问题,请参考以下文章

在 OpenGL 中绘制 2D 形状的轮廓,同时更改线条粗细

OpenGL - 如何使用弹出菜单绘制多个不同的 2D 形状?

旋转使用 OpenGL 绘制的 2D 对象

Android:在运行时更改形状颜色

Android上OpenGL-ES游戏的教程和库[关闭]

使用 OpenGL ES 2.0 绘制 2D 图像