(三)通过WebGL绘制一个简单的三角形来理解渲染管线

理解 WebGL 绘图原理的关键是了解它的渲染管线。WebGL 渲染管线实际上是由多个阶段组成的,每个阶段都有特定的任务,最终输出的是屏幕上的图像。为了让你能轻松理解这些原理,我将通过一个简单的例子来详细解释。

绘制一个简单的三角形

我们将以绘制一个简单的 2D 三角形为例,通过 WebGL 的渲染管线一步步讲解其中的每个阶段。

1. 准备顶点数据

首先,我们需要一些顶点数据,WebGL 使用这些数据来定义要绘制的图形(比如三角形、矩形等)。在 WebGL 中,顶点是通过数组来表示的。

假设我们的三角形顶点数据如下:

const vertices = [-0.5, -0.5,  // 左下角0.5, -0.5,  // 右下角0.0,  0.5   // 顶部
];

这些顶点会定义一个简单的 2D 三角形。

2. 初始化 WebGL 环境

接下来,我们需要初始化 WebGL 环境,并创建一个 顶点缓冲区,用于存储顶点数据。WebGL 的渲染流程是由 GPU 执行的,我们将这些数据上传到 GPU 内存中。

const canvas = document.getElementById('canvas');
const gl = canvas.getContext('webgl');const vertexBuffer = gl.createBuffer();
gl.bindBuffer(gl.ARRAY_BUFFER, vertexBuffer);
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(vertices), gl.STATIC_DRAW);

通过 gl.createBuffer()gl.bufferData(),我们将顶点数据传输到 GPU。

3. 编写着色器(Shader)

WebGL 使用 着色器(Shader) 来处理顶点和像素(片段)的数据。着色器程序运行在 GPU 上,它们分为两类:

  • 顶点着色器(Vertex Shader):处理顶点数据。
  • 片段着色器(Fragment Shader):处理像素数据。
顶点着色器

顶点着色器的作用是对传入的顶点数据进行变换,输出位置坐标和其他信息。对于我们的三角形,顶点着色器的作用只是简单地传递顶点坐标。

const vertexShaderSource = `attribute vec2 a_position;  // 顶点位置void main(void) {gl_Position = vec4(a_position, 0.0, 1.0);  // 输出坐标}
`;

在顶点着色器中,我们定义了一个 a_position 属性,它会接收每个顶点的坐标,然后使用 gl_Position 输出最终的位置。

片段着色器

片段着色器的作用是为每个像素计算颜色。我们将颜色设置为白色(也可以为其他颜色)。

const fragmentShaderSource = `void main(void) {gl_FragColor = vec4(1.0, 1.0, 1.0, 1.0);  // 白色}
`;

4. 编译和链接着色器

一旦我们编写了顶点着色器和片段着色器,我们需要将它们编译并链接到一起,生成一个可供 WebGL 使用的 着色器程序

// 编译顶点着色器
const vertexShader = gl.createShader(gl.VERTEX_SHADER);
gl.shaderSource(vertexShader, vertexShaderSource);
gl.compileShader(vertexShader);// 编译片段着色器
const fragmentShader = gl.createShader(gl.FRAGMENT_SHADER);
gl.shaderSource(fragmentShader, fragmentShaderSource);
gl.compileShader(fragmentShader);// 创建并链接着色器程序
const shaderProgram = gl.createProgram();
gl.attachShader(shaderProgram, vertexShader);
gl.attachShader(shaderProgram, fragmentShader);
gl.linkProgram(shaderProgram);// 使用该程序
gl.useProgram(shaderProgram);

5. 设置顶点属性

接下来,我们需要将顶点数据传递给着色器。通过 attribute 变量,顶点着色器能够接收到这些数据。我们要告诉 WebGL 如何从缓冲区中提取数据并将其传递到着色器。

const positionAttributeLocation = gl.getAttribLocation(shaderProgram, 'a_position');
gl.vertexAttribPointer(positionAttributeLocation, 2, gl.FLOAT, false, 0, 0);
gl.enableVertexAttribArray(positionAttributeLocation);

这段代码告诉 WebGL 从 vertexBuffer 中提取数据并传递给 a_position,它表示顶点的坐标。

6. 绘制三角形

