opengl 学习4

现代opengl ,就是一个巨大的状态机。在学习过程中常会听到"opengl上下文"一词。这个词语很容易让新手感到疑惑。不如直接这样理解:

"上下文" = "初始化指定变量" = "顶点缓冲区" + "顶点数据解析 + "着色器"

现代opengl的渲染流程是:我将顶点数据放入缓冲区中,着色器从缓冲区中取数据,并绘制图像。

顶点能够包含若干属性,坐标,纹理,颜色等。这取决于我们如何定义

缓冲区指的是GPU显存

着色器是运行在GPU上得到代码(C++代码运行在CPU上)

设定好上面三样东西(其实不止三样),我就说已经有了opengl上下文环境。其实体现在代码中,就是初始化一系列变量,没错吧?

然后一步步来

  1. 先创建一个缓冲区
cpp 复制代码
  unsigned int a;
  glGenBuffers(1, &a);//新建缓冲区,ID存在变量a中 
  glBindBuffer(GL_ARRAY_BUFFER,a); //绑定缓冲区(设置了一个上下文变量)
  1. 向缓冲区中写数据,供GPU使用
cpp 复制代码
//顶点数据(一行代表一个顶点,只有一个属性"坐标")
float vertices[6] = {
      -0.5f, -0.5f,
      0.5f, -0.5f,
      0.0f,  0.5f
};
//填入数据
glBufferData(GL_ARRAY_BUFFER, sizeof(vertices), vertices, GL_STATIC_DRAW);
  1. 告诉GPU我们的数据在缓冲区中是如何分布的,毕竟缓冲区中的数据本质是字节,opengl并不能区分哪个是顶点,哪个是属性,有几个顶点
cpp 复制代码
 //链接顶点属性(告知GPU,数据是如何排布的)                  
glVertexAttribPointer(0, 2, GL_FLOAT, GL_FALSE, 2 * sizeof(float), (void*)0);
//第一个参数:为顶点属性"坐标"编号为0
//第二个参数:顶点属性的元素个数为2,即(x,y)
//第三个参数:顶点属性中的元素的数据类型
//第五个参数:步长,即从该属性第一次出现的位置,到第二次出现的位置,中间要相隔多远。
  1. 编写着色器,告诉GPU要怎么使用缓冲区内的数据

具体的代码,参考LearnOpenGL-CN

相关推荐
小陶的学习笔记23 分钟前
python~基础
开发语言·python·学习
学编程的闹钟25 分钟前
92【<h1-h6>指定文字大小】
学习
森之鸟29 分钟前
【我的经济学基础01-宏观经济】
学习
我的xiaodoujiao30 分钟前
使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 46--撰写 README项目说明文档文件
python·学习·测试工具·pytest
第七序章36 分钟前
【Linux学习笔记】初识Linux —— 理解gcc编译器
linux·运维·服务器·开发语言·人工智能·笔记·学习
学编程的闹钟44 分钟前
99【html与php的混写】
学习
-Springer-1 小时前
STM32 学习 —— 个人学习笔记5(EXTI 外部中断 & 对射式红外传感器及旋转编码器计数)
笔记·stm32·学习
魔力军1 小时前
Rust学习Day3: 3个小demo实现
java·学习·rust
●VON1 小时前
HarmonyOS应用开发实战(基础篇)Day01-《ArkTS基本知识》
学习·华为·harmonyos·鸿蒙·von
玄同7652 小时前
Python Random 模块深度解析:从基础 API 到 AI / 大模型工程化实践
人工智能·笔记·python·学习·算法·语言模型·llm