zoukankan      html  css  js  c++  java
  • Unity3D在IOS上的优化小结

    http://www.58player.com/blog-635-122.html

    最近一段時間一直在做Unity 在IOS設備上的資源優化,結合Unity的官方文檔以及自己遇到的實際問題,我把自己認为一些重要的信息罗列在下面,並盡可能對將其量化,以方便更多需要做優化的朋友。

    1、角色

    每個角色盡量使用一個Skinned Mesh Renderer

    這是因为當角色僅有一個Skinned Mesh Renderer時,Unity會使用可見性裁剪和包圍體更新的方法來優化角色的運動,而這種優化只有在角色僅含有一個Skinned Mesh Renderer時才會启動。

    角色Material數量

    2-3個

    骨骼數量

    小於30個

    面片數量

    300-1500

    一般角色應該沒有IK結點

    這是因为角色的動作大多數都是事先設定好的,並不需要經過IK操作來進行實時計算(Rogdoll除外),所以在模型導入時,不要將IK結點一起導入。

    2、靜態實體

    不要附加Animation Component

    在靜態實體上附加Animation部件雖然對結果沒有影響,但卻會增加一定的CPU開銷來調用這一組件,所以盡量去掉該組件。

    網格頂點數

    小於500

    UV值範圍盡量不要超過(0, 1)區間

    盡量保證UV值不越界,這對於將來的紋理拼合優化很有幫助。

    3、地形

    地形的分辨率大小

    長寬均盡量小於257。這是因为地形太大,會造成大量頂點數據,给你的內存帶寬造成一定的影響,在目前的ios設備中,內存帶寬是非常有限的,需要盡量節省。同時,如果用Unity自帶的地形,一定也要使用Occlusion Culling,因为Unity的刷地形工具雖然方便,但卻是framekiller,刷過之後,你會發現drawcall增加的非常多。

    混合紋理數量

    不要超過4。地形的混合操作是很耗時的,應該盡量避免。能合並的紋理盡量合並。

    4、紋理

    紋理格式

    建議png或tga。不用轉成ios硬件支持的PVRTC格式,因为Unity在發布時會幫你自動轉的。

    紋理尺寸

    長寬小於1024。同時應該盡可能地小,夠用就好,以保證紋理對內存帶寬的影響達到最小。

    支持Mipmap

    建議生成Mipmap。雖然這種做法會增加一些應用程序的大小,但在遊戲運行時,系統會根據需求應用Mipmap來渲染,從而減少內存帶寬。

    檢查Alpha值

    如果紋理的alpha通道均为1,則用RGB的24位紋理來代替RGBA的32位紋理。(據說Unity內部會進行自動檢測)

    5、光源

    光源“Important”個數

    建議1個,一般为方向光。“Important”個數應該越小越少。個數越多,drawcall越多。

    Pixel Light數目

    1-2個。

    6、粒子特效

    屏幕上的最大粒子數

    建議小於200個粒子。

    每個粒子發射器發射的最大粒子數

    建議不超過50個。

    粒子大小

    如果可以的話,粒子的size應該盡可能地小。因为Unity的粒子系統的shader無論是alpha test還是alpha blending都是一筆不小的開銷。同時,對於非常小的粒子,建議粒子紋理去掉alpha通道。

    盡量不要開启粒子的碰撞功能。

    非常耗時。

    7、音頻

    遊戲中播放時間較長的音樂(如背景音樂)

    使用.ogg或.mp3的壓縮格式。

    較短音樂(如槍聲)

    使用.wav和.aif的未壓縮音頻格式。

    8、相機

    裁剪平面

    將遠平面設置成合适的距離。遠平面過大會將一些不必要的物體加入渲染,降低效率。

    根據不同的物體設置不同的遠裁剪平面

    Unity提供了可以根據不同的layer來設置不同的view distance,所以我們可以實現將物體進行分層,大物體層設置的可視距離大些,而小物體層可以設置地小些,另外,一些開銷比較大的實體(如粒子系統)可以設置得更小些等等。

    9、碰撞

    盡量不用MeshCollider

    如果可以的話,盡量不用MeshCollider,以節省不必要的開銷。如果不能避免的話,盡量用減少Mesh的面片數,或用較少面片的代理體來代替。

    10、其他

    Drawcall

    盡可能地減少Drawcall的數量。IOS設備上建議不超過100。減少的方法主要有如下幾種:Frustum Culling,Occlusion Culling,Texture Packing。Frustum Culling是Unity內建的,我們需要做的就是尋求一個合适的遠裁剪平面;Occlusion Culling,遮擋剔除,Unity內嵌了Umbra,一個非常好OC庫。但Occlusion Culling也並不是放之四海而皆准的,有時候進行OC反而比不進行還要慢,建議在OC之前先確定自己的場景是否适合利用OC來優化;Texture Packing,或者叫Texture Atlasing,是將同種shader的紋理進行拼合,根據Unity的static batching的特性來減少draw call。建議使用,但也有弊端,那就是一定要將場景中距離相近的實體紋理進行拼合,否則,拼合後很可能會增加每幀渲染所需的紋理大小,加大內存帶寬的負擔。這也就是为什麼會出現“DrawCall降了,渲染速度也變慢了”的原因。

    非運動物體盡量打上Static標簽

    Unity在運行時會對static物體進行自動優化處理,所以應該盡可能將非運行實體勾上static標簽。

    場景中盡可能地使用prefab

    盡可能地使用prefab的實例化物體,以降低內存帶寬的負擔。檢查實體的PrefabType,盡量將其變成PrefabInstance,而不是ModelPrefabInstance。

    備注:優化是個無止境的過程,可優化的項目其實還有很多很多,比如腳本優化,shader優化等等,這些留待以後再慢慢添加。

    原文链接:http://rritw.com/a/caozuoxitong/OS/20120426/160528.html

  • 相关阅读:
    自定义博客园skin
    c++11: <thread>学习
    《明日方舟》Python版公开招募工具
    Python列表
    Python基础
    C#常用修饰符
    C#单例类的实现
    云服务器反黑客入侵攻防实录(一)
    在CentOS7.6上安装自动化运维工具Ansible以及playbook案例实操
    技术漫谈 | 远程访问和控制云端K8S服务器的方法
  • 原文地址:https://www.cnblogs.com/123ing/p/4095128.html
Copyright © 2011-2022 走看看