最后一步是绘制三角形。我们调用 gl.drawArrays() 来绘制图形,它的作用是将顶点数据按照定义的方式绘制到屏幕上。

gl.clear(gl.COLOR_BUFFER_BIT);  // 清空画布
gl.drawArrays(gl.TRIANGLES, 0, 3);  // 绘制三角形,0表示从第一个顶点开始,3表示使用3个顶点

7. WebGL 渲染过程总结

以上步骤就是一个 WebGL 渲染过程的完整流程。为了帮助你更好地理解,下面是 WebGL 渲染管线的主要步骤:

  1. 准备顶点数据:我们创建一个顶点缓冲区,存储图形的顶点信息。
  2. 编写着色器:通过顶点着色器和片段着色器,定义如何处理顶点和像素。
  3. 编译和链接着色器:将编写的着色器代码编译并链接成一个可用的程序。
  4. 传递顶点数据:将顶点数据传递到着色器中,并告诉 WebGL 如何使用这些数据。
  5. 绘制图形:通过调用 gl.drawArrays() 绘制图形,最终在画布上显示出三角形。

8. 渲染管线的关键原理

  • 顶点着色器:负责处理和变换顶点数据(如坐标、颜色、法线等)。它的输出通常是变换后的顶点位置,传递给管线的下一个阶段。
  • 光栅化:将顶点数据转化为片段(像素)。这时图形的形状被“切割”成许多小块。
  • 片段着色器:计算每个像素的最终颜色,例如进行光照计算、纹理映射等。
  • 帧缓冲:片段的输出会被存储到帧缓冲中,最终在屏幕上显示出来。

希望通过这个简单的例子,你能对 WebGL 的渲染管线有一个清晰的认识。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/65350.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【shell编程】报错信息:bash: bad file descriptor(包含6种解决方法)

大家好,我是摇光~ 在运行 Shell 脚本时,遇到 bash: bad file descriptor 错误通常意味着脚本尝试对一个无效或不可用的文件描述符(file descriptor)执行了读写操作。 以下是一些可能导致这个问题的原因、详细案例以及相应的解决…

Kafka3.x KRaft 模式 (没有zookeeper) 常用命令

版本号:kafka_2.12-3.7.0 说明:如有多个地址,用逗号分隔 创建主题 bin/kafka-topics.sh --bootstrap-server localhost:9092 --create --topic demo --partitions 1 --replication-factor 1删除主题 bin/kafka-topics.sh --delete --boots…

Business Cooperation Process

Business Cooperation Process 商务合作基本流程 并不是每个人都能做到言而有信的,因此还是需要流程来约束的。

模式识别-Ch2-分类错误率

