Guppy Animation Tools is a collection of tools to help with animation production in Maya.
Guppy Animation tools and all associated files are licensed under the GNU Lesser General Public License version 3.0 unless otherwise stated.
Regular Users: Download Guppy Animation Tools as a zip file here.
Developers: Feel free to clone/fork the repo. Add the repo to your PYTHONPATH,
it should be named "guppy_animation_tools". Import the specific tool you
need. Skip ahead to the usage section.
-
If you downloaded the zip archive, extract it.
-
Rename the top folder "guppy_animation_tools" without the quotes. Make sure that this is the TOP folder. Some zip extraction tools will add an extra folder!
-
Move the guppy_animation_tools folder to Maya's "scripts" directory. In windows this should be "My Documents/Maya/scripts". In linux this should be "~/maya/scripts".
If you're having trouble finding a directory you can write to, you can try running the following lines in the python script editor in Maya. It should print out all the directories you can use.
import maya.mel as mel
print '\n'.join(mel.eval('getenv("PYTHONPATH")').split(';'))
The userSetup.py file is a python script that Maya executes on startup. It should be in Maya's "scripts" directory - the same directory you put the guppy_animation_tools folder in. You may have to create this file if it does not exist.
Add the following lines to your userSetup.py:
import maya.cmds as cmds
cmds.evalDeferred("from guppy_animation_tools import *")
All of the commands given below are python. Some of these tools, are meant to be run as hotkeys. If you don't know how to set a hotkey in Maya, the documentation is an excellent place to learn.
Arc Tracer is a tool that can visually display the arc of an animated object or point on a mesh. It aims to have a few extra features not found in most other arc tracers, such as a display-over-mesh feature and displaying sub-frame arc information.
IMPORTANT Arc Tracer has not yet been updated to use viewport 2.0
As a stop-gap measure, in order to see anything in Maya 2017 update 3 or
later, you must set the MAYA_ENABLE_VP2_PLUGIN_LOCATOR_LEGACY_DRAW
before launching maya. In bash terminals this is done by running
this command before launching:
export MAYA_ENABLE_VP2_PLUGIN_LOCATOR_LEGACY_DRAW=1
To create an arc tracer, select a node you want to trace, then run the python command:
arcTracer.create()
If you want an arc tracer to always be run with the same settings, first create an arc tracer with the settings you like, then run:
arcTracer.getShortcut()
This will print out the command needed to create an arc tracer with those settings. You can make that your default hotkey/shelf button.
This command will let you trace mesh. Run this python command and click the point on the mesh you want to trace. A word of warning: this was an experiment that has mostly been abandoned due to being extremely slow. If you want to use this with the getShortcut command, just replace arcTracer.create with arcTracer.atPoint from the output.
arcTracer.atPoint()
Settings
A brief description of the settings on the Arc Tracer node.
- Past Frames: How many frames to trace before the current one.
- Future Frames: How many frames to trace after the current one.
- Min Subframes: The minimum number of subframes to calculate. Arc Tracer tries to guess at a good number of subframes to calculate between the minimum and maximum based on the camera distance. If Min and Max subframes are at the same number, this will force Arc Tracer to calculate exactly that many subframes.
- Max Subframes: The maximum number of subframes to calculate.
- Show Arc: Shows the arc curve.
- Overlay Arc: Shows the arc curve on top of every object in the scene.
- Show Frame Numbers: Shows the frame numbers (duh) on the arc.
- Show Frame Markers: Shows dots on each frame.
- Frame Markers Scale To Camera: The size of the markers will stay the same on the screen no matter how much you zoom in or out.
- Frame Marker Size: The size of the frame markers. There is no control for the size of frame numbers.
- Update On Playback: New frame information will be gathered when the current frame is changed.
- Use Refresh Mode: Only use this if Arc Tracer doesn't seem to be tracing the
object correctly. By default Arc Tracer tries to use methods in Maya that avoid a
full scene DG evaluation (which is slow). However, these methods can fail to
work correctly in certain circumstances (usually involving IK's or expressions).
Enabling this mode will make the Update button move the current frame and refresh the entire scene for every frame needed. This will result in the most accurate positional data from Maya. - Update: Updates the Arc Tracer.
Clever Keys provides a simple way to key selected attributes. It determines which attributes to key based on the mouse position and tries to always insert a key.
But what exactly what is keyed and when? Roughly, if your cursor is over the graph editor, things selected in the graph editor will be keyed, otherwise attributes selected in the channel box will be keyed. What specifically happens can be tweaked in the various options listed below.
This is the main command, setting a key. I suggest setting this to your default setKey hotkey, "s". It might also be a good idea to set Maya's original hotkey to something like Shift + "s". I've tried to make this script as bug free and stable as possible. But if something does go wrong at some point and you do need to set a normal key again, it's nice to have the fallback already set up.
cleverKeys.setKey()
Everything from here on is just icing on the cake. If you just want to use the default Clever Keys, you don't need to read any further.
If you don't want clever keys to try to insert keys, you can use this command instead:
cleverKeys.setKey(insert=False)
When working in the graph editor, if any part of an animation curve is selected Clever Keys will only key the selected curve(s) and not any other attributes. To disable this, you can use the option:
cleverKeys.setKey(usePartialCurveSelection=False)
Even with this option set, if an entire curve is selected (not just part of it) Clever Keys will only key the selected curve(s) and not any other attributes. To disable curve filtering entirely, you can use the option:
cleverKeys.setKey(useSelectedCurves=False)
Clever keys can help you clear your selected attributes.
cleverKeys.clearAttributes()
This command works the same way that Clever Keys does. It clears whatever is under your mouse. If you want to just clear a specific window, you can use either of these:
cleverKeys.clearAttributes(graphEditor=True)
cleverKeys.clearAttributes(channelBox=True)
Or to clear them both:
cleverKeys.clearAttributes(graphEditor=True, channelBox=True)
CleverKeys can help you sync your selection between the graph editor and the channel box.
cleverKeys.selectSimilarAttributes()
If your mouse is over the graph editor, this will sync the attributes selected in the Graph Editor to the Channel Box. If your mouse is not over the graph editor, this will sync the channels selected in the channel box to the ones in the graph editor.
To explicitly select similar attributes in the Graph Editor without detecting where your mouse is, use:
cleverKeys.selectSimilarAttributes(detectCursor=False)
To explicitly sync the Channel Box to the Graph editor, use the following command.
cleverKeys.syncGraphEditor()
To sync the Graph Editor to the Channel box, use this python command:
cleverKeys.syncChannelBox()
Lock 'n Hide is a tool that allows you to lock and or hide attributes on referenced nodes. You can restore the original state at any time.
Lock 'n Hide can be opened with the python command:
lock_n_hide.ui()
If you want to use an action without using the GUI, right click on the action to copy it to the keyboard. You can then make a hotkey or shelf button by pasting this in the appropriate area. You do not have to have the UI open in order to use these hotkeys.
Attributes not modified by Lock 'n Hide that are hidden or locked on referenced nodes can not be unlocked or unhidden. This is to protect asset integrity.
Move My Objects is a simple tool to save and restore the world position of nodes.
Move My Objects can be opened with the python command:
moveMyObjects.ui()
If you want to use an action without using the GUI, right click on the action to copy it to the keyboard. You can then make a hotkey or shelf button by pasting this in the appropriate area. You do not have to have the UI open in order to use these hotkeys.
Rename It is a simple, but powerful renaming tool. It is opened with the following python command:
renameIt.ui()
RenameIt can do simple renaming. It understands ending numbers and how to pad node names.
RenameIt can also search and replace text.
For the advanced user, RenameIt can also do complex regex search and replace. The up/down arrow keys can be used to bring up previous entries.
Slide Animation Keys helps you quickly adjust the values of multiple keys.
Slide Animation Keys uses a lot of the same selection logic that Clever Keys uses. If your graph editor is open it will work on the selected keys. If no keys are selected or the graph editor is closed, it will work on the keys on the selected object on the current frame.
Slide Animation Keys is opened with the python command:
slideAnimationKeys.ui()
Right click to adjust settings. If you want to use an action without using the GUI, right click on the action to copy it to the keyboard. You can then make a hotkey or shelf button by pasting this in the appropriate area. You do not have to have the UI open in order to use these hotkeys.
Blend Modes
Blend mode moves all keys towards the previous and next keys.
Shift mode shifts the keys as a block towards the previous and next keys.
Average mode moves keys toward the average of the previous and next key per attribute.
Level mode moves all keys toward a single average value.
Shrink mode shrinks each key towards each other on every frame.
Linear mode makes a line between the previous key and the next key per attribute.
Default mode moves all keys toward their defaults (zero for most attributes).
Zero Selection returns the selected attributes to their default values.
Zero Selection uses the same logic as Clever Keys when choosing what attribute to zero out. Zero Selection is run with the python command:
zeroSelection.zeroSelection()