2022-03-18 17:46:08 +01:00
|
|
|
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,
|
2023-01-12 19:43:03 +01:00
|
|
|
one is of course doing it in `NLA Editor`
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/nla_editor.jpg
|
|
|
|
![](img/nla_pushdown.jpg
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
Or it can be done stashing the action in `Dope Sheet`
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/dope_sheet.jpg
|
|
|
|
![](img/stash_action.jpg
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
**2. Check mute status of NLA tracks**
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
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`
|
2022-03-18 17:46:08 +01:00
|
|
|
NLA tracks into every action (including the action action) being exported.
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/nla_strip.jpg
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
**3. Export the scene**
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
Make sure the `Export Stashed Actions` option has been turned on.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/stash_action_option.jpg
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Then all the stashed actions, as well as the active action, are exported
|
|
|
|
to an AnimationPlayer.
|
|
|
|
|
2024-03-16 20:56:52 +01:00
|
|
|
![](img/in_pandemonium.jpg
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
|
|
|
|
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
|
|
|
|
---------------------------
|
2024-03-16 20:56:52 +01:00
|
|
|
Pandemonium and Blender have different structure to store animation data.
|
|
|
|
In Pandemonium animation data is stored in an AnimationPlayer node, instead
|
2022-03-18 17:46:08 +01:00
|
|
|
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.
|