分类错误率 最小错误率贝叶斯决策 样本 x x x的错误率: 任一决策都可能会有错误。 P ( error ∣ x ) { P ( w 2 ∣ x ) , if we decide x as w 1 P ( w 1 ∣ x ) , if we decide x as w 2 P(\text{error}|\mathbf{x})\begin{cases} P(w_2|\mathbf{x}), &…

Milvus×全诊通:从导诊到智能超声,如何将人效比翻倍

AI与智慧医疗的结合已是未来发展的必然趋势。近年来,国家卫健委推崇智慧医疗和AI技术,如智能导诊、预问诊、辅助诊断等,以提高医疗服务效率和诊断准确性,改善患者就医体验。 全诊通是一家专注于医疗SaaS和人工智能的公司&#xff…

自动驾驶相关知识学习笔记

一、概要 因为想知道SIL、HIL是什么仿真工具,故而浏览了自动驾驶相关的知识。 资料来源《自动驾驶——人工智能理论与实践》胡波 林青 陈强 著;出版时间:2023年3月 二、图像的分类、分割与检测任务区别 如图所示,这些更高阶的…

springcloud 介绍

Spring Cloud是一个基于Spring Boot的微服务架构解决方案集合,它提供了一套完整的工具集,用于快速构建分布式系统。在Spring Cloud的架构中,服务被拆分为一系列小型、自治的微服务,每个服务运行在其独立的进程中,并通过…

Blazor用户身份验证状态详解

在 Blazor 应用程序中,AuthenticationState 是一个核心概念,用于表示用户的身份验证状态。它提供有关当前用户的信息,例如是否已登录、用户的身份信息(如用户名、角色等)。 AuthenticationState 通常由 Authenticatio…

VAxios

VAxios(或v-axios)是一个基于Axios的Vue插件,旨在让开发者在Vue项目中更方便、快捷地引入和使用Axios。以下是对VAxios的详细介绍: 一、功能与特性 VAxios作为Axios的Vue封装插件,继承了Axios的众多特性,…

什么是 ERP?

目录 企业资源计划(ERP)的定义 ERP与财务管理的区别 ERP基础知识 ERP的业务价值 ERP简史 ERP部署模式:从本地部署到云端 ERP云 — 新的ERP交付模式 迁移至ERP云技术解决方案的7个原因 企业资源计划(ERP)的定义 …

Linux环境下确认并操作 Git 仓库

在软件开发和版本控制中,Git 已成为不可或缺的工具。有时,我们需要确认某个目录是否是一个 Git 仓库,并在该目录中运行脚本。本文将详细介绍如何确认 /usr/local/src/zcxt/backend/policy-system-backend 目录是否是一个 Git 仓库&#xff0c…

【PLL】非线性瞬态性能

频率捕获、跟踪响应,是大信号非线性行为锁相范围内的相位、频率跟踪,不是非线性行为 所以:跟踪,是线性区域;捕获,是大信号、非线性区域 锁定范围:没有周跳(cycle-slipping&#xff0…

QML学习(七) 学习QML时,用好Qt设计器,快速了解各个组件的属性

在初步学习QML时,特别建议看看Qt设计器,先利用Qt Quick设计师的使用,快速的对Qt Quick的各个组件及其常用的属性,有个初步的了解和认识。如果初始学习一上来直接以代码形式开干,很容易一头雾水。而设计器以最直白的所见…

回调函数和工厂模式

回调函数和工厂模式可以结合使用,以实现灵活的对象创建和动态行为。这种结合通常用于需要根据特定条件创建对象并在对象上执行某些操作的场景。以下是如何将回调函数与工厂模式结合的示例和解释。 结合使用的场景 动态对象创建:使用工厂模式创建不同类型…

find 查找文件grep匹配数据

一、find介绍 1. find . -iname "*.txt"查找当前目录下各个文件夹下的txt属性的文件(i忽略大小写)。 2.find . -type f 查找当前目录下各个文件夹下的文件 3.find . -type d 查找当前目录下各个文件夹下的目录 4.find . -type f | xargs grep -ain -E "匹配…

Mac上鸿蒙配置HDC报错:zsh: command not found: hdc -v

这个问题困扰了好久,按照官方文档去配置的,就是会一直报错,没有配置成功,主要原因是官网ide的路径可能和你本地的ide的路径不一致,因为官网的ide版本可能是最新的 一.先查找你本地的toolchains目录在哪里,…

CS·GO搬砖流程详细版

说简单点,就是Steam买了然后BUFF上卖,或许大家都知道这点,但就是一些操作和细节问题没那么明白。我相信,你看完这篇文章以后,至少会有新的认知。 好吧,废话少说,直接上实操! 首先准…

“深入浅出”系列之FFmpeg:(1)音视频开发基础

我的音视频开发大部分内容是跟着雷霄骅大佬学习的,所以笔记也是跟雷老师的博客写的。 一、音视频相关的基础知识 首先播放一个视频文件的流程如下所示: FFmpeg的作用就是将H.264格式的数据转换成YUV格式的数据,然后SDL将YUV显示到电脑屏幕上…

【Linux】Linux开发:GDB调试器与Git版本控制工具指南

Linux相关知识点可以通过点击以下链接进行学习一起加油!初识指令指令进阶权限管理yum包管理与vim编辑器GCC/G编译器make与Makefile自动化构建 在 Linux 开发中,GDB 调试器和 Git 版本控制工具是开发者必备的利器。GDB 帮助快速定位代码问题,G…

【设计模式-2】23 种设计模式的分类和功能

在软件工程领域,设计模式是解决常见设计问题的经典方案。1994 年,Erich Gamma、Richard Helm、Ralph Johnson 和 John Vlissides(四人帮,GoF)在《设计模式:可复用面向对象软件的基础》一书中系统性地总结了…