Toolbox

Status: Alpha release - August 2017

Last Updated: 09.05.2017

The cgmToolbox is a collection of many tools that may be accessed in a several ways:

  • Tool Window - The easiest way to access most of the tools is through the main window and be the main part of what we'll be talking about.
  • Top menu - We'll be talking about using this method in the next sections
  • Marking menu - We'll get to this later...
_images/toolbox_td_base.png

Access

  • cgmTopMenu>Open Tool Win - You should see what something like the above image
  • Python
import cgmToolbox
cgmToolbox.ui()

TD Tab

This is a collection of tools mainly for doing td and rigging work.

_images/toolbox_td_base.png

Context Some tools work with this contextual setup. They are designated in the ui/marking menu/top menu via a *.

  • selection - Only on selected objects
  • children - Selected objects and below
  • heirarchy - Selected objects and their heirarchies
  • scene - Everything in the scene. Careful.

Snap

See cgmSnap

Rigging

_images/toolbox_rigging.png

Create from selected

Series of options for creating objects from a selection. Works with components as well.

  • Transform -
  • Joint -
  • Locator - Locators are special. They work based off component selection and are updateable. More on that here...
  • Curve - Instead of per object, creates a curve through selection. Points may be components.

Copy

Series or functions for copying this and that in a from>to fashion.

  • Transform - Copy the position and orientation.
  • Orientation - Only the orientation.
  • Shapes - Any shapes are appended.
  • rotatePivot -
  • scalePivot -

Parent

Parent based on selection order.

  • Ordered -
  • Reverse Ordered -

Group

Series or functions for grouping selected per selected objects. Groups are created matching the transform of their targets so objects can be zeroed for example. They are also named.

  • Just Group - Just the group
  • Group Me - Group created, objected paretned to said group. Group is in world.
  • In Place - Group created, and inserts itself between target and target's original parent

Attributes

  • [type] + - Creates a ui prompt to add a number of attributes of the selected type. Separate by , .

    • Left click the type to change.
    • Types: enum , string , int , float , vector , bool , message
  • [cgmAttrTools] -- page not done

  • Compare Attrs - Compares the prime node to other selected nodes. That comparison comprising seeing what attributes on the given objects match and which do not. Here's example output:

# cgm.core.lib.attribute_utils : Comparing nurbsSphere2 to nurbsSphere1... #
# cgm.core.lib.attribute_utils : Matching attrs: 199 | Unmatching: 29 #
# cgm.core.lib.attribute_utils : -------------------------------------------------------------------------- #
# cgm.core.lib.attribute_utils : attr: boundingBoxMin... #
# cgm.core.lib.attribute_utils : source: [-4.348416510705419, -1.543820107219151, 0.38805085162276876] #
# cgm.core.lib.attribute_utils : target: [-1.2264094625656805, -1.0, -1.2264094625656803] #
# cgm.core.lib.attribute_utils : attr: boundingBoxMinX... #
# cgm.core.lib.attribute_utils : source: -4.34841651071 #
# cgm.core.lib.attribute_utils : target: -1.22640946257 #
# cgm.core.lib.attribute_utils : attr: boundingBoxMinY... #
# cgm.core.lib.attribute_utils : source: -1.54382010722 #
# cgm.core.lib.attribute_utils : target: -1.0 #
# cgm.core.lib.attribute_utils : attr: boundingBoxMinZ... #
# cgm.core.lib.attribute_utils : source: 0.388050851623 #
# cgm.core.lib.attribute_utils : target: -1.22640946257 #

Control Curves

Options for creating control curves from selected objects.

  • Create Control Curve - Creates a control curve at each selected object utilizing stored create options. See [Toolbox Options](toolboxoptions.md) for more details.
  • One of each - Just a way to create one of every curve type in our library
  • Make resizeObj - Create a matching transform and shape from your selected objects so you can cleanly resize and shape without worrying about the rig. When you're done...
  • Push resizeObj changes - Replace the shapes of the original object and delete our resizeObj
  • Mirror World Space To Target - Currently only works across world x
  • {Options} - Opens the Option Window

Shape

Series of tools for working with shapes. Works with a from>to format.

  • Parent - Parent shape in place. This is our implementation as we foud maya's not to work well.
  • Combine - Combine the selected shapes to the last transform.
  • Add - Add selected shapes to the last transform.
  • Replace - Replace the last objects shapes with the former ones
  • Extract - Extract a specific shape from a transform. (Works best with outliner - show shapes for easy selectability)
  • Describe - Given a selected nurbs curve, generate the code necessary to recreate it.

