当前位置: 首页 > news >正文

webgl入门实例-07顶点缓冲区基本概念

WebGL 顶点缓冲区 (Vertex Buffer)

顶点缓冲区(Vertex Buffer)是WebGL中存储顶点数据的主要机制,它允许您高效地将大量顶点数据发送到GPU。

基本概念

顶点缓冲区用于存储:

  • 顶点位置坐标
  • 顶点颜色
  • 纹理坐标
  • 法线向量
  • 其他顶点属性数据

创建和使用顶点缓冲区

1. 创建顶点数据

// 示例:三角形的三个顶点,每个顶点包含位置和颜色
const vertices = [// 位置(x,y)    颜色(r,g,b)0.0,  0.5,    1.0, 0.0, 0.0,  // 顶点1 (红色)-0.5, -0.5,    0.0, 1.0, 0.0,  // 顶点2 (绿色)0.5, -0.5,    0.0, 0.0, 1.0   // 顶点3 (蓝色)
];

2. 创建并绑定顶点缓冲区

// 创建缓冲区对象
const vertexBuffer = gl.createBuffer();// 绑定缓冲区为当前使用的ARRAY_BUFFER
gl.bindBuffer(gl.ARRAY_BUFFER, vertexBuffer);// 将数据传入缓冲区
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(vertices), gl.STATIC_DRAW);

3. 设置顶点属性指针

// 获取着色器中属性位置
const positionAttributeLocation = gl.getAttribLocation(program, "a_position");
const colorAttributeLocation = gl.getAttribLocation(program, "a_color");// 启用属性
gl.enableVertexAttribArray(positionAttributeLocation);
gl.enableVertexAttribArray(colorAttributeLocation);// 告诉WebGL如何从缓冲区读取数据
const stride = 5 * Float32Array.BYTES_PER_ELEMENT; // 每个顶点5个浮点数(x,y,r,g,b)// 位置属性
gl.vertexAttribPointer(positionAttributeLocation, // 属性位置2,                        // 每个顶点的大小(2个分量x,y)gl.FLOAT,                 // 数据类型false,                    // 是否归一化stride,                   // 步长(到下一个顶点的字节数)0                         // 偏移量
);// 颜色属性
gl.vertexAttribPointer(colorAttributeLocation,    // 属性位置3,                        // 每个顶点的大小(3个分量r,g,b)gl.FLOAT,                 // 数据类型false,                    // 是否归一化stride,                   // 步长2 * Float32Array.BYTES_PER_ELEMENT // 偏移量(跳过前2个浮点数x,y)
);

4. 绘制图形

// 绘制三角形
gl.drawArrays(gl.TRIANGLES, 0, 3);

顶点缓冲区的类型

WebGL中有两种主要缓冲区类型:

  1. ARRAY_BUFFER - 用于顶点数据
  2. ELEMENT_ARRAY_BUFFER - 用于索引数据(与索引缓冲区配合使用)

使用多个顶点缓冲区

您可以使用多个顶点缓冲区来存储不同类型的顶点属性:

// 位置数据
const positions = [0.0,  0.5,-0.5, -0.5,0.5, -0.5
];// 颜色数据
const colors = [1.0, 0.0, 0.0,0.0, 1.0, 0.0,0.0, 0.0, 1.0
];// 创建位置缓冲区
const positionBuffer = gl.createBuffer();
gl.bindBuffer(gl.ARRAY_BUFFER, positionBuffer);
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(positions), gl.STATIC_DRAW);// 创建颜色缓冲区
const colorBuffer = gl.createBuffer();
gl.bindBuffer(gl.ARRAY_BUFFER, colorBuffer);
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(colors), gl.STATIC_DRAW);

性能考虑

  1. 静态数据:使用gl.STATIC_DRAW表示数据不会或很少改变
  2. 动态数据:使用gl.DYNAMIC_DRAW表示数据会频繁改变
  3. 流数据:使用gl.STREAM_DRAW表示数据每帧都会改变

顶点数组对象(VAO)

在更复杂的应用中,可以使用顶点数组对象来封装顶点属性状态:

const vao = gl.createVertexArray();
gl.bindVertexArray(vao);// 设置所有顶点属性...
// (位置、颜色、纹理坐标等)// 绘制时只需绑定VAO
gl.bindVertexArray(vao);
gl.drawArrays(gl.TRIANGLES, 0, 3);

顶点缓冲区是WebGL渲染的基础,合理使用可以显著提高渲染性能,特别是在处理复杂3D模型时。

http://www.dtcms.com/a/138339.html

相关文章:

  • LabVIEW液压系统远程监控与故障诊断
  • 【创新实训个人博客】前端实现
  • 基于Flask的漏洞挖掘知识库系统设计与实现
  • Java语言实现递归调用算法
  • Java课堂6
  • 组合模式实战:用树形结构管理企业组织与文件系统
  • 【PyTorch】PyTorch中的非线性激活函数详解:原理、优缺点与实战指南
  • 自求导实现线性回归与PyTorch张量详解
  • 【第46节】windows程序的其他反调试手段中篇
  • ubuntu 向右拖动窗口后消失了、找不到了
  • 高通手机抓取sniffer log的方法
  • Python网络爬虫设计(二)
  • C++入门基础:命名空间,缺省参数,函数重载,输入输出
  • vue3 Ts axios 封装
  • Vscode 插件开发
  • 03_Americanas精益管理项目_StarRocks
  • 巧用ChatGPT生成适合小白的Python练习题,助力编程入门
  • 具身智能机器人学习路线全解析
  • Linux网络编程实战:从字节序到UDP协议栈的深度解析与开发指南
  • 游戏数据分析,力扣(游戏玩法分析 I~V)mysql+pandas
  • 识别法院PDF文件特定字段并插入数据库【正则表达式+本地化部署】
  • 锚定效应的应用-独立站优化价格打折显示-《认知偏差手册》
  • 少数服从多数悖论、黑白颠倒与众人孤立现象之如何应对(一)
  • 观察者设计模式详解:解耦通知机制的利器
  • AI+SWAT模型革命性应用!ArcGIS Pro流域水循环/水生态智能模拟实战;SWAT模型下载 安装 运行 建模流程
  • docker登录AWS ECR拉取镜像
  • Langchain构建Agent
  • 使用AI工具打造专业级PPT的完整方案,结合 DeepSeek构思、Kimi生成内容、Napkin优化设计 等工具,分阶段详细说明流程及工具使用
  • 【软件测试】性能测试概念篇
  • 多个路由器互通(静态路由)无单臂路由(简单版)