OpenGL ES 3.0 Java用颜色数组绘制顶点(每个顶点有不同的颜色)

Gat*_*nos 2 java android opengl-es glsl opengl-es-3.0

我有线条,我想用数组的颜色来绘制它们。

颜色数组是一个 FloatBuffer,每个顶点都有 RGBA 数据。

我尝试了这种方法,但它不起作用:

着色器代码:

private final String vertexShaderCode =
    "uniform mat4 uMVPMatrix;" +
    "attribute vec4 vPosition;" +
    "void main() {" +
    "  gl_Position = vPosition;" + 
    "}";

private final String fragmentShaderCode =
    "precision mediump float;" +
    "uniform vec4 vColor;" + 
    "void main() {" +
    "  gl_FragColor = vColor;" + 
    "}";
Run Code Online (Sandbox Code Playgroud)

绘制方法:

public void draw(GL10 gl)
{
    GLES30.glUseProgram(mProgram);

    mPositionHandle = GLES30.glGetAttribLocation(mProgram, "vPosition");

    GLES30.glEnableVertexAttribArray(mPositionHandle);

    GLES30.glVertexAttribPointer(mPositionHandle, COORDS_PER_VERTEX, GLES30.GL_FLOAT, false, vertexStride, vertexBuffer);

    gl.glEnableClientState(GL10.GL_COLOR_ARRAY);

    gl.glColorPointer(vertexBufferSize / 4 / 4, GL10.GL_FLOAT, 4*4, colorBuffer);

    GLES30.glDrawArrays(GLES30.GL_LINES, 0, vertexBufferSize / 4 / COORDS_PER_VERTEX);

    GLES30.glDisableVertexAttribArray(mPositionHandle);

    gl.glDisableClientState(GL10.GL_COLOR_ARRAY);
}
Run Code Online (Sandbox Code Playgroud)

我使用 2 个坐标来设置顶点 (COORDS_PER_VERTEX = 2)。

问题是什么?

Rab*_*d76 5

glEnableClientState并且glColorPointer不是 OpenGL ES 的一部分。它们是旧版 OpenGL的一部分,并且已弃用固定功能管道

如果您对颜色使用统一变量,则整条线都会以设置为统一变量的颜色着色:

int color_loc = GLES30.glGetUniformLocation(mProgram, "vColor")
GLES30.glUseProgram(mProgram);
GLES30.glUniform4f(color_loc, 1.0, 0.0, 0.0, 1.0); // red  

mPositionHandle = GLES30.glGetAttribLocation(mProgram, "vPosition");
GLES30.glEnableVertexAttribArray(mPositionHandle);
GLES30.glVertexAttribPointer(mPositionHandle, COORDS_PER_VERTEX, GLES30.GL_FLOAT, false, vertexStride, vertexBuffer);

GLES30.glDrawArrays(GLES30.GL_LINES, 0, vertexBufferSize / 4 / COORDS_PER_VERTEX);
GLES30.glDisableVertexAttribArray(mPositionHandle);
Run Code Online (Sandbox Code Playgroud)


但是,如果你想为每个顶点属性定义不同的颜色属性,那么你必须声明一个颜色属性,就像你为顶点坐标所做的那样。并且您必须将属性从顶点着色器传递到片段着色器:

private final String vertexShaderCode =
    "uniform mat4 uMVPMatrix;" +

    "attribute vec4 aPosition;" +
    "attribute vec4 aColor;" +

    "varying vec4 vColor;" +

    "void main() {" +
    "    vColor      = aColor;" +
    "    gl_Position = aPosition;" + 
    "}";
Run Code Online (Sandbox Code Playgroud)

private final String fragmentShaderCode =
    "precision mediump float;" +

    "varying vec4 vColor;" +

    "void main() {" +
    "    gl_FragColor = vColor;" + 
    "}";
Run Code Online (Sandbox Code Playgroud)

像使用顶点坐标属性一样定义颜色属性:

mPositionHandle = GLES30.glGetAttribLocation(mProgram, "aPosition");
mColorHandle    = GLES30.glGetAttribLocation(mProgram, "aColor");

GLES30.glEnableVertexAttribArray(mPositionHandle);
GLES30.glVertexAttribPointer(mPositionHandle, COORDS_PER_VERTEX, GLES30.GL_FLOAT, false, vertexStride, vertexBuffer);

GLES30.glEnableVertexAttribArray(mColorHandle);
GLES30.glVertexAttribPointer(mColorHandle, 4, GLES30.GL_FLOAT, false, 0, colorBuffer);

GLES30.glDrawArrays(GLES30.GL_LINES, 0, vertexBufferSize / 4 / COORDS_PER_VERTEX);
GLES30.glDisableVertexAttribArray(mPositionHandle);
GLES30.glDisableVertexAttribArray(mColorHandle);
Run Code Online (Sandbox Code Playgroud)