U3d 手游优化概述

移动平台瓶颈

体积小 芯片要求改

功耗小 影响计算系能

带宽小 传输方面受限

性能优化

资源方面

美术方面

自带地形(地形是非常占用资源的)

a.控制地形的分辨率

b.地形高度图尺寸小于257

c.地形纹理中尽量使用少的混合纹理数目,尽量不要超过4个

纹理数据

a.纹理格式 尽量采取压缩格式

b.纹理尺寸 长宽小于1024 同时应该尽量小够用就好

c.尽量使用Mipmap 虽然Mipmap 有可能会增加程序的大小,但会提高渲染效率。

动态物体

a.控制面片数量 300-2000面片

b.控制Skinned Mesh Render 为1个

c.控制材质数量为1-3个

d.控制骨骼数量 小于30根

静态物体

a.控制网格顶点数量 小于500个

b.标记为Static

c.Static Batching

d.Animation组件:如果不需要,尽量不要附加

音频数据

a.播放时间长的音乐如背景音乐 可以使用.Ogg 或.MP3格式的压缩文件格式

b.播放时间段的音乐 可以使用.WAV或.aif格式的未压缩格式

引擎方面优化

光源设置:

a.在满足效果的前提下,控制场景中,光源的个数,尽量不要添加冗余光源。

b.控制Important光源的数目,尽量1个或干脆没有,个数越多,drawcall越多。

c.Pixed Light Count 1-2个

相机设置

a.设置合理的剪切平面,可根据不同的场景进行修改

粒子特效

a.频幕上的粒子总数,建议小于200个粒子,

b. 每个粒子发射器所发射的粒子总数,建议不超过50个

c.粒子大小 如果可以的话,粒子的size应该尽量小,对于非常小的粒子,在其粒子纹理中可以去除alpha通道

物理引擎优化

a.碰撞题控制 尽可能的使用Sphere Collider 和Box Collider,尽量避免使用Mesh Collider

渲染优化

a.尽可能避免使用Alpha Test和Alpha Blend。Alpha Test的性价比比较低,可能的话,使用?Alpha Blend来代替?Alpha Test

b.将使用Alpha Test和Alpha Blend的像素数降至最低??

c.DrawCall Batching:unity 在渲染时,可以将一些物体合并,从而可以只用一个DrawCall来渲染他们,这称为DrawCall Batching。理论上讲unity Batching的物体越多,则会得到更好的渲染性能。?

d.StaticBatching:静态合并。针对静态物体进行Batching,对几何数据的大小没有限制。原理:静态VertexBuffer+动态IndexBuffer,将同种材质的物体合并在一个大的VertexBuffer中,在运行时,通过视锥剪切来动态的改变IndexBuffer。

注意:使用StaticBatching后会额外的增加内存开销来存储Batch后的数据

e.Dynamic Batching:动态合并。对于相同的材质的动态物体,unity会自动对其进行Batching。

原理:动态VertexBuffer+动态IndexBuffer

注意:目前仅支持小于900顶点的网格物体

缩放物体无法与非缩放物体进行Batch

f.纹理合并 Texture Batching

遮挡剔除(Occlusion Culling)

代码方面优化

通过编程的方式,来提高代码的运行性能

a.对于有的函数,则可以每个几帧 执行一次

b.通过使用InvokeRepeating函数实现定时重复调用,比如,启动0.5s后每隔1s执行一次DoSomeThing

c.尽量少使用临时变量,特别是在Update() OnGUI()等实时调用的函数中

d.定时进行垃圾回收

e.优化数学运算,尽量避免使用float,而用

int,特别是在手机游戏中,尽量少用复杂的数学函数,比如sin,cos等函数。改除法为乘法,比如0.5f*a而不是a/2.0f

时间: 2024-10-22 12:52:03

U3d 手游优化概述的相关文章

Unity手游优化——CPU篇

Unity 手游优化——CPU篇 前段时间本人转战unity手游,由于作者(Chwen)之前参与端游开发,有些端游的经验可以直接移植到手游,比如项目框架架构.代码设计.部分性能分析,而对于移动终端而言,CPU.内存.显卡甚至电池等硬件因素,以及网络等条件限制,对移动游戏开发的优化带来更大的挑战. 这里就以unity4.5x版本为例,对Unity的优化方案做一个总结,有些是项目遇到的,也有些是看到别人写的不错拿来分享,算作一个整理,后期也会持续更新.本优化从CPU.GPU和内存三个方面着手总结,这

如何快速优化手游性能问题?从UGUI优化说起

WeTest 导读 本文作者从自身多年的Unity项目UI开发及优化的经验出发,从UGUI,CPU,GPU以及unity特有资源等几个维度,介绍了unity手游性能优化的一些方法. 在之前的文章<手游内存占用过高?如何快速定位手游内存问题>中提到,Mono内存和native内存是PSS内存主要的组成部分,mono内存更多的起到内存调用的功能,因此常常成为了开发人员优化内存的起点:而在游戏的其他的进程中,同样有很多因素影响着游戏的性能表现.本文将从UGUI的优化角度,介绍unity游戏性能优化的

