unity3d移动平台性能优化专题16:性能优化实战之20个复杂单位战斗

          一直秉持着性能最优的原则,目前我们的3d游戏即使在红米上也能够到达平均45帧,最低30帧的水平。但这次有一个功能是一个大问题,我们平时战斗都是5v5,但这次需要做一个10v10,理论上复杂度*2,时间也应该*2.

         45帧,那么*2后应该是25帧左右。但遗憾的是性能这东西并不是简单的乘法,而是超越一定瓶颈后会指数下降。果然,在红米上只有15帧,而且体验会有问题。那么根据前面的全部性能优化的专题,我们来看下如何针对性的去解决。

         1.分析性能下降的最重要原因,发现监视器中显示的是渲染部分,以前10个单位,现在20个单位,大概多了几万个面,导致突破了瓶颈。那么这个是硬性指标,我浏览了我们所有的场景,发现大部分场景都在50k个三角形左右,但是我也找到了一个不错的场景,只有10k,我首先的策略就是更换场景,将场景换成这个10k的。和策划商量后,策划同意了。ok,马上修改进行测试。

         ok,结果出乎意料,最后确实发现可以维持在30帧,但战斗过程中还是只有15帧。看来这还远远不够,我不得不继续研究。

         2.仔细看了下,似乎渲染上已经不是太大问题,那么毫无疑问,就是单位过多引起的,有两种可能,一个是脚本AI执行*2,一种是特效数量*2.不管是哪一种,似乎都是只能通过逻辑优化了,本来走路Ai是很复杂,但现在鉴于人过多,只能简化走路ai,直接直走,然后减少ui上的drawcall,进行新一轮的测试。

         这样之后,战斗过程大概也是在20帧-30帧之间,似乎还可以接受,但体验有问题,由于我采用AI排队策略,现在人数太多,导致AI执行变慢,比如你应该碰到人要攻击了,但由于你的AI在排队,你没办法马上攻击,只能等待甚至继续跑,但这是无法接受的,而且我发现只有一开始会这样,那么我大致推论,只有一开始的时候由于JIT等原因导致比较卡,所以帧率很低,大概只有15帧,这个时候能过被执行的AI数量并不多,20个人,人人都是非常着急要攻击的。但是我的队列清除速度是5,我认为这是一个比较合适的值,如果增加到20,当然每一个人都会攻击,但是这样排队的意义就没有了。

        而且测试了一下,发现增加排队的效果微乎

你可能感兴趣的:(u3d性能优化)