OpenGL渲染管线概览

翻译自OpenGL Wiki:http://www.opengl.org/wiki/Rendering_Pipeline_Overview,如有错误还请赐教

管线

OpenGL渲染管线按以下方式工作:

1. 准备顶点数组数据并渲染

2. 顶点处理:

1. 每个顶点都要经过顶点着色器处理。每个顶点按所在数据流中的             顺序依次处理为输出顶点;

2. 可选的图元曲面细分阶段;

3. 可选的图元几何着色器处理,输出为一系列基本图元;

3. 顶点后处理,上一阶段的输出被调整或移位到不同的位置

1. 变换反馈在此处进行;

2. 图元裁切,齐次正规化以及视口到窗口的变换;

4. 图元装载

5. 扫描转换与图元参数差值(译注:即光栅化),生成一系列片段

6. 片段着色器处理每一个片段,每个片段生成一系列输出

7. 逐采样点处理

1. 剪刀测试

2. 模板测试

3. 深度测试

4. 混合

5. 逻辑运算

6. 写蒙版

顶点规格化

在顶点规格化的过程中,应用建立一个有序的顶点表并送入管线中。这些顶点定义了图元的边界。

图元是基本的绘图形状,比如三角形、直线和点。具体顶点表如何被解释为图元交于下一阶段处理。

管线的此部分处理一些对象,例如顶点数组对象和顶点缓冲区对象。顶点数组对象定义了每个顶点的数据,而顶点缓冲区对象存储实际的顶点数据。

一个顶点的数据是一系列属性,每个属性是一小集数据,将在下一阶段进行运算。尽管一系列属性确实能够确定一个顶点,但没有规定说明顶点的属性集必须包括位置或者法线。属性数据是完全任意的,在顶点处理阶段才会赋予其唯一的意义。

顶点渲染

一旦顶点数据规格化结束,就通过渲染指令被渲染成为图元。

顶点处理

每一个从原始数据采集来的顶点都必须被处理,这是顶点着色器的职责。它接收来自前一阶段的属性输入,根据一个任意的、由用户定义的程序,将每一个输入顶点转化为单个输出顶点。

不像输入顶点的信息,输出顶点数据要求较少,顶点着色器只必须填写一个位置值,以便送出一个有效的顶点。

顶点处理的一个限制是每个输入顶点必须对应一个特定的输出顶点。又因为顶点着色器的调用不能共享状态,输入属性与输出顶点数据是一一对应的。也就是说,如果在同样的图元中,你用同样的属性输入同样的顶点着色器,就会得到同样的输出顶点数据。这给了着色器优化顶点处理的权利,如果它们能探测出即将处理一个之前处理过的顶点,则可以使用变换后数据缓冲区中已经处理好的数据,从而避免对该顶点重复进行顶点处理。

图元装配

图元装配是收集一系列来自顶点着色器的顶点数据输出,并且将其合成为一个可行的基本图元的过程。用户用来渲染的图元类型决定了处理的方式。

这一处理的输出是一个有序的简单图元(点、线或三角形)序列。例如,如果输入是一个包含12个顶点的三角形条带图元,则输出的是10个三角形。

曲面细分

通过两个着色器阶段和之间的一个固定函数细分器,图元可以被曲面细分化。

几何着色器

除普通的图元装配步骤之外,你还可以使用一个几何着色器。这是一个用户定义的程序用于处理每个输入图元,并返回零或多个输出图元。

几何着色器的输入图元是图元装配的输出图元,故如果你输入一个三角形条带作为一个图元,则几何着色器会将其视为一系列三角形。

然而,还有一些输入图元种类是为几何着色器专门定制的,这些邻接图元给几何着色器一个关于这些图元的更广阔的视角:它们提供了邻接顶点的信息。

几何着色器的输出是零个或多个简单图元,和图元装配的输出类似。几何着色器可以移除图元,或者将单个输入细分成多个输出图元。几何着色器同样可以用来处理顶点值,包括替顶点着色器做一定工作,或者在细分的同时进行插值。几何着色器甚至还能将图元转换为不同的种类:输入点图元可转化为三角形,或者直线转化为点。

变换反馈