利用KBEngine +U3D 做的一个简单MMO手游Demo

利用KBE +U3D 做的一个简单MMO手游Demo目前只完成到一个普通攻击和一个火球术,  火球术需要点击怪物后才能释放.点击npc后会跳到一个副本.里面有一只半兽人. 欢迎大家来试玩 并提出宝贵意见.http://pan.baidu.com/s/1dDtVjnb 感谢kbe 一直以来的帮助.

手游安全告急,爱加密提供全套解决方案

手游已经成为移动互联网具有代表性的产业,在开源性和开放性都更高的Android系统平台下,手游游戏款数.用户量.市场收入都呈激增态势.但另一方面,随着手游应用的急剧增多,手游应用安全也被不法分子和无良黑客盯上,在游戏中捆绑恶意广告插件来谋取利益,不少手游用户便落入扣费.隐私窃取.流氓推广的种种陷阱之中. 目前,手游行业面临的安全问题主要有内购破解.资源文件篡改.存档修改.内存修改.广告修改和注入恶意代码等.针对手游安全现状,越来越多的第三方手游安全服务提供商加入到这个行业,为手游安全保驾护航.

完美世界3D格斗手游[格斗宝贝]今日公测

欢迎来到unity学习.unity培训.unity企业培训教育专区,这里有很多Unity3D资源.Unity3D培训视频.Unity3D教程.Unity3D常见问题.Unity3D项目源码,[狗刨学习网]unity极致学院,致力于打造业内unity3d培训.学习第一品牌. 狗刨学习网报道 / 经过近两年井喷式的发展,国内手游市场洗牌的信号愈加强烈.用户体验的提升,以及对产品核心品质的要求,促进了手游的精品化,而白热化的市场竞争,也催生了各大厂商在细分市场的抢滩.其中,更注重画面和战斗体验感的中重

主流游戏引擎分析 【端游 、页游 、手游 解析】

该分享仅供参考,目的是提升大家对游戏引擎方面的一些认知.文档中部分内容收集于互联网,若有内容不准确,还请告知. 关于本文PPT文档:github 一.介绍 游戏引擎是指一些已编写好的可编辑电脑游戏系统或者一些互交式实时图像应用程序的核心组件.这些系统为游戏设计者提供各种编写游戏所需的各种工具,其目的在于让游戏设计者能容易和快速地做出游戏程序而不用由零开始.大部分都支持多种操作系统平台,如Linux.Mac OS X.微软Windows.游戏引擎包含以下系统:渲染引擎(即"渲染器",含二

谈谈龙之谷手游兼容测试的一百个坑

一.项目背景 1. 高价值IP 龙之谷 ,一款优秀的端游移植到手游平台,凭借的丰富的游戏内容和优秀的游戏品质,公测首日便在畅销榜登顶,取得了巨大的成功.  游戏内容不仅继承了端游的内容,还根据手游操作方式以及平台特性进行了改进,使之更适合移动用户操作,界面分部也更加合理.  2.初期兼容性问题较多 龙之谷与其他游戏产品一样,版本初期暴露的兼容性问题很多,类似无法安装以及必现的CRASH等致命问题多次出现外,还存在着大量UI错位.资源加载异常.屏幕分辨率适应差等严重级别的兼容性问题.  二.定制测

2017手游买量时代的到来

--记2017年GMGC大会 一年一度的GMGC (全球游戏大赛)在17年的3月15-17日举行,从本届(2017年度)大会透射出来的很多行业信息,或许可以主导未来几年行业整体的发展格局.首先是手游市场从2012年快速启动,经历5年的爆发式增长后,最近两年进入了白热化的"存量时代".在大量同质化手游产品的情况下,"买量"成为业内中大型游戏企业存活与发展的不二法门.[注: "买量"就是通过营销手段,获取大量玩家的下载量] (大会签到处) 一: 手游

解密:腾讯如何打造一款实时对战手游

2015年以来,手机游戏的市场偏好,逐渐从早期的休闲类.跑酷类.卡牌类游戏,转向重度.操作性更强的ARPG .FPS..MOBA类游戏.因此实时对战这一游戏玩法,也逐渐成为了手机游戏的一个核心玩法.纵观AppStore畅销榜前十的游戏,过半都支持玩家实时的PK或者合作攻关.由于实时对战有玩家之间自发进行强互动的特点,活跃度和社交强度都是比较高,为游戏的用户活跃和流水的提高奠定了坚实的基础. 腾讯的游戏开发团队,很早就观察到实时对战这一核心玩法对游戏生命周期影响的重要性,因此在自研产品方面,加大力