Animation in Blender

From Valve Developer Community
Jump to: navigation, search

This article covers rigging and animating a model in Blender Blender for export with the Blender Source Tools Blender Source Tools. Also, make sure to try Source Ops addon for exporting from blender to source. It assumes you are familiar with using Blender to create meshes. See Exporting a model/Blender for general exporting help.


Todo:  Update information for blender 3.4
Todo:  Add blender 2.8x information along 2.7x due to the fact that not everyone uses blender 2.8

Creating an armature

"Armature" is Blender's term for a skeleton.

  1. If you aren't in (Icon) Object Mode, select it from the bar at the bottom of the 3D View.
  2. Add a new armature with Shift+A > (Icon) Armature.
  3. To prevent the mesh hiding your bones, go to (Icon)+(Icon) Object Properties, find the Display panel, and enable the "X-Ray" option.
  4. Enter (Icon) Edit Mode with Tab . This is where you will edit the bones in the armature.
    • To add bones, use Shift+A (add a new root), E (extrude from the selected bone/bones), or Ctrl+LMB (create a new bone where you click).
    • To move one end of a bone while leaving the other in place, select one of its connector spheres.
    • To rename a bone, go to (Icon)+(Icon) Bone Properties. To have Blender label bones in the 3D view, go to (Icon)+(Icon) Armature Properties, find the Display panel and enable "Names".

Skinning

In Blender, the link between mesh and bones is called a "skin". The Blender Source Tools support three methods of creating one:

Bone parent

Warning.pngWarning: This does not work with SourceOps 0.7.0 (November 2022). This section was added in July 2011 for Blender 2.5 and has not been updated since. If you know which versions of which addon this works for, please add that information here.

If your model is made up of rigid components, you can create it as a collection of separate objects and then parent each one to a bone.

  1. Enter (Icon) Pose Mode and select the bone you want.
  2. Select your mesh, then use Shift to multi-select the armature.
  3. Press Ctrl+P and choose "Bone".

You can also set a bone parent via the Relations panel of (Icon)+(Icon) Object Properties.

Armature modifier

Modifiers affect objects without altering their underlying data, and the (Icon) Armature Modifier causes a mesh to be deformed by the pose of an armature. To add an one, select your mesh and go to (Icon)+(Icon) Object Modifiers.

The armature modifier can work in one or both of the following ways:

Envelopes

This is the easiest way to skin an organic mesh. Each bone automatically projects an "envelope" of influence, and by repositioning them and changing their Radius a fairly good skin can be created.

  • To change a bone's Radius, enable Envelope display from (Icon)+(Icon) Armature Properties then select its connector and scale it (S) as you would an object.

Weight mapping

Weight painting the upper arm of the Heavy.

A "weight map" defines how much influence each bone has over each vertex's position (an envelope or bone parent simply generates one for you). If a vertex is weighted 50% to two bones, then the associated bones each have 50% control over it during animation.

In Blender, a Mesh's weightmap is defined by (Icon) Vertex Groups with names matching bones on an associated Armature. The weightmaps of other object types cannot be directly edited.



Managing Vertex Groups:

  • Blender can generate and populate vertex groups automatically: select your Mesh, then your Armature, then hit Ctrl+P and choose the appropriate option from underneath "Armature Deform". You can do this at any time, but if an Armature Modifier already existed remember to remove the new one from (Icon)+(Icon) Object Modifiers!
  • To create or destroy groups manually, enter (Icon) Edit Mode and go to the Vertex Groups panel in (Icon)+(Icon) Mesh Properties.

Assigning to Vertex Groups:

  1. Select your object and enter (Icon) Weight Paint mode.
  2. Choose a Vertex Group either with Shift+LMB, which will offer a list of nearby bones, or from the Vertex Groups panel of (Icon)+(Icon) Mesh Properties.
  3. Paint! You can control the brush settings from the Tool Shelf on the left side of the 3D View. If it isn't visible, press T.
    • You can also manually assign weights from the Vertex Groups panel while in (Icon) Edit Mode.


Solution to an unconfirmed error:

Encountered inside Counter-Strike: Source Counter-Strike: Source and its VHE. Bones refuses to affect the mesh. Maybe because of a recent update? (as of 01.2018)

To fix this: try assigning vertex groups and weight map on the same area.


Todo: Does it happen in CS:S only?

Animating

Note.pngNote:Only the animation of bones created in (Icon) Pose Mode will be exported. Whole-object animation will not make it out.

In Blender, animations are stored in (Icon) Actions. You can store any number in the same file but the UI for managing them is poor.

  • To manage Actions, install the Blender Source Tools and use the new "SMD Export" panel in (Icon)+(Icon) Armature Properties.
  • To edit an Action, enter (Icon) Pose Mode, select the bones you want to animate and use I to create a keyframe for the first frame of your animation. Then change to another frame with the arrow keys or (Icon) Timeline and create more keyframes.

For general help with the process of animating, see:

Exporting

Note.pngNote:

Blender cannot currently associate more than one Action with an Armature, making batch exporting from busy .blend files tricky.

The Source Tools overcome this as best they can by supporting the export of a filtered list of all Actions in the .blend, as well as of the active Action. You can configure this from the SMD Export panel of (Icon)+(Icon) Armature Properties (which starts off as the last panel in the list but can be dragged higher).

To export Actions from an Armature, select it and run the "SMD Export" operator from either:

  • The search box (Space)
  • The SMD Export panel of (Icon)+(Icon) Scene Properties or (Icon)+(Icon) Armature Properties
  • The (Icon) File > Export menu