Joints

  • *Show x - Show axis (CONTEXTUAL)
  • *Hide x - Hide axis (CONTEXTUAL)
  • cometJO - Tool by the brilliant Michael B. Comet for orienting joints
  • seShapeTaper - Tool by our good friend Scott Englert for splitting sdk 'poses'

Mesh

  • MeshTools - page not done.
  • abSymMesh - (Brendan Ross) Great tool for working with blendshapes
  • abTwoFace - (Brendan Ross) Tool for splitting blendshapes

Skin

  • Copy - Copy the skinCluster data from first object to others
  • abWeightLifter - (Brendan Ross) Useful tool for retargeting/moving skinCluster data.
  • ngSkinTools - (NOT INCLUDED) If you have the tool installed, it will launch. Otherwise it'll open the page in a browswer to get it. You should get it.

Constraints

  • Get Targets - Given a selected object with constraints or a constraint, select the targets of the constraints involved

Joints

Nested load of cgmJointTools. Looks something like this:

_images/toolbox_joint.png

Transform

This section/tool is for tweaking and pushing transform data on one node and to others. When Bokser suggested it, it made me think of Lightwave's editor but it also has a bit of Comet's influence as well.

_images/toolbox_transform.png

It may be accessed in the toolbox section or you can launch a separate window via the anim tab transformTools button. It is split into three sections:

  • Source - This is where you load your base object with which to work and push values from/to
  • Tweak - Relative adding/subtracting values
  • Values - A grid of float fields expressing attributes and xform data

Source

This is where you load a source object. For editing and pushing values, something must be loaded as the source. It will auto load the first object in your selection on gui intialization or you can do it manually with the <<.

  • << - Load first selected object to the source
  • Update- Update the values section with the source objects current data
  • Ctxt - Probably temp but shows what your active targets are that will be affected by any other buttons
  • Lock source - When lock source is on, the source object will not be affected by any value changes or pushes

Tweak Values

The easiest way to understand this is as a relative value +/- for any of the data rows in values.

_images/toolbox_transform_tweakRow.png
  • x [    ] x [    ] z [    ] - Values to use for add/subtract. 0 of course does nothing.
  • + - Add to the current value. See Values checkbox explanation for more details.
  • - - Subract from the current value
  • Zero - Rest the value fields and uncheck all tweak check boxes in the values section

Values

This section is for absolute value setting where Tweak is for relative. The fields fill based off the source object both on loading a source and when you press the update button.

Let's first look at the format, then each attribute/value type.

_images/toolbox_transform_valueRow.png
  • Translate - Simple label expressing what kind of data this row is representing.
  • [] - Check box that couples with tweak. When you press the + for example in tweak. It checks for any rows with the check box and uses those to see what to tweak.
  • x [    ]- Populates with the given value from attribute or xform data
  • > - Only push this channel to targets
  • >>> - Push all channels to targets

Now to look at what each of these rows is.

  • translate - Local translation values
  • position - World space position xform data.
  • rotate - Local rotation values
  • orient - World space rotation xform data
  • rotateAxis - Attribute data
  • jointOrient - Attribute data (ONLY SHOWS UP FOR JOINTS)
  • scale - Local scale data
  • scaleLossy - Compound scale data from parents (Not tweakable)
  • scalePivot - xform data(not tweakable)

Examples

Let' take a look at a couple of examples

If you wanted to add 10 to the world position y value of a selection of objects.

  1. Select some objects
  2. Put 10 in the tweak y value field
  3. Check mark the position row
  4. Hit the + on the tweak row

If you wanted to absolutely set the world position y value of a selection of objects

  1. Select some objects
  2. Put a 10 in the position row y value field
  3. Hit the > next to that field

Controls

This section is for working with curve control creation and manipluation.

_images/toolbox_controls.png

There are 4 main sections currently.

  1. Shape creation - Create curve shapes based off of selection
  2. ResizeObj - Someone we started trying a couple gigs back and find it useful
  3. Mirror - Still fleshing this out but should be obvious
  4. Shape editing - see notes in rigging section
  5. Control coloring - Row for basic control coloring

Shape Creation

