glsl着色器学习(六点五)顶点和片元的处理顺序

在WebGL中,顶点和片元的处理顺序遵循着图形渲染管线的流程。

顶点处理阶段

顶点处理阶段是图形渲染管线的起点,在这一阶段,所有与顶点相关的操作都会被执行。

顶点着色器(Vertex Shader)
  • 顶点着色器接收每个顶点的数据,例如顶点坐标,法线,纹理坐标等。
  • 将顶点数据上传到图形硬件的缓冲区。
  • 在顶点着色器中,对这些顶点数据进行变换和运算,例如将顶点从模型空间转换到世界空间、视图空间和裁剪空间。
  • 计算顶点的法线、颜色等其他属性,这些属性可能会传递给片元着色器进行进一步处理
  1. 装配图元
    • 顶点被组合成几何图形,例如点、线、面
    • 如果启用了背面剔除,则会根据顶点顺序判断是否剔除该三角形
  2. 光栅化
    • 将三角形等图元转化成片元(像素的候选者),确定每个片元的位置
    • 顶点着色器输出的数据会被插值到片元级别。比如:三角形顶点之间的颜色或者纹理坐标会被平滑的插值到每个片元

2. 片元处理阶段

片元处理阶段是图形渲染管线的后半部分,专注于处理和计算每个片元的最终颜色

片元着色器
  1. 对每个片元执行片元着色器,计算出片元颜色、深度等属性
  2. 片元着色器会利用从顶点着色器插值过来的数据,例如颜色,纹理坐标等来进行进一步的计算,例如纹理采样,光照计算等。
  3. 深度测试和模板测试
    1. 片元经过深度测试,判断是否被遮挡,深度较大时会被丢弃
    2. 模板测试如果启用,可以控制片元是否通过。
  4. 混合
    1. 如果启用了混合,片元的颜色会与缓冲区已有的颜色进行混合,生成最终的颜色
  5. 写入缓冲区
    1. 最终通过测试的片元颜色会被写入帧缓冲区,成为图像的一部分

总体说来,顶点处理后,确定几何图形的位置和属性,然后进行片元处理,确定每个片元(像素)的颜色和其他属性,最终渲染到屏幕上

相关推荐
Xzh04236 分钟前
AI Agent 学习路线(Java 后端方向)
java·人工智能·学习
做cv的小昊33 分钟前
计算机图形学:【Games101】学习笔记08——光线追踪(辐射度量学、渲染方程与全局光照、蒙特卡洛积分与路径追踪)
图像处理·笔记·学习·计算机视觉·游戏引擎·图形渲染·概率论
星恒随风35 分钟前
C++ 类和对象入门(五):初始化列表、explicit 和 static 成员详解
开发语言·c++·笔记·学习·状态模式
sensen_kiss2 小时前
CPT304 SoftwareEngineeringII 软件工程 2 Pt.8 软件测试 (Software Testing)(上)
学习·软件工程
力学与人工智能2 小时前
PPT分享 | 洛桑联邦理工学院魏震:深度几何学习在工业设计优化中的应用
学习·优化·工业设计·深度几何学习·洛桑联邦理工学院
sensen_kiss4 小时前
CPT304 SoftwareEngineeringII 软件工程 2 Pt.9 软件测试 (Software Testing)(下)
学习·软件工程
wu_ye_m4 小时前
学习c语言第35天 函数声明和定义
c语言·开发语言·学习
清辞8535 小时前
Coze从入门到实战---第一、二章
大数据·人工智能·学习·语言模型
伊布拉西莫5 小时前
【流畅的Python】第20章:并发执行器 — 学习笔记
笔记·python·学习
jinglong.zha5 小时前
LScript-从零基础到商业变现的AI自动化学习平台
运维·学习·自动化