pandemonium_engine_docs/usage/assets_pipeline/escn_exporter/animation.md

2.8 KiB

Animation

Animation supported:

  • transform animation of all types of objects
  • transform animation of pose bones
  • shape key animation
  • light animation
  • camera animation

Multiple Actions For Single Object

In most games, one object would have several animations to switch between. This add-on has support for exporting multiple actions all at once into a single AnimationPlayer and makes it easy to switch actions.

This workflow makes use of blender nla_tracks. Here is a brief guide on how to use this feature:

1. Stash active action

New created action is always an active action bound to object. There are several ways to place an active action into NLA track, one is of course doing it in NLA Editor

![](img/nla_editor.jpg ![](img/nla_pushdown.jpg

Or it can be done stashing the action in Dope Sheet

![](img/dope_sheet.jpg ![](img/stash_action.jpg

2. Check mute status of NLA tracks

An NLA track can be mute or unmute, the exporter will export all the mute NLA track as a separate action, while blends all the unmute NLA tracks into every action (including the action action) being exported.

![](img/nla_strip.jpg

3. Export the scene

Make sure the Export Stashed Actions option has been turned on.

![](img/stash_action_option.jpg

Then all the stashed actions, as well as the active action, are exported to an AnimationPlayer.

![](img/in_godot.jpg

Constraints

Sometimes complicated animation is built with object constraint; a usual example is inverse kinematics. The add-on would automatically check if an object has some constraint; if it does, all the constraints are baked into actions and then exported along with the object.

Animation Mode

Godot and Blender have different structure to store animation data. In Godot animation data is stored in an AnimationPlayer node, instead of in each animated node. In order to fix this inconsistence and still make the animation play versatile, this add-on has three animation exporting modes.

Mode 'Animation as Actions'

Treat all the animations as object actions, so in the exported scene, every object would have its own AnimationPlayer and hold its actions.

Mode 'Scene Animation'

If you want your animation to generate the same result as playing at Blender's timeline, this is what you want. In this mode, all the animations in the scene are placed in just one AnimationPlayer in the scene root.

Mode 'Animation as Action with Squash'

This mode has very similar behavior of mode 'Animation as Action', but it can generate fewer AnimationPlayers; objects in parent-children relationship would share their AnimationPlayer. It is useful when you have several rigs, and each Skeleton and Mesh has actions; then one rig would have just one AnimationPlayer.