_images/toolbox_controls_shapes.png
  • Create row - First we have the create type row.
    • Shape - If you left click this label you can specify the curve create type.
    • Default color - The color created curves will be
  • Create Aim - Aim Next we have the create aim. You specify the create objects forward with this to get created curves to snap better. The library of shapes are generally stored as z forward y up.
  • Size Mode - How the created curves will be sized
    • Guess - Guess based on child distance. Most useful for joints.
    • Fixed - Set size. Change via the size button.
    • Cast - NOT IMPLEMENTED Plan on implementing with our raycasting stuff at some point
    • Size - Change the fixed size
    • Multiplier - Couples with Guess. If multiplier * distance to child = size
  • Create - ...using settings above
  • One of each - Make one of each shape type in our library so you know what they are.

Resize Obj

_images/toolbox_controls_resizeObj.png

In short the idea here is that if you are given a rig will all kinds of wiring and you want to tweak a control that exists without just replacing the shape which we could use replace. You could of course go to component mode but the pivot for scaling can get wonky. Regardless, in short, this gives you clean shapes of the control in question on a matching transform you can scale, move or do whatever with without messing with the rig. Then you can push those changes back to the control by using our replace call. This just makes it an easy one two step.

  • Make resizeObj - Makes currently selected objects resize objects. This sets up the connections to handle pushing back changes and what not.
  • Push resizeObj changes - Pushes changes back and cleans up wiring we added

Mirror

_images/toolbox_controls_mirror.png

Pretty sparse for now.

  • Mirror World Space To Target - Only works across X now. Given two selected curves, mirrors the first to the second. Supports multi shape controls. Wrote this for a recent gig. Need to flesh out more.

Control Coloring

Supports curves and geo both. With geo, a shader will be setup to acomplish the shader.

_images/toolbox_controls_color.png
  • [] rgb - Color by rgb rather than index. If versions before 2016 this isn't usable.
  • [] geo - When checked, geo controls will be given a shader with transparency per color setting. Note, when off surfaces wire color will be the only thing changed.
  • [] push - Push color changes to sub shapes. If unchecked only the selected shape or transform will be affected.
  • [][][][]... - Set color by our defaults for left, center and right / main,sub,direct styling.
  • Clr* - Clear color overrides on selected

Color

Not done with this section. Still works for now...

_images/toolbox_color.png

Raycast

We use raycasting a lot. These options affect:

  • RayCast Snapping
  • AimCast
  • Raycast object creation in this section
  • MeshTools curve casting

You can find more info about it in the corresponding knowledge section.

Buffer

When the buffer is inactive, ALL nurbs and poly surfaces in the scene are eligible cast targets. If you want to specify certain cast targets you do it here.

_images/toolbox_raycast_buffer.png
  • Define - Whatever is selected will now be the buffer
  • Add Selected - Append to the buffer
  • Remove Selected - ...
  • Report - Report the buffer to the script editor
  • Select Members - Select the buffer
  • Clear - Empty the buffer

Cast

This specifies what data is returned for the subsequent mode you're in. Note the objects actually being hit with rays can be specified with the rayCast buffer

_images/toolbox_raycast.png
  • close - Only use first impact regardless of mesh hit
  • mid - Mid point of impacts
  • far - Only far hits.
  • all - All hits.
  • x - Creates a temporary x axis plane to cast at
  • y - Creates a temporary y axis plane to cast at
  • z - Creates a temporary z axis plane to cast at

Offset

  • None - Hit point is the position used
  • Distance - Fixed instance offset along normal or cast vector
  • snapCast - Technique for offsetting created or snapped objects to the impact point by multiple casts. Will explain more later

Orient

  • None - Don't even try
  • Normal - Orient to the normal

Note

Not thrilled with the orient stuff yet. We'll be revisting or any contributors are welcome to take a stab at it

  • Set Drag Interval - Creates a uiPrompt to change the value. Drag interval sets how often to register hits during drag mode.
  • Set offset - Creates a uiPrompt to change the value

rayCreate

Create objects with rayCasting.

_images/toolbox_raycast_create.png

Tip

