Select USD data in the Viewport

When working with a USD set in Maya, clicking in the Viewport selects an exact prim. This often results in the partial selection of a model. If you want to manipulate an entire model or set, you need to manually select it in the Outliner. You can override this behavior with the optionVar UsdSelectionKind and UsdPointInstancesPickMode. Choose a selection mode to reflect changes when you select prims in the Viewport and Outliner. Note: Default fallback selection mode is by prim.

About Selection by Kind and Point Instancers

Kind is a type of metadata that is used to classify prims in USD. It is an extensible system that is based on a Kind hierarchy that has pre-loaded string values. These string values determine the selection behavior in the Viewport. You can also define custom strings that are unique to your production pipelines.

Note: Kind is a type of metadata that needs to be authored. Not every USD file includes kind metadata. If no kind metadata exists, clicking in the Viewport selects an exact prim.
Important: Set kind values to prims to activate selection by kind. Set the classification value from the dropdown in the Attribute Editor to assign a kind category to a prim. Once a kind value is set to a prim, you can activate selection by kind.

The Kind Hierarchy:

PointInstancer is a "multi instancer", as it allows multiple prototypes to be scattered among its "points". The PointInstancer schema is designed to scale to billions of instances, which motivates the choice to split the per-instance transformation into position, (quaternion) orientation, and scales.

Activate Selection Modes

Using the interface in Maya

Using Maya interface, you can choose your USD selection mode in the Viewport.

Important: If you choose from the Point Instances selection menu, your selection in the Kinds menu will automatically revert to (none).

Using the Command Line for Selection by Kind

  1. Selection by Kind has the following modes:
    • optionVar -sv "UsdSelectionKind" "model" ; Selects the nearest ancestor that is a model or its subcategory.
    • optionVar -sv "UsdSelectionKind" "group" ; Selects the nearest ancestor that is a group or its subcategory.
    • optionVar -sv "UsdSelectionKind" "user-defined" ; Selects the nearest ancestor that is a user-defined kind or its subcategory.
    • optionVar -sv "UsdSelectionKind" "" ; Selects the exact prim that is picked in the viewport. This returns Viewport selection to its default behavior.

In the following example, we override the default Viewport selection behavior to select entire models in the USD set:

Using the Command line for USD Point Instance Selection

You can also use the optionVar (that was previously UsdPickMode) which is now UsdPointInstancesPickMode with the possible values of: pointInstancer, instances, or prototypes.

  1. Point Instance Selection has the following modes:
    • optionVar -sv "UsdPointInstancesPickMode" "PointInstancer" ; Selection mode that is the equivalent of being unset. Selecting an instance would return the instancer prim.
    • optionVar -sv "UsdPointInstancesPickMode" "Instances" ; Clicking an instance would return the specifc instance.
    • optionVar -sv "UsdPointInstancesPickMode" "Prototype" ; Selects the original prototype prim in the Viewport.
    • optionVar -sv "UsdPointInstancesPickMode" "" ; Selects all individual instances of the same prototype.

Combination Selection Modes

If the object picked in the viewport is a point instance, this optionVar controls what that pick resolves to the PointInstancer prim (a specific point instance scene item, or the prototype prim being instanced, respectively). This results in a more flexible way to use both the point instances pick mode and the selection kind in combinations.

Tip: If you don't have anything set for UsdSelectionKind, then the kind and prototypes pick modes are exactly the same.

A UsdView style selection menu can be implemented as follows:

  1. For Prims: UsdSelectionKind = '', UsdPointInstanceSelection = '[Anything]'

  2. For Models: UsdSelectionKind='model', UsdPointInstanceSelection = '[Anything]'

  3. For Instances: UsdSelectionKind='[Anything]', UsdPointInstanceSelection='instances'

  4. For Prototypes: UsdSelectionKind = '', UsdPointInstanceSelection = 'prototypes'

    Note: These combinations can be both ones that UsdView doesn't support while still allowing you to express the pick modes that UsdView already does support.

Related Concepts: For more information, see kind and metadata in the Pixar USD Glossary and Kind: Extensible Categorization.