首先要先从网上下载InstantOC组件(网上资源很多的不用跟我要)
那么介绍一下这个组件是干什么用的,为什么要用它,有什么好处
在游戏中我们看到的物体,是如何呈现给我们的呢?如图:
渲染管线
CPU干得事情
第一步 游戏:其实就是CPU来判断视锥以内,所能看到的物体都需要渲染
第二步 图形API:它是要看你发布的平台,不一样平台所需要的图形API也就不一样,比如Windows平台就需要DX,手机端平台就需要OpenGL等。。。。
第三步:绘制调用Draw Call每次引擎准备数据并通知GPU的过程,其实就是说每帧调用显卡渲染物体的次数(CPU与GPU的分界线)
GPU干得事情
第四步 顶点处理:接受CPU传输过来的顶点数据,来坐标转换(模型都是有若干个点和三角构成的)
第五步 图源装配(组装面):连接相邻的顶贴,绘制位三角形
第六步 光栅化:计算三角形的像素,并为后面着色阶段提供合理的插入参数
第七步 像素处理:对每个像素区进行着色,并写入到缓存中
第八步 缓存:一个存储像素数据的内存块,最重要的缓存是帧缓存和深度缓存
帧缓存:存储每个像素的色彩,即渲染后的图像,帧缓存常常子啊显存中,显卡不断读取并输出到屏幕中
深度缓存:Z-buffer:存储像素的深度信息,即物体到摄像机的距离,光栅化时变计算各像素的深度值,如果新的深度值比现有值更近,则像素颜色被写到帧缓存,并替换深度缓存
通过上面的叙述知道了游戏物体在渲染中是需要CPU和GPU共同来完成,那么在这个过程中一旦数据量变大一定回造成电脑性能上的消耗,为了降低消耗所以要使用InstantOC这个组件。
那么来介绍一下InstantOC,****InstantOC全称叫做Instant Occlusion Culling(遮挡剔除),为什么要用它?因为在摄像机的视锥内也有被物体所被遮挡而看不见的物体如果一起渲染出来会浪费大量的性能!因此我们就可以用遮挡剔除来减少GPU的工作量但同时也会增加CPU的工作量,那么如果在物体少或者没有遮挡的情况下就不要使用了(遮挡剔除)因为如果所有物体都需要渲染的话那再使用遮挡剔除无疑是给CPU增加了负担,那么遮挡剔除总结:当物体被送进渲染流水线之前,将摄像机视角内看不到的物体进行剔除,从而减少每帧渲染的数据量,提高了渲染性能,介绍了这些那就开始介绍它如何使用吧!
第一步:从网上下载一个InstantOC就是一个工具包,然后导入到Unity3D里(什么你问我怎么导入?,直接拖进去就可以了)!
第二步:导入完成后可以在Unity3D面板中看到一个名称叫做InstantOC文件夹,在这个文件中有一个IOCcam的C#脚本将它导入值摄像机(导入步骤也是托进去)
第三步:将导进摄像里的IOCcam脚本来进行参数配置,在所需要遮挡剔除的物体上的Layer(层)和Tag(标签)添加一个自定义的名称 ,分别给Layer mask(遮罩层)和 IOC Tag(遮挡标签)进行绑定
然后还需要设置Samples(取样)其实就是摄像机向视锥以内的物体发射一些射线碰到了就渲染碰不到就不渲染(射线是看不到的)
那么这些射线是随机发射的如果场景太大射线少就会导致物体明明能看到因为射线的原因没有碰到导致没有去渲染,
或者射线太多导致性能降低所以在射线这里是有一个规范的射线数量一般会设置在150-500之间
Rays FOV 射线远视:应大于摄像机视野Fied of View
View Disance:视图距离,射线长度将影响摄像机Clipping Planes——Far 数值
Hide Delay延迟隐藏,当物体被剔除是延迟的帧数,建议50-100之间(就是多让射线,多试几次毕竟射线是随机的所以需要延迟隐藏那些看不到的物体)
PreCull Delay:这个一定要勾选
那么在介绍一个这个组件上另外一个功能LOD!LOD全场叫Levels of Detail(多细节层次)LOD技术指根据物体模型的节点在显示环境中所处的位置和重要度,决定物体渲染的资源分配,降低非重要物体的面数和细节度,从而获得高效率的渲染运算
其实就是说当物体距离远了的时候才用面数较低的模型来减少渲染运算的工作量,来保证性能的一步优化
来开始如何使用它吧
使用方法:还是刚刚的步骤不变,在图下有这么几个属性需要设置一下,分别是Lod 1 distance和Lod 2 distance这是指摄像机与模型之前的距离 1代表精模(面数比较高的模型)2代表中模(代码面数一般的模型)如果超出这连个所设置的距离则会变成低模(面数比较低的模型),那么把数值调整好了 模型怎么办呢?(不用担心,工具本身是自带这3个模型的)如图 ,那么这里要说明一下 LOD是有命名规则的模型名称一定叫Lod_0、Lod_1、Lod_2来区分模型的面数如图,记得放到同一个空物体里,最后一张是配置完成后的