unity5中减少Draw Calls(SetPass Calls)
 
我一直工作于unity5支持的Standard Shader(标准着色器)上,并且做了一些关于如何有效地减少draw call的测试,在Unity5全新的standard shader上,实际成果相当可观。
 
我们先科普一下standard shader。Standard Shader是个基于物理的着色器, 物理渲染和当今的主流光照计算最大的区别就是,当今的lambert blinn phone基本上是基于模拟的模型,就是尽可能的去模拟我们看上去的物体反射的颜色,甚至可以说是拍脑袋的模型,用于欺骗我们的眼睛,而基于物理的光照计算则是依据了光线传播的物理特性,更加贴近于真是的光照情况,虽然在实现上还是用了一些近似计算。所以物理渲染在表现自然界的物体时尤其的看上去更加真实。
 
这是个小视频介绍了下standard shader可以实现的效果,官方的U5Shader视频
 
 
 
这个standard shader“变化”是变得更快还是更慢,取决于贴图你使用的texture slots。尽管如此,这两种着色器是不同的(即使他们使用的都是standard shader):

<ignore_js_op>

这两个shader(即使他们是”Standard shader”)
 
当渲染场景时他们是完全不同的shader,因此如果我们想减少一些draw call(setpass call),必须采用完全不同的处理方式。
 
在谈到如何在Unity5减少draw call之前,我将探讨无论shader是否被使用时怎样减少draw calls,然后讨论在Unity5中使用Standard shader减少draw calls.
 
 
在Unity中用手动方式降低Draw Call
 
如果我们想减少draw call,在Unity中或者在其他引擎上,可以尽量减少使用的material(材质)。基本上,这些可以还原为这些简单的步骤:
 
1.整理所有的material并且通过他们的shader类型收集他们
2.第二步:对于使用相同shader的材质,将他们的贴图做成一个图集(Atlas)
3.创建一个material,它将包含shader和图集(Atlas)
4.网格的所有UV重新映射,使用Shader适配图集的坐标
5.用映射的网格创建出步骤3的material
 
第一步:整理所有的material,并收集它们的shader类型
我打算用一个简单的场景解释,这个场景所有网格使用的是相同类型但不同texture的material.
在我们的情况下,我们将使用这个场景(其中包含4个material,其中每一个都具有Bumped Diffuse shader):
    <ignore_js_op>          
注意SetPass calls:4         
  
所以我们要对这一场景的这些material进行处理:   
 
第二步:对于使用相同shader的材质,将他们的贴图做成一个图集(Atlas)
在我们的例子中,我们有2个texture,每一个着色的漫反射贴图使用一个正常的法线贴图和一个基本texture,所以我们需要做的是将这两个texture这样设置:         
   <ignore_js_op> 
保存这些texture在项目视图中,我们一会儿将需要它们:
 
<ignore_js_op>             
        
第三步:创建一个material,它将包含shader和图集(Atlas)
创建一个material,并将两张贴图和Shader(Bumped Diffuse)赋予给材质:      
   <ignore_js_op>             
 
第四步:网格的所有UV重新映射,使用Shader适配图集的坐标
这个修改可以用任何建模软件(Maya/ 3D studio / Max / Blender /等)来操作。
这是很无聊的又很必要的步骤,包括修改网格的UV坐标并且使它们适配texture图集(我们第二步创建的texture图集)。
所以我们要做的是,将每一个UV坐标设置为[ 0,0–1,1 ],我们可以将他们重新定位在一个[ 0,0-1,1 ]的较小的子范围中,这样就与步骤2中创造的图集相匹配。
<ignore_js_op>            
接着……我们为每个网格共享相同的shader。            
 
第五步:用你映射的网格创建出步骤3的material         
 
我们基本上完成了!我们还有几步要做:            
1。选择你所有的UV映射网格,用他们替换旧网格的位置并且停用旧的网格
        
2。将步骤3创造的材质赋予所有的UV映射网格。   
<ignore_js_op>          
 
到了这里,我们就结束了!,现在让我们点击play看看:
            
<ignore_js_op>      
在优化前,如果你回到步骤1,我们有4个SetPass call,现在优化已经完成,我们最终就有1个 SetPass call!太惊人了!在这种情况下,它的75%draw call减少了。            
在Unity5中减少绘制调用的标准着色        
在这里,你应该知道多了解些在standard shader上优化过程是如何做的。我在开头写了,standard shader内部“变化”和越来越快/慢,取决于你使用的texture slots。就是说,我们必须收集我们对象的material,如果他们使用了texture也使用的Standard shader。
通过使用的texture归类这些对象,我们只需要遵循我们用于所有shader的以下几个步骤:
            
1.整理所有的material并且通过他们的shader类型收集他们
2.第二步:对于使用相同shader的材质,将他们的贴图做成一个图集(Atlas)
3.创建一个material,它将包含shader和图集(Atlas)
4.网格的所有UV重新映射,使用Shader适配图集的坐标
5.用映射的网格创建出步骤3的material
           
这是我为测试创建的一个小场景:
<ignore_js_op>          
如果你比较原始场景的draw call(91)和优化后场景的draw call(22),你可以看到,有75%draw call减少了!,太惊人了!   
此外,如果你可以尝试尽可能多的组合网格,这也有很多帮助!。            

