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

相关推荐
MicroTech202510 小时前
微算法科技(MLGO)研发突破性低复杂度CFG算法,成功缓解边缘分裂学习中的掉队者问题
科技·学习·算法
future141212 小时前
MCU硬件学习
单片机·嵌入式硬件·学习
好奇龙猫12 小时前
日语学习-日语知识点小记-构建基础-JLPT-N3阶段-二阶段(4):文法運用
学习
mtactor12 小时前
投资理财学习笔记
笔记·学习·金融
浮游本尊13 小时前
React 18.x 学习计划 - 第四天:React Hooks深入
前端·学习·react.js
立志成为大牛的小牛14 小时前
数据结构——二十六、邻接表(王道408)
开发语言·数据结构·c++·学习·程序人生
Olrookie15 小时前
若依前后端分离版学习笔记(二十)——实现滑块验证码(vue3)
java·前端·笔记·后端·学习·vue·ruoyi
请你喝好果汁64115 小时前
Conda_bashrc 初始化机制学习笔记
笔记·学习·conda
maxruan16 小时前
PyTorch学习
人工智能·pytorch·python·学习
MYX_30916 小时前
第三章 线型神经网络
深度学习·神经网络·学习·算法