答案是使用C++和OpenGL绘制三角形需配置GLFW和GLAD,创建窗口后初始化顶点数据,编写着色器程序,通过VAO和VBO传递顶点,最后在渲染循环中调用glDrawArrays绘制橙色三角形。

用C++结合OpenGL绘制一个三角形,是学习图形渲染的起点。整个过程涉及环境搭建、着色器编写、顶点数据传递和渲染循环等基础步骤。下面一步步说明如何实现。
1. 搭建OpenGL开发环境
在开始前,需要配置好必要的库:
- GLAD:用于加载OpenGL函数指针
- GLFW:创建窗口和处理输入
- GLM(可选):数学计算库,处理向量和矩阵
你可以通过包管理器或官网下载这些库。以Windows + Visual Studio为例,将头文件和lib文件正确链接到项目中。
2. 初始化窗口与OpenGL上下文
使用GLFW创建一个窗口,并初始化GLAD:
立即学习“C++免费学习笔记(深入)”;
#include#include int main() { glfwInit(); glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 3); glfwWindowHint(GLFW_CONTEXT_VERSION_MINOR, 3); glfwWindowHint(GLFW_OPENGL_PROFILE, GLFW_OPENGL_CORE_PROFILE);
GLFWwindow* window = glfwCreateWindow(800, 600, "Draw Triangle", nullptr, nullptr); if (!window) { glfwTerminate(); return -1; } glfwMakeContextCurrent(window); if (!gladLoadGLLoader((GLADloadproc)glfwGetProcAddress)) { return -1; } // 设置视口 glViewport(0, 0, 800, 600);
3. 定义顶点数据与缓冲区
三角形由三个顶点组成。将坐标传入GPU的顶点缓冲区(VBO),并通过顶点数组对象(VAO)管理属性指针:
float vertices[] = {
-0.5f, -0.5f, 0.0f,
0.5f, -0.5f, 0.0f,
0.0f, 0.5f, 0.0f
};
unsigned int VAO, VBO;
glGenVertexArrays(1, &VAO);
glGenBuffers(1, &VBO);
glBindVertexArray(VAO);
glBindBuffer(GL_ARRAY_BUFFER, VBO);
glBufferData(GL_ARRAY_BUFFER, sizeof(vertices), vertices, GL_STATIC_DRAW);
glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, 3 * sizeof(float), (void*)0);
glEnableVertexAttribArray(0);
这里将顶点位置绑定到属性位置0,后续着色器会使用它。
4. 编写并编译着色器
OpenGL需要至少一个顶点着色器和一个片段着色器。简单示例如下:
const char* vertexShaderSource = R"(
#version 330 core
layout (location = 0) in vec3 aPos;
void main() {
gl_Position = vec4(aPos, 1.0);
}
)";
const char* fragmentShaderSource = R"(
version 330 core
out vec4 FragColor;
void main() {
FragColor = vec4(1.0, 0.5, 0.2, 1.0); // 橙色
}
)";
编译着色器并链接成着色程序:
unsigned int vertexShader = glCreateShader(GL_VERTEX_SHADER);
glShaderSource(vertexShader, 1, &vertexShaderSource, nullptr);
glCompileShader(vertexShader);
unsigned int fragmentShader = glCreateShader(GL_FRAGMENT_SHADER);
glShaderSource(fragmentShader, 1, &fragmentShaderSource, nullptr);
glCompileShader(fragmentShader);
unsigned int shaderProgram = glCreateProgram();
glAttachShader(shaderProgram, vertexShader);
glAttachShader(shaderProgram, fragmentShader);
glLinkProgram(shaderProgram);
glDeleteShader(vertexShader);
glDeleteShader(fragmentShader);
5. 渲染循环中绘制三角形
在主循环中使用着色程序并调用绘图命令:
while (!glfwWindowShouldClose(window)) {
glClearColor(0.1f, 0.1f, 0.1f, 1.0f);
glClear(GL_COLOR_BUFFER_BIT);
glUseProgram(shaderProgram);
glBindVertexArray(VAO);
glDrawArrays(GL_TRIANGLES, 0, 3);
glfwSwapBuffers(window);
glfwPollEvents();
}glDrawArrays使用当前绑定的VAO和着色器程序绘制一个三角形。
释放资源后关闭窗口:
glDeleteVertexArrays(1, &VAO);
glDeleteBuffers(1, &VBO);
glDeleteProgram(shaderProgram);
glfwTerminate();
return 0;
基本上就这些。只要配置正确,运行程序就能看到一个橙色三角形出现在窗口中央。这是OpenGL渲染管线的最小完整示例,理解每一步对后续学习纹理、变换、光照等非常关键。