在unity5中减少Draw Calls(SetPass Calls)[转]的更多相关文章

  1. Draw Call(Unity 5中显示为SetPass calls

    Draw Call(Unity 5中显示为SetPass calls

  2. 12个Unity5中优化VR 应用的技巧

    本文章由cartzhang编写,转载请注明出处. 所有权利保留. 文章链接:http://blog.csdn.net/cartzhang/article/details/50176429 作者:car ...

  3. Unity5中的MetaPass

    前些天烘焙lightmap的时候发现用自己写的Shader的模型在烘焙时候不会烘焙效果不对,它不会产生对周围物体的间接光照,但是我放到了unity4.x中就是没问题的.查了一番,发现Unity5中加了 ...

  4. Unity5中叹为观止的实时GI效果

    http://www.manew.com/thread-43970-1-1.html 今天为大家分享unity与Alex Lovett共同使用unity5制作的Shrine Arch-viz Demo ...

  5. CNN中减少网络的参数的三个思想

    CNN中减少网络的参数的三个思想: 1) 局部连接(Local Connectivity) 2) 权值共享(Shared Weights) 3) 池化(Pooling) 局部连接 局部连接是相对于全连 ...

  6. Unity5中新的Shader体系简析

    一.Unity5中新的Shader体系简析 Unity5和之前的书写模式有了一定的改变.Unity5时代的Shader Reference官方文档也进一步地变得丰满. 主要需要了解到的是,在原来的Un ...

  7. 在WPF中减少逻辑与UI元素的耦合

    原文:在WPF中减少逻辑与UI元素的耦合             在WPF中减少逻辑与UI元素的耦合 周银辉 1,    避免在逻辑中引用界面元素,别把后台数据强加给UI  一个糟糕的案例 比如说主界 ...

  8. Unity5中WebGL平台封装的一些技巧

    最近在接触unity的WebGL平台,其实这个平台作为Web Player的替代品,已经能满足大部分的开发需求,而且不需要额外的插件支持,确实方便了不少,但开发中依旧遇到了不少问题,在这里记录和共享一 ...

  9. 如何在代码中减少if else语句的使用

    前言 代码中嵌套的if/else结构往往导致代码不美观,也不易于理解.面向过程的开发中代码有大量的if else,在java中可以用一些设计模式替换掉这些逻辑,那么在js中是否也有类似的方法用来尽可能 ...

随机推荐

  1. VR设备

    我本来想亲自介绍下我最近特别感兴趣的VR(虚拟现实)设备,但我发现我不会插入图片,所以我只好特意去找了一篇介绍虚拟现实现状设备的文章. 虚拟现实现状设备篇:http://www.cnblogs.com ...

  2. Html5 学习系列(五)Canvas绘图API快速入门(2)

    Canvas绘图API Demos 上一篇文章中,笔者已经给大家演示了怎么快速用Canvas的API绘制一个矩形出来.接下里我会在本文中给各位介绍Canvas的其他API:绘制线条.绘制椭圆.绘制图片 ...

  3. SignalR初体验

    简介 ASP .NET SignalR[1]  是一个ASP .NET 下的类库,可以在ASP .NET 的Web项目中实现实时通信.什么是实时通信的Web呢?就是让客户端(Web页面)和服务器端可以 ...

  4. C++ 重载操作符与转换

    <C++ Primer 4th>读书笔记 重载操作符是具有特殊名称的函数:保留字 operator 后接需定义的操作符号. Sales_item operator+(const Sales ...

  5. js中的hasOwnProperty()和isPrototypeOf()

    js中的hasOwnProperty()和isPrototypeOf() 这两个属性都是Object.prototype所提供:Object.prototype.hasOwnProperty()和Ob ...

  6. Origin的图片导出问题

    很多会议投稿都会要求提交的pdf文件用的是type1字体,因为type1字体是矢量字体,无论怎么放大缩小都不会失真.一旦pdf里嵌入了其他非矢量字体,例如type3字体,就会通不过测试,一个典型的例子 ...

  7. atitit.dw不能显示正确的百分比高度in dw的解决

    atitit.dw不能显示正确的百分比高度in dw的解决 div 设置35%的高度,三,不能正确的显示高度...环境dw cs6 但是设置161px奏能ok了...表明这个是dw的一个bug... ...

  8. 记忆化搜索hdu1078 dfs

    http://acm.hdu.edu.cn/showproblem.php?pid=1078 题意:给出n*n的格子,每个各自里面有些食物,问一只老鼠每次走最多k步所能吃到的最多的食物 #includ ...

  9. phpMyAdmin 登陆需要密码

    网页设计从事者在学习网页时都用过 "xampp" 这款软件吧. 本人今天正常使用时,系统提示可升级 phpMyAdmin.当前最新版本为:phpMyAdmin-4.6.4-all- ...

  10. 初识React,Virutal DOM, State以及生命周期

    这是React分类下的第一篇文章,是在了解了一些基本面后,看Tyler文章,边看边理解边写的. React可以看做是MVC中的V,关注的是视图层.React的组件就像Angular的Directive ...