You can drop rayCasting context with the q key regardless of how you started it (markingMenu, this section, etc.).

  • [ locator ] - Left click to change what kind of creation object you want

    • Locator - Locators are created such that they are updateable.
    • Joint - Joint at hit point
    • Joint Chain - After tool is dropped, chain will be created from locs
    • Curve - After tool is dropped
    • Duplicate - If you have an object selected, it will be duplicated and snapped according to other options
    • vectorLine - Visual representation of raycasting. Creates two linear curves with a start and end point.
    • CastPoint----->Impact
    • Impact------->Fixed distance along mesh normal vector
    • Data - Just report data in the script editor
  • Create - Starts a dragContext in which you can click in the viewport to create objects at points of intersection per mouseclick

  • Drag - Same as create but will continue to create as long as the button is pressed and at the interval specified

Distance

Requires at least two selected objects to do anything. First object selected is source. Curves, mesh and surfaces are suported. If target objects have multiple shapes, all shapes are checked.

_images/toolbox_distance.png

Distance

  • [0.0000] - Float field that is updated when distance is measured
  • Measure - Measure the disance between all selected objects, add them, and update the float field to make it easy to copy

Vector

  • x[] y[] z[] - Float fields that is updated when vector is measured
  • Measure - Measure the vector between two objects, add them, and update the float field to make it easy to copy

Near

  • Object - Closest object of seleted objects to the first.
  • Shape - Closest shape of selected object's shapes to the first transform
  • Surface Point - Closest point on selected objects...
  • Surface Loc - Closest point loc'd...
  • Surface Nodes - Wired nodes per shape and result loc...

Far

  • Object- Furthest...
  • Shape- ....

Anim Tab

_images/toolbox_anim_base.png
  • Snap Section - Mirrored section from td tab. See more...
  • Aim Section - Mirrored section from td tab. check it out...
  • cgmLocinator - Tool for setting up snapping objects and baking that data while animating. Details...
  • cgmDynParentTool - Tool for setting up space switches. See more
  • cgmTransformTools - Open a separate window with the transform section
  • autoTangent - Michael Comet
  • tweenMachine - Justin Barrett
  • mlArcTracer - Morgan Loomis
  • mlCopyAnim - Morgan Loomis
  • mlHold - Morgan Loomis
  • red9.Studio Tools - Setup red9 tools. They are packaged with our tools. Great stuff.

Settings Tab

The things in the settings tab iteract with our optionVar setups that most of our tools access. Most of these things are accessible in the marking menu but it's tedious changing settings there. Thus we moved it here.

_images/toolbox_settings_base.png

Match

This if for snapping accessed via marking menu or top.

Mode

  • point - Position only
  • orient - Rotation only
  • point/orient - Position and rotation

Aim

Mode

  • local - Use local vector based on object defaults OR stored aiming options
  • world - Use world vector
  • matrix - IN DEVELOPMENT Bokser is playing around

Object Defaults

Because assumptions are often wrong.

Obj Aim

The local aim axis for vector work

Obj Up

The local up axis for vector work

Obj Out

The local out axis for vector work. Out is rarely used and may be deprecated.

RayCast

Cast

  • close - Only use first impact regardless of mesh hit
  • mid - Mid point of impacts
  • far - Only far hits.
  • all - All hits.
  • x - Creates a temporary x axis plane to cast at
  • y - Creates a temporary y axis plane to cast at
  • z - Creates a temporary z axis plane to cast at

Offset

  • None - Hit point is the position used
  • Distance - Fixed instance offset along normal or cast vector
  • snapCast - Technique for offsetting created or snapped objects to the impact point by multiple casts. Will explain more later

Orient

  • None - Don't even try
  • Normal - Orient to the normal

Note

Not thrilled with the orient stuff yet. We'll be revisting or any contributors are welcome to take a stab at it

  • Set Drag Interval - Creates a uiPrompt to change the value. Drag interval sets how often to register hits during drag mode.
  • Set offset - Creates a uiPrompt to change the value

Anim Options

  • Key Mode

    • Default - Maya default of keying everything keyable
    • Channelbox - Prioritizes channel box attribute selection so if you have obj1 and obj2 selected and tx selected in the channel box. The following would be keyed: [obj1.tx,obj2.tx]
  • Key Type - Keys set by default via marking menu can be reg or breakDown type

  • Reset Mode -

    • Default - All keyable attributes will be reset
    • Transform Atts - Only keyable transform attributes will be set: translate , rotate , scale

Legacy Tab

_images/toolbox_legacy_base.png
  • AnimTools - Old standalone collection
  • SetTools 1.0 - Will be rewriting soon
  • Locinator 1.0 - Old version. Like the new one but not as neat.
  • tdTools 1.0 - Old version of this. Still a few tools we need to migrate.
  • AttrTools 1.0 - Old version. New one is in alpha. Docs not done.

