#define GLEW_STATIC
#include <GL\glew.h>
#include <GLFW\glfw3.h>
#include <GL\glew.h>
#include <glm.hpp>
#include <iostream>
#include <fstream>
#include <string>
#define WIDTH 800
#define HEIGHT 600
#define TITLE "Dynamic"
GLFWwindow* window;
int vaoID;
float vertices[] = {-0.5f, 0.5f, 0, -0.5f, -0.5f, 0, 0.5f, 0.5f, 0, 0.5f, 0.5f, 0, -0.5f, -0.5f, 0, 0.5f, -0.5f, 0};
void loadToVAO(float vertices[]);
void update() {
loadToVAO(vertices);
while (!glfwWindowShouldClose(window)) {
glfwPollEvents();
glClear(GL_COLOR_BUFFER_BIT);
glClearColor(1, 0, 0, 1);
glDrawArrays(GL_TRIANGLES, 0, 6);
glfwSwapBuffers(window);
}
}
int main() {
if (!glfwInit())
std::cout << "Couldn't initialize GLFW!" << std::endl;
window = glfwCreateWindow(WIDTH, HEIGHT, TITLE, NULL, NULL);
glfwMakeContextCurrent(window);
glfwSwapInterval(1);
if (GLEW_OK != glewInit())
std::cout << "GLEW fucked up!" << std::endl;
std::cout << "Your GL version: " << glGetString(GL_VERSION) << std::endl;
glEnable(GL_CULL_FACE);
glCullFace(GL_BACK);
update();
}
void loadShaders() {
}
void loadToVAO(float vertices[]) {
GLuint vboID;
GLuint vaoID;
glGenBuffers(1, &vboID);
glBindBuffer(GL_ARRAY_BUFFER, vboID);
glBufferData(GL_ARRAY_BUFFER, sizeof(vertices) * 8, vertices, GL_STATIC_DRAW);
glGenVertexArrays(1, &vaoID);
glBindVertexArray(vaoID);
std::cout << vaoID << std::endl;
glVertexAttribPointer(0, 3, GL_FLOAT, false, 0, 0);
glEnableVertexAttribArray(0);
}
这是我创建和渲染包含具有顶点位置的VBO的VAO的代码。但不幸的是它不起作用。它绘制三角形而不是四边形。但是当我在while循环之前将loadToVAO函数的代码放在update函数中时,它可以工作。
答案 0 :(得分:3)
sizeof
运算符始终返回基础类型的大小。将loadToVAO
的内容复制到更新功能时,sizeof(vertices)
基本上是sizeof(float[18])
,这是数组的总大小。
但在loadToVAO
内,sizeof(vertices)
将函数参数vertices
作为输入,而不是全局变量。由于C ++中未定义大小的数组参数被视为相同类型的点,我们在这里:
sizeof(vertices) == sizeof(float[]) == sizeof(float*)
这是指针(4或8)的大小,而不再是数据的大小。
要解决此问题,您可以将数组的大小也传递给函数,这是C的方法。更现代的方法是首先使用std::array
或std::vector
来存储数据。
编辑:第二次看,我看到你首先使用了sizeof(vertices) * 8
。我不确定8来自哪里,因为你既没有8个元素也没有浮点数大小为8个字节。