可编程渲染管线(Scriptable Render Pipeline, SRP)

可编程渲染管线处理数据的流程可分为以下3大阶段
1. 应用阶段
这个阶段大概会由CPU处理4件事情。首先会对模型数据进行可见性判断。模型数据由顶点位置、法线方向、顶点颜色、纹理坐标等构成。然后会将模型数据加载到显存以提高读取速度。再为每个图元设置常数寄存器和渲染状态。最后为一个渲染图元列表调用DrawCall指令。
图元可以是点、线、三角形。
2. 几何阶段
这个阶段由GPU进行处理,会对每一个需要渲染的图元进行逐顶点、逐多边形处理,最根本的任务是将顶点的模型坐标转换到屏幕空间。
2.1 顶点着色器
顶点着色器的基本任务是将顶点转换到齐次裁剪空间,还可以进行的其他任务有:
- 逐顶点着色操作,如逐顶点光照
- 纹理计算
- 逐顶点蒙皮
- 逐顶点程序式动画(procedural animation)
2.1.1 投影变换

透视投影
在摄像机使用透视投影的时候,为了呈现出近大远小的透视收缩(perspective foreshortening)效果,需要对顶点进行透视投影变换。使用透视投影矩阵进行变换后,并没有进行裁剪,只是使得w值有了意义,为后面的裁剪做准备。


Unity透视投影矩阵(右乘)

会改变空间手系,从右手系变成了左手系,因为Unity的观察空间是右手系,NDC空间是左手系
观察空间中的顶点(x,y,z)透视投影到齐次裁剪空间后变为

透视投影齐次裁剪空间中坐标的w值为 

正交投影
$正交投影远(近)裁剪平面高度=2 \cdot Size$
Unity正交投影矩阵(右乘)

会改变空间手系,从右手系变成了左手系,因为Unity的观察空间是右手系,NDC空间是左手系
观察空间种的顶点(x,y,z)正交投影到齐次裁剪空间后变为 
正交投影齐次裁剪空间中坐标的w值为1

2.2 曲面细分着色器
用于细分图元
2.3 几何着色器
- 几何着色器的功能是修改、剔除、创建图元,可以实现以下效果:
- 阴影体积拉伸(shadow volume extrusion)
- 渲染立方体贴图(cube map)的6个面
- 在网格的轮廓边拉伸毛发的鳍(fur in)
- 从点数据生成例子四边形
- 动态镶嵌
- 把线段分形细分(fractal subdivision)以模拟闪电、布料
- 将数据传到管线开头重新进入管线
- 用例:在顶点着色器内对头发样条的控制点进行物理模拟,在几何着色器内把样条镶嵌成线段,通过流输出将线段传到管线开头重新进入管线进行渲染
2.4 裁剪
裁剪的作用是将每个三角形在平截头体以外的部分切掉,把在平截头体以外的三角形剔除。
满足以下条件的顶点才会被保留下来:

2.5 齐次除法
所谓的齐次除法就是让x、y、z都除以w,这时就可以得到NDC空间中的坐标


上图右边都是OpenGL的NDC,DirectX的NDC也和上图右边类似,但z范围在[0,1]
2.6屏幕映射
视口空间:程序运行窗口构成的空间


矩阵中的X、Y是视口空间原点的屏幕坐标
3. 光栅化阶段
这个阶段由GPU来决定绘制哪些片元以及这些片元的颜色
片元=片段:三角形被栅格化后,其中的每一个小方块都是一个片元,可以看成是还不确定最终是否可以呈现到屏幕上的像素

