The following methods and system globals are associated with the Modify panel:
modpanel.getPinStack()
Returns true
if the Pin Stack button is pressed, false
if not pressed or not in Modify panel.
Available in 3ds Max 2010 and higher.
modpanel.isPinStackEnabled()
Returns true
if the Pin Stack button is enabled, false
if not enabled or not in Modify panel.
Available in 3ds Max 2010 and higher.
modpanel.setPinStack <bool >
Sets the Pin Stack button to the specified state as long as the Pin Stack button is enabled.
Available in 3ds Max 2010 and higher.
enableShowEndRes <boolean>
This method sets the checkbutton/button behavior of the Show End Result icon.
If the boolean parameter is true
, the Show End Result button remains pressed, thus behaving as a checkbutton.
If the boolean parameter is false
, the Show End Result button will return to the off state after being pressed, behaving as a button.
This method must be used in true
/ false
pairs, as its effect is "sticky" when selecting other objects or modifiers, or when switching away from and back to the Modify panel.
showEndResult
A 3ds Max system global variable that lets you get and set the state of the Show End Result Toggle icon in the Modify panel. It contains a Boolean value of true
if Show End Result is on, and false
if it is off.
enableSubObjSel <boolean>
If the boolean parameter is true
, allows the user to enter Sub-Object mode for those objects/modifiers that have Sub-Object modes defined. If false
, the Sub-Object button is disabled. This method must be used in true
/ false
pairs, as its effect is "sticky" when selecting other objects or modifiers, or when switching away from and back to the Modify panel.
IsSubSelEnabled()
Returns true
if the user is allowed to enter Sub-Object mode, false
otherwise.
numSubObjectLevels
A read-only 3ds Max system global variable that lets you get the number of sub-object levels supported by the object or modifier currently selected in the modifier stack.
If the Modify panel is not open or no objects are selected, the global variable contains the value undefined
.
subObjectLevel
A 3ds Max system global variable that lets you get and set the sub-object level in the Modify panel if it is open.
The value is an Integer of zero or greater up to the number of sub-object levels supported by the currently open modifier, typically in the order shown in the Sub-Object drop-down list.
A subObjectLevel
of 0 means sub-object mode is off.
If the Modify panel is not open or sub-object level setting not permitted in the current modifier, the global variable contains the value undefined
.
EXAMPLE
b=box() -- create a box em=edit_mesh() -- create an Edit Mesh modifier addModifier $box001 em -- add edit mesh mod print subObjectLevel -- print the current subobject level max modify mode -- open mod panel select $box001 -- select object box001 print subObjectLevel -- print the current subobject level subObjectLevel = 2 -- set sub-object level to Edge
OUTPUT
$Box:Box001 @ [0.000000,0.000000,0.000000] Edit_Mesh:Edit Mesh OK undefined undefined OK OK 0 0 2
The following methods can also be used to get and set the sub-object level:
getSelectionLevel <maxobject>
Get the subObject level of MAXObject. If MAXObject is a node, this method operates on the base object. This method is applicable to base editables, and select and edit modifiers.
setSelectionLevel <maxobject> {#object | #vertex | #edge | #face}
Set the subObject level of MAXObject. If MAXObject is a node, this method operates on the base object. This method is applicable to base editables and select and edit modifiers.
modPanel.addModToSelection <modifier>
Applies a modifier to the current selection opened in the Modify panel.
It must be used in place of addModifier()
in places where the target is a selection or group or where you have the stack open at a particular place in the Modify panel with a sub-object selection active and you want the modifier applied to that selection.
addModifier()
adds the modifier separately to each object in the selection or group and does not honor the current active sub-object selection in all cases. See Node Common Properties - Modifier Stack Related Methods for more.
The Modify panel must be open on the selection you want to apply the modifier to, otherwise the function does nothing.
modPanel.getCurrentObject()
Returns the modifier or base object currently selected in the Modify panel stack.
If the Modify panel is not open, this function returns undefined
. Use the max modify mode
command to switch to the Modify panel.
modPanel.setCurrentObject < modifier | node | node_baseobject > [node:<node>] [ui:<boolean>]
Sets the specified object to be the active object in the modifier stack. The Modify panel must be open, otherwise the function does nothing.
If node
: is specified, the modifier or base object will be searched only in the specified node. This is typically specified when you know what node to look in, and the modifier or base object is instanced in another node. If the argument is a node, the node keyword argument defaults to that node.
If ui
: is set to true
, the Command Panel will be switched to Modify mode. The default is false
.
modPanel.getModifierIndex <node> <modifier>
Returns the index of the given modifier in the modifier stack for the given node.
This index corresponds to the modifiers position in the <node>.modifiers
array.
This function returns undefined
if the given modifier is not in the node's modifier stack.
modPanel.validModifier (< modifier > | < modifier_class >).
Returns true
if Modify panel is open, one or more nodes are selected, and the specified modifier is applicable to all the nodes at their current edit level in the stack.
In 3ds Max 6 and higher, the modPanel.validModifier
method will return false
if either the node/node collection or modifier/modifier class is 'undefined', or the node collection is empty.
EXAMPLE
modPanel.addModToSelection (bend()) -- apply bend modifier to current selection modPanel.getModifierIndex $ foo -- returns index of modifier foo modPanel.setCurrentObject $ -- open on base object modPanel.setCurrentObject $.baseObject -- same as above modPanel.setCurrentObject $.taper -- open on taper modifier in object modPanel.setCurrentObject $.modifiers[3] -- open on 3rd modifier modPanel.setCurrentObject foo -- open on foo object or modifier