几何着色器或图元装配的输出结果被写入一系列专门为此设置的缓冲区对象中,这就称为变换反馈模式:它允许用户通过顶点和几何着色器进行数据变换,并可将结果保存供之后使用。

输出到变换反馈缓冲区的数据是由此步每个图元发出的。

通过放弃光栅化结果,渲染管线至此可以高效地结束。这使变换反馈可能成为了渲染过程的唯一输出。

裁剪和剔除

图元接着被裁剪和适当地剔除。

裁剪意味着处于可见区域内外边界的图元被分割成几个图元。同时,顶点着色器可以在保护空间中定义一些裁剪框并作用于图元,这些裁剪框将对穿过其上的图元进行额外裁剪。

三角形的表面剔除同样发生在此阶段,具体实现可以自由地立即剔除任意不在视区或者完全落于裁剪框边界内部的图元。

通过齐次正规化和视口变换,顶点的位置从裁剪空间转换到了窗口空间,

光栅化

到达此阶段的图元按输入顺序被光栅化,输出是一系列片段。

片段是一个状态集合,用于计算在输出帧缓冲区中的最终数据像素(或者采样点,如果允许多重采样的话)。片段的状态包括它在屏幕中的位置、在允许多重采样情况下采样的覆盖情况,以及一列来自先前顶点或几何着色器输出的任意数据。

最终的数据集通过片段顶点间的数据插值得到,插值的方式通过输出这些值的着色器定义。

片段处理

由光栅化阶段得到的每个片段的数据都被片段着色器处理,其输出是一列要写向颜色缓冲区的颜色值、深度值和模板值。片段着色器不能设定片段的模板数据,但是可以控制颜色及深度值。

逐采样点处理

接着,由片段处理输出的片段数据又历经了一系列步骤。

第一步是不同的剔除检测。如果有模板检测或深度检测则进行,如果失败了,此片段被剔除并不加入到帧缓冲。如果这些检测任意一个失败了,此片段被剔除并不加入到缓冲区。

注意:如果你的片段着色器不填写深度值,也就是使用一般计算得到的深度值,具体实现中可以使用一种称为提早深度测试的优化策略。它在片段处理         前就执行深度(以及模板)检测,因此如果一个片段被剔除了,则无需运行片段着色器。

再次之后,进行混合。对每一个片段颜色值,有一个特定的混合操作,用于其与帧缓冲中对应位置的已经存在的颜色值。

最后,片段数据被写入帧缓冲。蒙版操作允许用户避免写入特定值。颜色、深度、模板写入均可选择开启或关闭蒙版,独立的颜色通道同样可以使用蒙版。

时间: 2024-08-09 14:37:55

OpenGL渲染管线概览的相关文章

OpenGL: 渲染管线理论

http://blog.csdn.net/augusdi/article/details/19934463 学习着色器,并理解着色器的工作机制,就要对OpenGL的固定功能管线有深入的了解. 首先要知道几个OpenGL的术语 渲染(rendering):计算机根据模型(model)创建图像的过程. 模型(model):根据几何图元创建的物体(object). 几何图元:包括点.直线和多边形等,它是通过顶点(vertex)指定的. 最终完成了渲染的图像是由在屏幕上绘制的像素组成的.在内存中,和像素

现代OpenGL渲染管线介绍

原文摘选自 现代OpenGL渲染管线介绍 此文对最新的OpenGL做一个简单的介绍,如有理解错误,敬请指正.英文原文: https://glumpy.github.io/modern-gl.html opengl已经发展了很多年,自从2003年后提出dynamic pipeline(OpenGL 2.0)后发生了重大变化,例如 shader的使用允许直接对GPU操作 在这个版本之前,OpenGL使用固定管线(fixed pipeline),现在仍旧可以找到很多使用固定管线的手册,这篇文件将介绍O

OpenGL渲染管线漫谈