Top Menu

The new top menu was initially released in February 2017. It shares tool libraries with the marking menu so most items available in one are in the other. Menu sections may be torn off for easy access.

Note

Functions we're testing usually end up in the top menu before going to other sections or their own UI's

Until we get embeded video sorted. Please use this link: https://player.vimeo.com/video/206286478

Should be pretty self explanatory from the sections above. Most of the functions in the tool window are accessible here as well.

Snap

Functions for snapping items around. In general, they function on a selection basis with all targeting the last.

_images/snap.png

Basic

  • Point Special - Special point snaps...

    • Closest - To the closest point on the last surface,curve,shape
    • Ground - Snap to the objects point on the ground with offset for the pivot
    • boundingBox - Snap to the various points of a selection or each object's individual bounding box
    • axisBox - Same as last but with the axisBox. The axisBox is like the boundingBox but follows the object's transform
    • castFar - Same as the others but casting at targets. This one uses furthest hit.
    • castNear - ...nearest hit
    • castCenter - ...center hit
  • Parent - Position and orientation

  • Orient - rotation only

  • Aim - Currently uses object defaults from Menu. Will take into account object tagging in future.

  • Aim Special - In the cgmMarkingMenu, if three or more objects are selected splits to subMenu:

    • All to last - All items aim at the last
    • Selection Order - Each object aims to the next
    • First to Midpoint - First object aims at the midpoint of the rest of the selection

Casting

Casting utilizes rayCasting to help position things. Our rayCasting by default casts at all eligible surfaces.

  • RayCast - Uses the rayCast options to detect a point in space
  • AimCast - Uses rayCasting to aim selected objects in real time at a point of intersection

Matching

If an object is tagged to a cgmMatchTarget, will match the object to the match target. For example, if it is an updatable object ([Locinator](locinator.md) loc), it will update.

  • Self - Update the selected object to their respective match targets
  • Target - Updates the selected's match targets to the selected
  • Buffer - Update utilizing the match buffer

Arrange

  • Arrange -
    • Along Line (Even) - Arrange selected along line from frist to last evenly
    • Along Line (Spaced) - Arrange selected along a line snapping middle objects to their nearest point on the line

TD

Collection of tools for rigging and td work. It will eventually cover all that our legacy tool did and much more.

_images/td.png

Select

A contextual selection tool. For each option provided you can select objects of the given type. This is a WIP tool, we're unsure how useful it is. Simply an easy call from some other stuff we were doing.

  • Selection - Work from our current selection
  • Children - Check all children of all selected objects
  • Heirarchy - Check heirarchies of all selected objects
  • Scene - Check entire scene
_images/select_context.png

The options which are pretty self evident. If you clicked TD/Create/Select*/scene/Joints all joints in the scene would be selected.

  • Joints
  • Curves
  • Mesh
  • Surface

Control Curves

Options for creating control curves from selected objects.

  • Create Control Curve - Creates a control curve at each selected object utilizing stored create options. See [Toolbox Options](toolboxoptions.md) for more details.
  • One of each - Just a way to create one of every curve type in our library
  • Make resizeObj - Create a matching transform and shape from your selected objects so you can cleanly resize and shape without worrying about the rig. When you're done...
  • Push resizeObj changes - Replace the shapes of the original object and delete our resizeObj
  • Mirror World Space To Target - Currently only works across world x
  • {Options} - Opens the Option Window

Dev

  • Purge Option Vars - Remove all cgm option variables

  • Connect to Wing IDE - WIP

  • Start Wing Server - WIP

  • Load Local CGM Python - Load cgm modules to python memory so you can call them in the script editor

  • Load Morpheus Maker - WIP

  • Maya Oddities -

    • End Maya Progress bar - Sometimes the maya progress bar gets stuck. This closes it.
  • Unittesting - Just for us for now

Help

_images/help.png
  • CGM Docs - Gets you here.
  • Report Issue - Brings up a form on bitbucket for you to report errors. Please see the info in support before submitting.
  • Get Builds - Link to the download location on bitbucket. Working on making this better
  • Videos - Links to red9 and our vimeo channels
  • Coding Questions - Visit one of our favorite places - stackoverflow
  • Enviornment Info - See support for details.