File: basics.rst

package info (click to toggle)
blender-doc 4.3-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 253,604 kB
  • sloc: python: 13,030; javascript: 322; makefile: 113; sh: 107
file content (276 lines) | stat: -rw-r--r-- 12,144 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276

***********
Basic Usage
***********

.. _bpy.ops.pose.rigify_generate:

Basic Rig Generation
====================

#. Add a meta-rig structure from the :menuselection:`Add --> Armature` menu.
#. Edit the bone positions to match the character geometry.
#. In the armature properties click on the *Generate Rig* button to generate the rig.


Add a Predefined Meta-Rig
-------------------------

.. reference::

   :Mode:      Object Mode
   :Menu:      :menuselection:`Add --> Armature`
   :Shortcut:  :kbd:`Shift-A`

Rigify stores all the information required to generate complex rig controls and mechanism in
more simple armatures called "meta-rigs".

The predefined meta-rigs can be found in the *Add* menu.
Currently available meta-rig types are:

- Basic Human (doesn't include face and fingers)
- Basic Quadruped
- Human
- Cat
- Wolf
- Horse
- Shark


Edit Bone Positions
-------------------

To correctly match your character, meta-rig bones must be moved to correct positions.
This can be achieved in two different ways: Pose Mode or Edit Mode.

.. note::

   Rigify assumes that 1 unit corresponds to 1 meter. So a human is about 2 units tall.
   If your character is in a different scale and you are more familiar with modeling rather than rigging,
   it is suggested to scale it to Rigify dimensions before positioning the meta-rig bones.
   If you want to scale the character's geometry, we suggest you to first scale up the character in Object Mode,
   then apply the geometry scale with the *Apply Scale* tool.


Rigify Human Alignment Tips
^^^^^^^^^^^^^^^^^^^^^^^^^^^

- Limbs: Keep the legs as straight as possible in the front view (Rigify human works better in predictable cases).
  Give the knee and the elbow a slight bend angle (Rigify needs to know where your knee/elbow is pointing).
- Torso: Keep the spine as straight as possible in the front view (Rigify human works better in predictable cases).
  The last bone of the spine is the head. By default the next two bones (top to bottom)
  are considered the neck bones. It is suggested to keep the neck bones as aligned as possible while editing.
- Face: Positioning face bones can be tricky if you are not an expert in bone editing and
  they are almost useless if you plan to make facial animation through shape keys.
  Consider removing face features from your character if they aren't really needed.
  If you don't need the face all the face bones can be deleted.
  All the face bones are in the *Face* armature bone collection by default.
  You can select them by displaying only that collection, selecting all of its content and
  then deleting the bones in Edit Mode to correctly remove the face.

  If you want to scale all the face bones at once, consider scaling the face master bone
  in Pose Mode (see Pose Mode matching method).
  The face master bone is placed in the same position of the head bone.
  To select it easily, hide all other bone collections.

  For more tips, see the :doc:`Positioning Guide </addons/rigging/rigify/bone_positioning>`.


Pose Mode Matching (Basic)
--------------------------

Enter the meta-rig Pose Mode. Rotate, scale, and translate the bones in the correct position.
When bones are in correct positions (always staying in Pose Mode)
use :menuselection:`Apply --> Apply Pose As Rest Pose`.

.. note::

   Connected bones cannot be translated in Pose Mode.
   You can scale the parent bones to match the general length and then refine child bones scale.
   For more detailed information on armature modes please refer to
   the :doc:`armatures section </animation/armatures/bones/editing/introduction>`.


Edit Mode Matching (Advanced)
-----------------------------

Some basic armature display setup is suggested before entering bone Edit Mode.

With the meta-rig selected, go in the Properties and click on the Object tab.
Scroll down to the display panel and enable X-ray and under *Maximum Draw Type* selector select *Wire*.
This way the bones will always be drawn in wireframe on top of your geometry.

Then, always in the Properties click on the Armatures tab and under display check the *Axis* checkbox.
This way you the bones rotation axes will be displayed during the edit process.

For more detailed information on armature display modes please refer to
the :doc:`Display panel page </animation/armatures/properties/display>`.


Generating the Rig
------------------

With the bones in the correct positions, jump back in Object Mode, go to the Armature tab,
scroll down to the bottom and click on the *Generate Rig* button to finalize the rig creation.
The generation process will take from few seconds to one minute depending on
rig complexity and hardware specifications of your machine.
If the generated rig needs tweaking, you can modify the meta-rig accordingly and
then click again on the generate button. If the rig already exists,
Rigify will simply overwrite it retaining all your modifiers and constraints and -- where possible --
all the previously generated features.

For information about additional generation options, see the `Advanced Rig Generation`_ section.

.. tip::

   If the metarig uses the legacy :doc:`face rig <./rig_types/faces>`, you can use the
   *Upgrade Face Rig* button that appears above *Generate Rig* to automatically upgrade
   to the new modular face system.

   The upgrade will preserve compatibility with existing skinning, but existing poses and
   animations will likely not be compatible due to subtle changes in control behavior.

.. note::

   To make the rig overwriting work as expected, you need to have **both** the rig and
   the meta-rig visible before generating again. Rigify will try to unhide them in simple
   cases, but will abort generation if that fails.

.. warning::

   As with all Python add-ons, Blender interface cannot be updated until the Python script execution is over.
   Wait until the rig appears to see the results.

.. warning::
   Rigify is designed assuming a workflow where the meta-rig is kept available to allow re-generating
   the main rig whenever it is necessary to make changes to it. Removing the meta-rig after generating
   the main rig, or significantly modifying the generated rig is not advised: it will make it impossible
   to introduce features added in later versions of Rigify, or easily adapt it to breaking changes in later
   Blender versions. In general, automatic version update scripts will be provided for meta-rigs when necessary,
   but not generated rigs.


Binding the Geometry to the Rig
-------------------------------

To bind the geometry to the rig you can use your preferred tools. Just few things you have to know:

- All the deforming bones are in the *DEF* bone collection.
- Eyes and Teeth bones of the legacy face are not deforming. You are supposed to bind the eyes and
  teeth geometry through Child Of constraints.
- Usually armature deform with automatic weights do a really good job out of the box
  if you correctly place your bones (and there is enough topology to work with!).

For more detailed information on bone collections, Armature modifier and weight painting refer to the Blender manual.


.. _bpy.types.Armature.rigify:

Advanced Rig Generation
=======================

Advanced Options Features
-------------------------

By using options in the Advanced sub-panel, it is possible to:

- Generate more than one rig per scene.
- Update/Override a specific rig.
- Force previously generated widget objects to be overwritten.
- Choose whether to use linked duplicates for left and right side widgets.
- Execute a script data-block after generation.

Advanced Options Sub-Panel
--------------------------

.. figure:: /images/addons_rigging_rigify_basics_advanced-panel.png
   :align: right
   :width: 300px

Advanced rig generation options are by default hidden in a sub-panel. Click on the *Advanced* line to open it.

Some of the options will be automatically set by Rigify if they have no value when a rig is generated,
while others are fully controlled by the user.

Rig Name
   When a brand new rig is generated, as opposed to overwriting an existing one, the value of this option
   is used to name it.

   If this field is empty, the new object will be named based on the name of the metarig according
   to the following rules:

   * If the name contains ``META``, it is replaced with ``RIG``.
   * If the name contains ``metarig``, it is replaced with ``rig``.
   * Otherwise, ``RIG-`` is prepended to the name.

   When overwriting an existing rig object specified by the *Target Rig* option, its name is not changed,
   allowing it to be freely renamed without having to keep the value of this option in sync.

Target Rig :guilabel:`auto`
   This option specifies the generated rig to overwrite when re-generating from this metarig.

   If the option is not set, Rigify will generate a new rig object and store it in this option.

   .. note::

      When the option isn't set, Rigify will create a brand new rig object even if an object
      with a matching name already exists.

Rig UI Script :guilabel:`auto`
   This option specifies the generated script datablock to overwrite when re-generating, and
   works in the same manner as *Target Rig*.

   The script controls the UI in the 3D Viewport that allows conveniently switching visible
   bone collections, changing custom properties, converting between IK and FK and so on.

Widgets Collection :guilabel:`auto`
   This reference specifies the collection containing generated widgets, and
   works in the same manner as *Target Rig*.

Overwrite Widget Meshes
   If enabled, Rigify will generate new widgets every time the rig is re-generated. By default,
   it tries to reuse the already generated widget objects that exist in the widget collection,
   allowing them to be manually edited to fit the character better.

Mirror Widgets
   When enabled, Rigify generates widgets for left and right side bones as
   linked duplicates, using negative X scale to flip the right side version.
   This enforces symmetry and reduces the number of meshes to adjust to
   fit the character.

   When reusing an already generated widget, Rigify detects if it was originally generated mirrored
   by checking object scale to avoid flipping existing controls. Therefore switching to mirrored
   widgets for an existing character requires deleting the right side widgets, or *Force Widget Update*.

Run Script
   It is possible to configure Rigify to execute a Python script contained in a text data-block
   after generation in order to apply user-defined customizations. The script is executed with
   the generated rig active and selected in Object Mode.

   The simplest use of this may be adjusting properties of generated constraints when Rigify rig types
   don't have any relevant meta-rig settings. That can be done by using the *Copy Full Data Path*
   context menu option on the property, pasting it into the script and making an assignment, e.g.::

      import bpy

      bpy.data.objects["rig"].pose.bones["MCH-spine.003"].constraints[0].influence = 0.6

   Doing such changes via a script ensures they aren't lost if the rig is re-generated.

   Users familiar with `Rigify scripting <https://developer.blender.org/docs/features/animation/rigify/>`__
   can import Rigify utility modules, and access the generator instance through ``rigify.get_generator()``.
   Yet note that, since generation is already finished, the only use of that is reading data created
   in the generation process.


Library Linking
===============

When linking a rig into another file, you generally want to create a collection that includes
the generated rig and the character mesh. You do not need to include the meta-rig or the widget
object collection. You then link in the collection and run
:ref:`Make Library Override <bpy.ops.object.make_override_library>`.

The ``rig_ui_template.py`` text data-block responsible for the rig UI
will be automatically linked along with the rig, you don't need to link it separately.
However, the script will not run until you run it manually from the Text editor or save and restart Blender.