我在OpenGL ES 2.0中有2个VBO和2个IBO。渲染第一个VBO时没有任何问题,但第二个VBO没有渲染。我也没有收到错误。
第一个VBO包含一个带有9个顶点的GL_STATIC_DRAW对象。第二个VBO包含4个顶点以创建一个简单的2D平面,以便我可以将用户界面渲染到其中。
这是我在C中的代码的相关部分。renderBG()
呈现第一个VBO,renderUI()
呈现第二个VBO。我这样做是正确的吗?
void renderBG(OGL_STATE_T *state) {
matIdentity(modelViewMatrix);
matTranslate(modelViewMatrix, 0, 0, -1.0);
_currentRotation = _currentRotation + 0.5;
_currentRotation = fmod(_currentRotation, 360);
matRotate(modelViewMatrix, 0, 0, 45);
matRotate(modelViewMatrix, 0, _currentRotation, 0);
const GLfloat *mvMat = modelViewMatrix;
const GLfloat *pMat = projectionMatrix;
glClearColor(0, 0.05, 0, 1.0);
glClearDepthf(10.0f);
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
glViewport(0,0,state->screen_width, state->screen_height);
glBindBuffer(GL_ARRAY_BUFFER, state->nsVB);
glUniformMatrix4fv(_projectionUniform, 1, 0, pMat);
glUniformMatrix4fv(_modelViewUniform, 1, 0, mvMat);
glVertexAttribPointer(_positionSlot, 3, GL_FLOAT, GL_FALSE, sizeof(Vertex), 0);
glVertexAttribPointer(_colorSlot, 4, GL_FLOAT, GL_FALSE, sizeof(Vertex),
(GLvoid *) (sizeof(float) * 3));
glEnableVertexAttribArray(_positionSlot);
glEnableVertexAttribArray(_colorSlot);
glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, state->nsIB);
glDrawElements(GL_TRIANGLES, sizeof(nsIndices)/sizeof(nsIndices[0]),
GL_UNSIGNED_BYTE, 0);
}
void renderUI(OGL_STATE_T *state) {
matIdentity(modelViewMatrix);
matTranslate(modelViewMatrix, 0, 0, -1.0);
const GLfloat *mvMat2 = modelViewMatrix;
const GLfloat *pMat2 = projectionMatrix;
glViewport(0,0,state->screen_width, state->screen_height);
glBindBuffer(GL_ARRAY_BUFFER, state->uiVB);
glUniformMatrix4fv(_projectionUniform, 1, 0, pMat2);
glUniformMatrix4fv(_modelViewUniform, 1, 0, mvMat2);
glVertexAttribPointer(_positionSlot, 3, GL_FLOAT, GL_FALSE, sizeof(Vertex), 0);
glVertexAttribPointer(_colorSlot, 4, GL_FLOAT, GL_FALSE, sizeof(Vertex),
(GLvoid *) (sizeof(float) * 3));
glEnableVertexAttribArray(_positionSlot);
glEnableVertexAttribArray(_colorSlot);
glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, state->uiIB);
glDrawElements(GL_TRIANGLES, uiIndicesArraySize / uiIndicesElementSize,
GL_UNSIGNED_BYTE, 0);
GLenum err;
if ((err = glGetError()) != GL_NO_ERROR)
printf("There was an error");
}
void render(OGL_STATE_T *state) {
renderBG(state);
renderUI(state);
eglSwapBuffers(state->display, state->surface);
check();
}
修改
以下是一些其他信息。这是在第二个VBO中填充顶点和索引数组的方法:
GLfloat _width = uiWidth;
GLfloat _height = uiHeight;
Vertex uiVertices[] = {
{{-_width,_height,0}, {1,1,1,1}}, // Top left
{{_width,_height,0}, {1,1,1,1}}, // Top right
{{-_width,-_height,0}, {1,1,1,1}}, // Bottom left
{{_width,-_height,0}, {1,1,1,1}} // Bottom right
};
GLubyte uiIndices[] = {
0,1,2,
2,1,3
};
uiVerticesArraySize = sizeof(uiVertices);
uiVerticesElementSize = sizeof(uiVertices[0]);
uiIndicesArraySize = sizeof(uiIndices);
uiIndicesElementSize = sizeof(uiIndices[0]);
printf("%f %f\n", uiVertices[0].Position[0], uiVertices[0].Position[1]);
glGenBuffers(1, &state->uiVB);
glBindBuffer(GL_ARRAY_BUFFER, state->uiVB);
glBufferData(GL_ARRAY_BUFFER, sizeof(uiVertices), uiVertices, GL_STATIC_DRAW);
glGenBuffers(1, &state->uiIB);
glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, state->uiIB);
glBufferData(GL_ELEMENT_ARRAY_BUFFER, sizeof(uiIndices), uiIndices, GL_STATIC_DRAW);
答案 0 :(得分:0)
事实证明,我按顺时针顺序声明了我的索引(思考面向相机的法线)并启用了GL_CULL_FACE。切换指数,对世界都很好。