Unity5 的新旧延迟渲染Deferred Lighting Rendering Path

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处理,网格物体也不能接受阴影,只能用四个
使
用它需要一个支持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 

时间: 2024-10-25 14:05:20

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

延迟渲染 deferred Shading

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

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

请接着上一课继续看. $.Deferred()方法中,有两个对象,一个是deferred对象,一个是promise对象. promise对象有以下几个方法:state,always,then,promise,pipe,done,fail,progress. deferred对象除了有promise对象的所有方法外(通过jQuery.extend( obj, promise ),把promise对象的所有方法复制到deferred对象中),还有其他三个:resolve,reject,notify.

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

Deferred Shading,看过<Gems2> 的应该都了解了.最近很火的星际2就是使用了Deferred Shading. 原帖位置:   http://blog.csdn.net/noslopforever/archive/2009/03/03/3951273.aspx 这篇文章是对GEMS2里<Deferred Shading in S.T.A.L.K.E.R.>(中文译名<S.T.A.L.K.E.R.中的延期着色>,原作者Oles Shishkovtsov

Deferred Shading延迟渲染

Deferred Shading 传统的渲染过程通常为:1)绘制Mesh:2)指定材质:3)处理光照效果:4)输出.传统的过程Mesh越多,光照处理越费时,多光源时就更慢了. 延迟渲染的步骤:1)Pass0先不做光照处理,将Mesh的Position信息和Normal信息绘制到纹理(RenderTargets,D3D支持多向输出):2)Pass1仅绘制屏幕大小的一个四边形,利用之前得到的Position纹理和Normal纹理对有效地区域选择性地进行光照处理,再输出最后的图像. 分析:由于延迟渲染

延迟渲染之由深度重建世界位置

前面一篇文章介绍了混合方式的延迟渲染(Hybrid deferred shading),本文来讲解一下其中的一个细节,由深度构建世界位置,我们这里假定使用D3D9以及左手坐标系. 我在这里介绍两种方式,这两种方式也就跟实现方式有一定的关系. 方法1: 如果我们在第一遍中写深度时使用的是经过透视除法的z值 1 // 第一遍时输出深度 2 float4x4 matViewProjection; 3 struct VS_INPUT 4 { 5 float4 Position : POSITION0;

比较java新旧I/O的性能——以复制大文件为例

package newio; import java.io.*; import java.nio.ByteBuffer; import java.nio.channels.FileChannel; /* * 分别采用新旧I/O包的API复制文件,比较性能 */ public class CopyFileCompara { public void copyFileOld(File from,File to) throws IOException{ //使用传统的I/O流处理(加了缓冲机制) Fil

MySQL新旧版本ORDER BY 处理方法

MySQL 的order by 涉及到三个参数:A. sort_buffer_size 排序缓存.B. read_rnd_buffer_size 第二次排序缓存.C. max_length_for_sort_data 带普通列的最大排序约束. 我来简单说下MySQL的排序规则.假设查询语句select * from tb1 where 1 order by  a ; 字段a没有建立索引:以上三个参数都足够大.MySQL内部有两种排序规则:第一种,是普通的排序.这种排序的特点是节省内存,但是最终会

vue-lazy-render: 延迟渲染大组件,增强页面切换流畅度

最近用element来做项目,在开发的过程中,突然发现页面的操作和切换在数据量大的时候相当卡,后来提了个issue,在furybean解答后才知道,我每个单元格都加了tooltip,会生成大量的节点,造成页面操作卡顿.后来将tooltip去掉,操作流畅多了. 但是,由于我是将页面的数据存在vuex中的,在路由切换回来的时候,发现在数据量大的时候,页面渲染得很慢,大概两三秒才能切换过来,用户体验相当不好. 这时,我就在想,能不能让页面切换完成之后才开始渲染数据量大的组件,用户起码不会感知到路由切换

Flex布局新旧混合写法详解(兼容微信)

flex是个非常好用的属性,如果说有什么可以完全代替 float 和 position ,那么肯定是非它莫属了(虽然现在还有很多不支持 flex 的浏览器).然而国内很多浏览器对 Flex 的支持都不是很好,这里针对微信内置浏览器写了一套兼容写法.下面入正题. 首先还是从两个版本的语法开始讲吧,这里还是假设flex容器为 .box ,子元素为 .item . 旧语法篇 定义容器的display属性 .box{ display: -moz-box; /*Firefox*/ display: -we