DrawCall优化---场景

大家好,又见面了,我是你们的朋友全栈君。

Unity DrawCall优化

一 Mesh Renderer 二 Skinned Mesh Renderer 三 合并要求对比 四 总结 五 场景制作建议

DrawCall优化合并,也叫批处理,即DrawCall Batching. 通过减少Draw call数提高性能。

一 Mesh Renderer 分为Dynamic Batching和 Static Batching Dynamic Batching 不需要任何操作,只要共享材质(即使是不同的Mesh模型也可以),就会自动被合并。可以自由移动旋转。但有以下使用要求: (1)单个Mesh的vertex attribute总数不超过900. 即 vertex* attributeCount < 900 例如一个Mesh有pos,uv,normal,那么attributeCount为3, 也就是顶点数量不超过300个。 (2)游戏对象使用相同模型和材质时,只有相同缩放(即xyz等比缩放,浮点尾数可以有细微差)的会被合并。 如 (1,1,1)与(1,1,1) (2,2,2)与(2,2,2) (0.5,0.5,0.5)与 (0.5,0.5,0.5) (2,2,2)与(2,2,2.0001) (3)场景烘焙:烘焙后同材质将不会被烘焙。lightmap 有隐藏的材质参数:offset/scale, 所以使用lightmap的物体不会被合并 (4)Shader不能使用多Pass:多Pass的Shader会破坏Dynamic Batching

Static Batching

原理: 运行游戏后将一组游戏对象的多个模型会被动态合并为1个。这组游戏对象所有使用同一材质的在一个DrawCall来完成。这些游戏对象运行后无法移动缩放旋转。但是Drawcall一定是最大化合并的,并且不受动态合并的诸多限制(见下文详述)。 注意:即使物体都使用了同样的模型,在batch后每一个物体都会创建一份模型对应的geometry,在新的Combined Mesh里。所以过多的batch会增加内存占用。例如场景里的树群就不适合Static Batch,而适合动态合并。 实现方法: (1)MeshRenderer勾选Batching Static: 勾了即可 (2)代码中使用UnityEngine.StaticBatchingUtility实现(可以在任何平台调用): 1)将所有要合并的静态物体(不须勾Batching Static)放入统一一个root 2)StaticBatchingUtility.Combine(root); 之后就合并好了! 区别: 勾选Batching Static: 完全自动合并,在MeshFilter里显示的是 Combined Mesh(root:scene)。合并后不能移动 StaticBatchingUtility: 合并到一个游戏对象下。合并后可以移动父节点游戏对象

二 Skinned Mesh Renderer Unity对Skinned Mesh Renderer没有任何batching, 但插件Mesh Baker可以对Skinned Mesh进行合并。 注意: (1)修改Renderer.material将会创建一份新的material,应使用Renderer.sharedMaterial来保持材质公用。 (2)可以使用Mesh.Optimize() 优化模型。导入模型不需要调用此接口,在导入模型至Unity3d时已自动处理。 代码创建的模型有可能需要调用此接口来优化。

三 合并要求对比 要求 动态 静态 1 只能是MeshRenderer不能是SkinnedMeshRenderer 要求 要求 2 Shader必须是单Pass 要求 不要求 3 不能被场景烘焙(不能标注为Light map static) 要求 不要求 4 网格模型文件总点数要求 要求 不要求 5 网格模型单个文件点数要求 要求 不要求 6 限制缩放 要求 不要求 7 限制位移旋转 不要求 要求

另外Unity中任何Mesh的面 有65536的面数限制

四 总结 三种方式: 1 动态合并 优点: 内存消耗小 可以自由位移旋转 缺点: 要求众多() 2 标记Light map static合并 优点: 最方便快捷,要求最少 缺点: 完全不能移动 内存有消耗 只能处理在Scene中默认放置的物体 3 代码StaticBatchingUtility合并 优点: 方便快捷,要求少 可整体移动 可处理代码动态加载的场景或物体 缺点: 内存有消耗

代码合并是要求最少的,并可以整体移动。而动态合并可以移动旋转,并做Animation动画。故推荐StaticBatchingUtility + 动态合并。

五 场景制作建议 美术人员在制作某场景时,尽量: 静态物体:使用静态合并 条件 1 用Mesh Renderer,也就是不绑定骨骼 2 不是Wrap循环UV的贴图,尽量合并到一张大图集 方法 标注Batching Static即可

动态物体:使用动态合并,动画可以用Unity的动画去做 条件 1 无骨骼 2 不参与场景烘焙 3 相同物体相同缩放 4 单个Mesh的vertex attribute总数不超过900. 5 Shader单Pass 方法 满足条件Unity自动优化 (不满足动态合并要求的。场景动画可以用骨骼动画去做。但应尽量避免或者少的使用这种方式。因为没有Drawcall优化效率较低)

PS: 要关闭动态合并在subshader里加以下代码即可 Tags { “DisableBatching” = “true” }

如果是非Mobile端可以考虑使用GPU Instancing 如果是有超级多的人,可考虑使用顶点动画提高性能。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/191775.html原文链接:https://javaforall.cn

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值