如果把OpenGL看做一个加工机器,它的功能就是把一系列顶点纹理数据可以在屏幕上面显示的像素.这就如同面条机器把一定比例的面和水加工成一根根面条一样.面条机器可以设置面条的宽度和厚度,这可以影响整个加工的面条,就相当于OpenGL可以设置纹理过滤模式,混合模式等全局状态,可以影响到这一帧的像素输出.从glDrawElements开始,OpenGL流水线就开始运作了,它由一系列过程串联而成,其中有些是程序可以操作的,比如顶点片段着色器:有些戏系统根据设置的全局OpenGL状态自动作用的,比如纹理采

统一D3D与OpenGL坐标系统

作者:游蓝海(http://blog.csdn.net/you_lan_hai) DirectX 3D与OpenGL坐标系统的差异性,给我们带来很大的麻烦,让跨平台编程的新手很困惑.最近在做一个跨平台的游戏,仔细看了下两者的矩阵,发现并没有什么大区别,将d3d左手系的矩阵传递给opengl shader完全可以正常工作. 先说一下两者一些概念上的区别:         (1)坐标系统不同 d3d左手坐标系,opengl右手坐标系         (2)矩阵行序不同 d3d行优先,opengl列优

OpenGL 开始学习指南

近期需要做一个涌潮的预报与仿真模拟,为了使模型更具有真实感,且逼真,使用起来更灵活.感觉还是得从基础的OpenGL学习.鉴于Direct3D技术存在的众多不确定性,且评论不太好的原因,决定用OpenGL来做.但是,之前接触的都是一些十分简单的OpenGL的管线变成,预计得舍弃并用现代版的OpenGL的着色语言进行实现. 下面给出一些自己在网上总结的学习OpenGL的一些建议,特别是初学者,可以拿来参考以下. 1.入门与学习资源 入门如果用NEHE,该经典教程确实众所周知,但也意味着老旧,全是固定

OpenGl 坐标转换 (转载)

OpenGl 坐标转换 (转载) 1. OpenGL 渲染管线 OpenGL渲染管线分为两大部分,模型观测变换(ModelView Transformation)和投影变换(Projection Transformation).做个比喻,计算机图形开发就像我们照相一样,目的就是把真实的场景在一张照相纸上表现出来.那么观测变换的过程就像是我们摆设相机的位置,选择好要照的物体,摆好物体的造型.而投影变换就像相机把真实的三维场景显示在相纸上一样.下面就分别详细的讲一下这两个过程. 1.1模型观测变换

基于Cocos2d-x学习OpenGL ES 2.0系列——你的第一个三角形(1)

[本系列转自]http://cn.cocos2d-x.org/tutorial/lists?id=79 前言 在本系列教程中,我会以当下最流行的2D引擎Cocos2d-x为基础,介绍OpenGL ES 2.0的一些基本用法.本系列教程的宗旨是OpenGL扫盲,让大家在使用Cocos2d-x过程中,知其然,更知其所以然.本系列教程不会涉及非常底层的数学原理,同时也不会过多地提及OpenGL本身的一些细节知识.但是我会在每篇文章的最后给出一些参考链接,大家可以顺藤摸瓜,一举Get OpenGL这个新

基于Cocos2d-x学习OpenGL ES 2.0系列——编写自己的shader(2)

在上篇文章中,我给大家介绍了如何在Cocos2d-x里面绘制一个三角形,当时我们使用的是Cocos2d-x引擎自带的shader和一些辅助函数.在本文中,我将演示一下如何编写自己的shader,同时,我们还会介绍VBO(顶点缓冲区对象)和VAO(顶点数组对象)的基本用法. 在编写自己的shader之前,我觉得有必要提一下OpenGL渲染管线. 理解OpenGL渲染管线,对于学习OpenGL非常重要.下面是OpenGL渲染管线的示意图:(图中淡蓝色区域是可以编程的阶段) 此图是从wiki中拿过来的

OpenGL顶点数组

概述 作为在立即模式(glBegin()与glEnd()之间)下指定单个顶点数据的替代,你可以保存顶点数据在一组列表中,包括顶点位置.法线.纹理坐标与颜色信息.并且你可以通过索引数组解引用数组元素绘制选定的几何图元. 看看下面的用立即模式绘制立方体的代码. glBegin(GL_TRIANGLES); // draw a cube with 12 triangles // 前面 ================= glVertex3fv(v0); // v0-v1-v2 glVertex3fv(