我尝试了一切,我知道我的程序正在绘制正确的顶点,我基本上将其指向索引,这是主循环
void mainLoop() {
while (!glfwWindowShouldClose(window)) {
glfwSwapBuffers(window);
glEnable(GL_DEPTH_TEST);
glClearColor(0.1, 0.1, 0.3, 1.0);
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
glfwPollEvents();
glFrontFace(GL_CW);
glDisable(GL_CULL_FACE);
glfwGetFramebufferSize(window, &WIDTH, &HEIGHT);
glViewport(1, 1, WIDTH, HEIGHT);
glm::mat4 view = glm::lookAt(
glm::vec3(1.2f, 1.2f, 1.2f),
glm::vec3(0.0f, 0.0f, 0.0f),
glm::vec3(0.0f, 0.0f, 1.0f)
);
glm::mat4 projectionmatrix = glm::perspective(glm::radians(45.0f), 800.0f / 800.0f, 1.0f, 10.0f);
glm::mat4 identitymatrix = glm::mat4(1.0f);
glm::mat4 modelmatrix = identitymatrix;
MVPmatrix = projectionmatrix * view * modelmatrix;
GLint loc = glGetUniformLocation(SHADERPROGRAM, "MVPmatrix");
glUniformMatrix4fv(loc, 1, GL_FALSE, &MVPmatrix[0][0]);
short vertex_index[] = { 2U, 4U, 1U, 8U, 6U, 5U, 5U, 2U, 1U, 6U, 3U, 2U, 3U, 8U, 4U, 1U, 8U, 5U, 2U, 3U, 4U, 8U, 7U, 6U, 5U, 6U, 2U, 6U, 7U, 3U, 3U, 7U, 8U, 1U, 4U, 8U };
glEnableVertexAttribArray(0);
glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, 0, 0);
glBufferData(GL_ELEMENT_ARRAY_BUFFER, sizeof(vertex_index) * sizeof(unsigned short), &vertex_index[0], GL_STATIC_DRAW);
glBufferData(GL_ARRAY_BUFFER, temp_vertices.size() * sizeof(glm::vec3), &temp_vertices[0], GL_STATIC_DRAW);
glUseProgram(SHADERPROGRAM);
glDrawElements(GL_TRIANGLES, sizeof(vertex_index) , GL_UNSIGNED_SHORT, (void*)0);
}
}
我现在真的不知道,并且我已经尝试了很长时间。该指数是从OBJ文件直等都是顶点。另外,我尝试关闭剔除失败,也尝试添加手动索引数量,甚至试图抵消它们。
导入多维数据集的顶点效果很好,但是一旦我尝试进行索引的多维数据集哎呀。
答案 0 :(得分:1)
我在您的代码中发现了2个问题:
1。)元素索引从0而不是1开始。
要么减小vertex_index
数组中的所有顶点印度,要么在temp_vertices
的开头添加一个“虚拟”顶点坐标,以解决该问题。
2。)第二个参数或glDrawElements
是索引的数目,而不是索引缓冲区的大小(以字节为单位):
glDrawElements(GL_TRIANGLES, sizeof(vertex_index), GL_UNSIGNED_SHORT, (void*)0);
glDrawElements(GL_TRIANGLES, sizeof(vertex_index)/sizeof(short), GL_UNSIGNED_SHORT, (void*)0);
但是我建议将索引放在std::vector<short>
中并使用std::vector::size()
。
在设置投影矩阵时,请进一步使用WIDTH
和HEIGHT
,以计算视口的宽高比。
除了您的代码可以正常工作外。我使用了以下投影和视图矩阵
glm::mat4 view = glm::lookAt(
glm::vec3(2.0f, 2.0f, 2.0f), glm::vec3(0.0f, 0.0f, 0.0f), glm::vec3(0.0f, 0.0f, 1.0f));
glm::mat4 projectionmatrix = glm::perspective(
glm::radians(90.0f), (float)WIDTH / (float)HEIGHT, 0.1f, 10.0f);
glPolygonMode(GL_FRONT_AND_BACK, GL_LINE);
要生成以下图像
答案 1 :(得分:0)
我采用了OP提供的值并作了草图:
然后我为其创建了顶点索引并得到:
GLushort vertex_index[] = {
0, 1, 2, 2, 3, 0, // front
0, 4, 5, 5, 1, 0, // right
4, 7, 6, 6, 5, 4, // back
7, 3, 2, 2, 6, 7, // left
0, 3, 7, 7, 4, 0, // bottom
1, 5, 6, 6, 2, 1 // top
};
如果我没记错的话(我牢记三角形的方向),这甚至可以与背面剔除(仅渲染CCW方向的三角形)一起使用,以仅显示在立方体外部。