unity5 的render path ,比4的区别就是使用的新的deferred rendering,之前的4的deferred rendering(其实是light prepass)也被保留了下来。

Legacy Deferred Lighting Rendering Path(light prepass)

老 旧的Deferred Rendering Path,使用了light prepass渲染。因为它是老旧的(unity5之前的Deferred Lighting,但是unity5还留着它使用),所以不支持一些新的渲染特性,比如unity5的新pbr shader standard shader,还有新的reflection probes。可以换成新的Deferred Lighting。

好处就是没有对光源个数
限制,因为它把所有光照计算所需要的数据都渲染到了render
target中。所有的光照都是逐像素计算,可以与法线贴图正确交互。所有的光都有cookies和阴影。因为它是逐像素计算光照,所以不像顶点着色多边
形明显,不真实。逐顶点光照,就是在vetext
shader中计算光照颜色,每个顶点计算一次光照,再进行插值。逐像素计算光照就是每个像素都计算光照,在fragement shader中计算。
light prepass渲染中的开销与光找到的像素数量呈正相关,与场景复杂度无关,与光的体积范围相关,与被照亮的物体个数无关。所以,使光的体积变小可以提升性能。
light
prepass渲染不支持抗锯齿,也无法处理半透明物体,半透明物体如图所示将会用forward
rendering处理,网格物体也不能接受阴影,只能用四个camera culling masks,(官方文档解释: You can only
use up to four culling masks. That is, your culling layer mask must at
least contain all layers minus four arbitrary layers, so 28 of the 32
layers must be set. Otherwise you will get graphical artefacts.)
使用它必须定义Shader Model 3.0以上,支持Depth render textures和two-sided stencil buffers。2004年后的大部分的pc都支持light prepass
light prepass的消耗全部来自光照射到物体需要渲染的像素个数,完全不取决于场景复杂度,所以小的点光源,和spot光,或者光照被遮挡,都是消耗很少的(优化可以从此处下手)。为了产生阴影也要渲染几次,所以阴影也有部分开销。

light prepass在unity中需要3个pass
1.    Base Pass:首先计算屏幕空间缓冲信息:depth, normal,和specular power
2.    Lighting pass: 使用上面的缓冲信息在其他的缓冲区计算光照
3.    Final pass: 物体再次渲染,获取上面计算的光照和贴图再加上环境光/自发光等等混合在一起。
过程如下图所示,
 
如果物体的shader不能用light prepass处理,则会用forward rendering处理。

Base Pass
在这个pass中先渲染一遍物体,把view space的 normal和 specular power存在一张 ARGB32 Render Texture中,normal使用agb通道,specular使用a通道。
Base Pass的结果就是把场景信息和一张 Render Texture填充在z buffer中。
Lighting Pass
Lighting
Pass就是通过depth,normal和specular power计算光照。光照在screen
space进行计算,所以消耗与需要计算的时间不取决于场景复杂程度。光照缓冲信息存在一张 ARGB32 Render
Texture中,它包括漫反射光照在rgb通道,高光强度在a通道。光照值用 logarithmic
encode可以有更好的动态范围。当camera 的HDR选项被选择,光照缓冲信息使用ARGBHalf 格式,不使用 logarithmic
encode。
final pass
所有物体再一次全部渲染,获取光照并与贴图和环境光混合计算。Lightmaps也在final pass
中使用。相机离得近的地方进行实时光照,只烘焙 indirect lighting。相机离得远的地方,光全部烘焙。

Deferred Lighting Rendering Path

unity5新的deferred rendering。
最大的好处就是不限制光源数量。所有的光照都是逐像素计算,可以与法线贴图正确交互。所有的光都有cookies和阴影。
使用G-Buffer 的前提是这些数据可以一次性写入多个render target, 即Multiple-Render-Target (MRT).
deferred rendering中的开销与光找到的像素数量呈正相关,与场景复杂度无关,与光的体积范围相关,与被照亮的物体个数无关。所以,使光的体积变小可以提升性能。
deferred rendering不支持抗锯齿,也无法处理半透明物体,半透明物体如图所示将会用forward rendering处理,网格物体也不能接受阴影,只能用四个

