Performance Unity Mobile
-
Upload
guillermo-andrades -
Category
Technology
-
view
666 -
download
0
Transcript of Performance Unity Mobile
Profiler
Samples
Detailed RAM
Gamebench
Scripts
Caches
Resources Folder
Pools
Tips
Materiales
Batching
Alpha
Atlas
Shared vs Instance
CombineChildren
Texture Formats
UI (4.6)
Tips
Target 60 FPS gama media ~ 40 drawcalls, ~50k verts ~ 120 tracks runtime 150 texturas en total 70 cargadas a la vez ~250 animaciones ~550 meshes
Profiler.BeginSample(“DoSomething”); DoSomething(); Profiler.EndSample();
Profiler.GetRuntimeMemorySize(t)
Acceder al transform es lo mismo que acceder a GetComponent<Transform>()
Acceder al GetComponent en el Update está desaconsejado
Cachear en el awake/start
private Transform myTransform; void Awake() { myTransform = transform; } void Update() { myTransform.Translate(0, 0, 5); }
Jamás usar GameObject.Find. Aparte de ser lentísimo, el nombre puede cambiar y tu código dejará de funcionar.
GameObject.Find ("MenuObject").transform.
GetChild(2).transform.GetChild (1).transform;
Referencias en la propia clase (public). Si necesitas muchas referencias, hacer un CustomInspector
Muy cómodo hacer Resources.Load pero ojocuidao con los tiempos de carga. Evitarlo dentro de lo posible.
Uso aceptable: elementos que no se utilizan en el juego inicialmente, pero que más tarde puede que si (cosméticos, habitaciones para un sistema aleatorio, etc). Si se referenciasen estos elementos se cargarían en memoria siempre, haciendolo desde Resources no.
Instantiate / Destroy son operaciones MUY costosas.
En el pool podemos tener pre-creados una lista de objetos a usar e ir activando/desactivando y reseteando según necesitemos.
Dos posibilidades. Crear todos los objetos en el Awake o tenerlos ya creados en la Scene.
Dato curioso. Cargar una escena con un Pool y X elementos tarda menos que cargar una escena con un Pool que en su awake cree X elementos
Foreach genera basura, no usarlo nunca. Las clases ArrayList y Array son muy lentas en
Unity. Mucho más rapido usar List o un array simple.
¿Seguro que necesitas llamar al método para actualizar la distancia cada frame? Optimizar las llamadas recurrentes.
DYNAMIC
Se aplica automáticamente (si se cumplen requisitos) Menos de 900 vertices.
300 si el shader usa Vertex Position, Normal y UV 180 si además se usa UV1 y Tangent.
Misma escala
STATIC
Se activa en QualitySettings
Hay que marcar los objetos como Static, no se podrán mover durante todo su lifetime.
Mejor performance que Dynamic batching
Unity Pro
Gran ahorro en el número de draw calls = mejor performance Batching solo funciona en objetos con el mismo material -> atlas (ojo con instancias)
Multiples Alpha en pantalla multiplican drawcalls
Usar cutout en la medida de lo posible (peor calidad, mejor rendimiento)
Unificar todos los efectos con Alpha del juego en un Atlas para hacer batching
No soportado por texturas ETC (tampoco el cutout)
Agrupando texturas en un Atlas conseguimos aumentar las posibilidades de Batching
Agrupar elementos relacionados (por nivel, por obstaculo / decoracion, etc).
TexturePacker de Unity funciona de forma automática, pero tiene algunos problemas
TexturePackerPro > all
Si accedemos al material desde script (renderer.material) estaremos creando una Instancia del material
Las instancias no hacen batching, por lo que generarán nuevos draw calls
Usar siempre que se pueda el sharedMaterial (renderer.sharedMaterial). Esto cambiará los parámetros en todos los objetos y no creará instancias del material.
Utilidad de Unity para combinar geometría al vuelo
Se puede usar on demand en runtime o hacerlo desde el editor y tener las meshes preparadas
La mesh será gigante, no se hará culling eficientemente y ocupará más espacio en memoria
Teniendo todos los elementos combinados solo se hará un draw call por material, aunque haya diferentes escalas y demás dado que contará como una sola mesh.
Mejor compresión para Android -> ETC 4 bits Soportado en el 99.9% de los moviles (OpenGL 2.0) No soporta Alpha ETC2 soporta Alpha, pero solo está asegurado en OpenGL 3.0
Mejor compresión para iOS -> PVRTC 4 bits Soportado en todos los dispositivos Soporta Alpha Texturas cuadradas o las deformará
16 bits / 32 (Truecolor) Si necesitamos Alpha en Android o nada de perdida de calidad
sobre la textura original Gran impacto en memoria (1024x1024 TC + mipmaps -> 5.3MB)
TextMeshPro > Text (65$). Mejor calidad con escalados, mejor implementación de outline / sombras / efectos, más opciones con el texto
No actualizar cada frame la UI Separar en diferentes Canvas en caso de que
algun panel tenga animaciones. Al mover / animar alguna parte, hace draw y batch de todo el canvas al completo