This page contains some tips to help you obtain the best performance from Unity’s animation system, covering character setup, the animation system and run-time optimizations.
In some cases you need to create characters with a large number of bones: for example, when you want a lot of customizable attachments. These extra bones increase the size of the build, and may have a relative processing cost for each additional bone. For example, 15 additional bones on a rig that already has 30 bones takes 50% longer to solve in Generic mode. Note that you can have additional bones for Generic and Humanoid types. When you have no animations playing using the additional bones, the processing cost should be negligible. This cost is even lower if their attachments are non-existent or hidden.
Combine skinned meshes whenever possible. Splitting a character into two Skinned Mesh Renderers reduces performance. It’s better if your character has just one Material, but there are some cases when you might require more than one.
Playing a single Animation Clip with no blending can make Unity slower than the legacy animation system. The old system is very direct, sampling the curve and directly writing into the transform. Unity’s current animation system has temporary buffers it uses for blending, and there is additional copying of the sampled curve and other data. The current system layout is optimized for animation blending and more complex setups.
Las animation scale curves (curvas de animación escaladas) son más caras que animar curvas de translation (translación) y rotation (rotación). Para mejorar el rendimiento, evite las scale animations (animaciones de escala).
Note: This does not apply to constant curves (curves that have the same value for the length of the animation clip). Constant curves are optimized, and are less expensive that normal curves. Constant curves that have the same values as the default scene values do not write to the scene every frame.
Most of the time Unity is evaluating animations, and keeps the overhead for animation layers and Animation State Machines to the minimum. The cost of adding another layer to the animator, synchronized or not, depends on what animations and blend trees are played by the layer. When the weight of the layer is zero, Unity skips the layer update.
These are tips to help you decide between these types:
Hay muchas optimizaciones que se pueden hacer, algunas recomendaciones útiles incluyen:
Utilice hashes en vez de strings para consultar el Animator. * Implement a small AI Layer to control the Animator. You can make it provide simple callbacks for OnStateChange, OnTransitionBegin, and other events. * Use State Tags to easily match your AI state machine to the Unity state machine. * Use additional curves to simulate events. * Use additional curves to mark up your animations; for example, in conjunction with target matching.
Always optimize animations by setting the animators’s Culling Mode to Based on Renderers, and disable the skinned mesh renderer’s Update When Offscreen property. This saves Unity from updating animations when the character is not visible.