3.1 三角形设置
这个阶段的任务是找出三角形边界所覆盖的像素
3.2 三角形遍历
这个阶段会对每个三角形进行栅格化,即找出每个三角形覆盖的像素区域。区域中的片元中信息(屏幕坐标、深度值、法线坐标、纹理坐标)由3个顶点数据进行插值(必要时会采用透视校正插值)得到
3.3 提前深度测试
如果用户没有在片元着色器中改变深度或自我丢弃(discard),显卡会自动开启该功能
3.4 片元着色器
用于执行逐像素着色操作,如纹理采样、多重纹理采样、逐像素光照
3.5 逐片元操作
3.5.1 模板测试
if 开启了模板测试 then
比较参考值(使用读取掩码)和模板缓冲区中的模板值(使用读取掩码)
if not 通过模板测试 then
舍弃该片元
end
根据已设置的渲染状态更新模板缓冲区中的值(使用写入掩码)
end
3.5.2 深度测试
if 开启了深度测试 then
比较该片元的深度值和深度缓冲区中的深度值
if 通过了深度测试 then
if 开启了深度写入 then
将深度值写入深度缓冲区
end
else
舍弃该片元
end
else
if 开启了深度写入 then
将深度值写入深度缓冲区
end
end
3.5.3 混合
if 开启了混合 then
用alpha混合函数(alpha blending function)将该片元的颜色值和颜色缓冲区中的颜色值进行混合
else
直接使用该片元的颜色值
end
更新颜色缓冲区中的颜色值
由于还要搬砖,没有办法一一回复私信把学习资料发给大家。我直接整理出来放在下面,觉得有帮助的话可以下载下来用于学习
链接:https://pan.baidu.com/s/1C-9TE9ES9xrySqW7PfpjyQ 提取码:cqmd
感谢各位人才的点赞、收藏、关注
微信搜「三年游戏人」收获一枚有情怀的游戏人,第一时间阅读最新内容,获取优质工作内推
可编程渲染管线(Scriptable Render Pipeline, SRP)的更多相关文章
- Scriptable Render Pipeline
Scriptable Render Pipeline SRP的核心是一堆API集合,使得整个渲染过程及相关配置暴露给用户,使得用户可以精确地控制项目的渲染流程. SRP API为原有的Unity构件提 ...
- Scriptable render pipeline unity
https://www.youtube.com/watch?v=zbjkEQMEShM LWRP https://blogs.unity3d.com/cn/2018/02/21/the-lightwe ...
- Lightweight Render Pipeline
(翻译) Lightweight Render Pipeline (LWRP),轻量级渲染管线,是一个Unity预制的Scriptable Render Pipeline (SRP).LWRP可以为移 ...
- 1.5:Unity Render Pipeline
文章著作权归作者所有.转载请联系作者,并在文中注明出处,给出原文链接. 本系列原更新于作者的github博客,这里给出链接. 这一节主要是为上一节中没有提到的一些概念作补充. 上一节提到了Unity中 ...
- 聊聊2018.2的Scriptable Build Pipeline以及构建Assetbundle
0x00 前言 在这篇文章中,我们选择了过去几周Unity官方社区交流群以及UUG社区群中比较有代表性的几个问题,总结在这里和大家进行分享.主要涵盖了Scriptable Build Pipeline ...
- [Unity] Shader Graph Error 当前渲染管道与此主节点不兼容(The current render pipeline is not compatible with this master node)
Shader Graph Error : The current render pipeline is not compatible with this master node 问题产生环境: Un ...
- 1.3:Render Pipeline and GPU Pipeline
文章著作权归作者所有.转载请联系作者,并在文中注明出处,给出原文链接. 本系列原更新于作者的github博客,这里给出链接. 在学习SubShader之前,我们有必要对 Render Pipeline ...
- Real-Rime Rendering (1) - 渲染管线(Rendering Pipeline)
提要 渲染管线是实时渲染中最重要的部分,它的最主要的任务就是在给定一个虚拟的场景,包括相机,object,灯光,纹理等等,生成一副2D的图像. 最基础的渲染管线如下图所示: 主要的阶段包括三个:App ...
- OpenGLES 2.0 可编程渲染管线
OpenGL ES 2.0 与 OpenGL ES 1.x 渲染管线的最大区别就是: 顶点着色器.片元着色器是可编程的,替代了原来的固定管线的很多功能.
随机推荐
- [HNOI2016]最小公倍数 (可回退并查集,回滚莫队)
题面 题目链接 题目描述 给定一张 N N N 个顶点 M M M 条边的无向图(顶点编号为 1 , 2 , - , n 1,2,\ldots,n 1,2,-,n),每条边上带有权值.所有权值都可以分 ...
- FFT快速傅立叶变换:解析wav波频图、Time Domain、Frequency Domain
您好,此教程将教大家使用scipy.fft分析wav文件的波频图.Time Domain.Frequency Domain. 实际案例:声音降噪,去除高频. 结果: 波频图: Time Domain:
- Python入门系列(二)语法风格
python缩进 Python使用缩进来表示代码块,例如 if 5 > 2: print("Five is greater than two!") 如果跳过缩进,Python ...
- 常用的SSH,你了解多少?(长文警告)
1.SSH工作原理 从ssh的加密方式说开去,看下文 1.1.对称加密 客户端和服务端采用相同的密钥进行数据的加解密,很难保证密钥不丢失,或者被截获.隐藏着中间人攻击的风险 如果攻击者插在用户与远程主 ...
- 完全解析Array.apply(null, { length: 1000 })
Array.apply(null, { length: 1000 }) 点击打开视频讲解更加详细 在阅读VueJS教程时有这么段demo code: render: function (createE ...
- Helm安装ingress-nginx-4.1.4
Application version 1.2.1 Chart version 4.1.4 获取chart包 helm fetch ingress-nginx/ingress-nginx --vers ...
- 【长文详解】TypeScript、Babel、webpack以及IDE对TS的类型检查
只要接触过ts的前端同学都能回答出ts是js超集,它具备静态类型分析,能够根据类型在静态代码的解析过程中对ts代码进行类型检查,从而在保证类型的一致性.那,现在让你对你的webpack项目(其实任意类 ...
- 学会Linux,看完这篇就行了!
转载请注明出处️ 作者:测试蔡坨坨 原文链接:caituotuo.top/797ab07d.html 你好,我是测试蔡坨坨. 对于测试同学来说,Linux基本属于必学必会内容,招聘要求中基本都会出现L ...
- 清理rook-ceph
官方步骤文档:https://rook.io/docs/rook/v1.8/ceph-teardown.html 请注意需要清理的以下资源: rook-ceph namespace: The Rook ...
- 2. 在 Kubernetes 上安装 Gitlab
总结: 所需要的三个yaml文件的下载地址:https://files.cnblogs.com/files/sanduzxcvbnm/k8s-gitlab.zip Gitlab官方提供了 Helm 的 ...