延迟渲染不能渲染半透明的原因gpu pro2给出了解释:

In particular, deferred rendering solutions have difficulty representing transparent materials, because information regarding surfaces seen through the material would be discarded. 是因为被discard掉了。

使
用它需要一个支持Multiple Render Targets (MRT)的显卡,必须定义Shader Model 3.0以上,支持Depth
render textures和two-sided stencil buffers。2005年后的大部分的pc都支持deferred
rendering。
deferred rendering的消耗全部来自光照射到物体需要渲染的像素个数,完全不取决于场景复杂度,所以小的点光源,和spot光,或者光照被遮挡,都是消耗很少的(优化可以从此处下手)。为了产生阴影也要渲染几次,所以阴影也有部分开销。

在deferred rendering中经过两个pass
1.  
 G-buffer pass:所有物体先渲染一遍,计算出diffuse color,specular color , smoothness,
world space normal,emission和depth,存在screen space 缓冲信息中。
2.    Lighting pass:增加光照到前面的emission缓冲信息中。
基本如下图所示(unity 在G-buffer中生成的信息比图中要多具体看1)
 
如果物体的shader不能用light prepass处理,则会用forward rendering处理。

默认 g-buffer布局,4个render targetRT0,RT1,RT2,RT3:
RT0, ARGB32 格式: Diffuse color (RGB), 不使用(A).
RT1, ARGB32格式: Specular color (RGB), roughness (A).
RT2, ARGB2101010格式: World space normal (RGB), 不使用(A).
RT3, ARGB32 (non-HDR) 或 ARGBHalf (HDR) 格式: Emission + lighting + lightmaps + reflection probes buffer.
Depth+Stencil buffer.
ARGB32:每个通道8位整型
ARGBHalf
:每个通道16位浮点型(所以在相机HDR模式使用这种格式储存光照可以获得更大动态范围,光照细节更细致。但是有些图形卡不支持浮点型的render
texture,使用需注意,可以用使用SystemInfo.SupportsRenderTextureFormat检查)

所以g-buffer中在无HDR情况下是160bits/像素,有HDR情况下是192/像素。

G-Buffer Pass

个物体都渲染一次,Diffuse, specular, surface smoothness, world space normal,
和emission+ambient+reflections+lightmaps 被渲染进
g-buffer贴图。g-buffer贴图作为材质的全局参数可以被使用(名字叫CameraGBufferTexture0 ..
CameraGBufferTexture3)
Light Pass
在Light Pass中通过g-buffer和depth计算光照,在screen space中计算,所以消耗与需要计算的时间不取决于场景复杂程度。光照信息存储在emission缓冲中。

参考:http://docs.unity3d.com/Manual/RenderTech-DeferredShading.html

http://blog.csdn.net/xoyojank/article/details/4460953

   

                               -----by  wolf96 

Unity5 的新旧延迟渲染Deferred Lighting Rendering Path的更多相关文章

  1. 渲染路径-Unity5 的新旧推迟渲染Deferred Lighting Rendering Path

    Unity5 的新旧延迟渲染Deferred Lighting Rendering Path unity5 的render path ,比4的区别就是使用的新的deferred rendering,之 ...

  2. Deferred shading rendering path翻译

    Overview 概述 When using deferred shading, there is no limit on the number of lights that can affect a ...

  3. 延迟渲染 deferred Shading

    流程: 1.先渲染一遍物体的位置,法线  和颜色  到三张纹理 2.在根据这三张纹理渲染一遍灯光 3.合成颜色图和灯光图  (ssao图) 看上去好像灯光不多,其实我在这里加了200个灯, 每个球代表 ...

  4. 新旧Django版本中urls与path的区别

    from django.conf.urls import url from . import view urlpatterns = [ url(r'^hello$', view.hello),] 新版 ...

  5. jquery源码解析:jQuery延迟对象Deferred(工具方法)详解2

    请接着上一课继续看. $.Deferred()方法中,有两个对象,一个是deferred对象,一个是promise对象. promise对象有以下几个方法:state,always,then,prom ...

  6. Deferred Shading,延迟渲染(提高渲染效率,减少多余光照计算)【转】

    Deferred Shading,看过<Gems2> 的应该都了解了.最近很火的星际2就是使用了Deferred Shading. 原帖位置:   http://blog.csdn.net ...

  7. Deferred Shading(延迟渲染)

    1.简介      在计算机图形学的词典里,Shading表示“对受光物体的渲染”,这个渲染过程包括下面几步[1]: 1) 计算几何多边形(也就是Mesh).      2) 决定表面材质特性,例如法 ...

  8. Deferred Shading延迟渲染

    Deferred Shading 传统的渲染过程通常为:1)绘制Mesh:2)指定材质:3)处理光照效果:4)输出.传统的过程Mesh越多,光照处理越费时,多光源时就更慢了. 延迟渲染的步骤:1)Pa ...

  9. unity5.0新功能

    原作者 只待苍霞 章节1: 先来两个最关心的新功能, 第一章先讲PBS, 第二章讲光影GI.说到PBS, 首先应该想到的是Unity自带的两个新的Shader, 分别是Standard以及Standa ...

随机推荐

  1. (转)PHP中文处理 中文字符串截取(mb_substr)和获取中文字符串字数

    一.中文截取:mb_substr() mb_substr( $str, $start, $length, $encoding ) $str,需要截断的字符串 $start,截断开始处,起始处为0 $l ...

  2. jmeter中webdriver插件,进行自动化压测

    1.下载JMeterPlugins-WebDriver-1.1.2 2.将JMeterPlugins-WebDriver-1.1.2\lib\ext中的*.jar拷贝到D:\apache-jmeter ...

  3. 使用本地光盘安装Microsoft .NET Framework 3.5 for Win8/WinServer2012

    如何使用本地源安装Microsoft .NET Framework 3.5 作为SQL Server 2012的 必要组件,校验组件过程有个小BUG,即使没有安装也通过,但会卡在安装环节(enabli ...

  4. [转]setTimeout() 函数未定义错误

    用 setTimeout("showMe()",1000) 时出现 showMe is not defined 错误.这是由于showMe() 函数不在 setTimeout 调用 ...

  5. SVM对偶形式

    dual svm 对偶SVM linear SVM 可以用二次规划方法解 xn通过非线性转换变成zn SVM配合非线性特征转换 透过large-margin降低模型复杂度 透过特征转换得到弯弯曲曲的边 ...

  6. 理解MySQL——索引与优化(转)

    写 在前面:索引对查询的速度有着至关重要的影响,理解索引也是进行数据库性能调优的起点.考虑如下情况,假设数据库中一个表有10^6条记录,DBMS的页 面大小为4K,并存储100条记录.如果没有索引,查 ...

  7. Linux + C + Epoll实现高并发服务器(线程池 + 数据库连接池)(转)

    转自:http://blog.csdn.net/wuyuxing24/article/details/48758927 一, 背景 先说下我要实现的功能,server端一直在linux平台下面跑,当客 ...

  8. StrongReference

    原创作品:未经本人允许,不得转载前段时间写项目时遇到了一个问题,就是从网络获取图片资源的问题,总是出现OOM异常,经过几天的努力,终于处理的还算是可以使用,OOM的处理一直都是很头疼的问题.对于三级缓 ...

  9. PHPExcel导出excel

    如果导出中文时出现乱码,可以尝试将字符串转换成gb2312,例如下面就把$yourStr从utf-8转换成了gb2312: $yourStr = mb_convert_encoding("g ...

  10. C#中标准Dispose模式的实现

    http://www.cnblogs.com/luminji/archive/2011/03/29/1997812.html 需要明确一下C#程序(或者说.NET)中的资源.简单的说来,C#中的每一个 ...