Unless otherwise noted, the following transform properties are always interpreted with respect to the current working coordinate system as defined by the currently active coordsys context. The default coordsys
is world
. The pos
, rotation
, and scale
properties of a node are aliases to the corresponding subcontroller for the node's transform controller. If the transform controller does not have one of these subcontrollers, accessing the corresponding node property will result in an "Unknown property" error message. For example, the LookAt controller does not have a Rotation subcontroller, and the IK controller does not have any subcontrollers. You can still access the transform values using the Matrix3 properties of the node's transform
property, for example, objpos=obj.transform.translationpart
.
<node>.transform: Matrix3
Can read/write to.
If written to, the Matrix3 value is decomposed into its position, rotation, and scale values. These values are stored in the respective position, rotation, and scale controllers, if those controllers exist and can be written to.
<node>.pos: Point3 --can use .position synonym throughout
<node>.pos.controller: Controller --can use .track synonym throughout
<node>.pos.isAnimated: Boolean, read-only --true if position is animated
<node>.pos.keys: MAXKeyArray
<node>.pos.track: Controller --synonym of .pos.controller
<node>.rotation: Quat
Gets or sets the rotation component of the node's transform in world space (that is, around the scene origin), as a quat value. To rotate in the node's local space, you can do something like:
in coordsys (transmatrix $.pos) $.rotation = (quat 0 0 0.446743 0.894662)
<node>.rotation.x_rotation: Float --X rotation of node
<node>.rotation.y_rotation: Float --Y rotation of node
<node>.rotation.z_rotation: Float --Z rotation of node
<node>.rotation.controller: Controller --can use .track synonym throughout
<node>.rotation.isAnimated: Boolean, read-only --true if rotation is animated
<node>.rotation.keys: MAXKeyArray
<node>.rotation.track: Controller --synonym of .rotation.controller
<node>.scale: Point3 -- fraction
<node>.scale.controller: Controller --can use .track synonym throughout
<node>.scale.isAnimated: Boolean, read-only --true if scale is animated
<node>.scale.keys: MAXKeyArray
<node>.scale.track: Controller --synonym of .scale.controller
<node>.dir: Point3 --local z-axis direction vector
Rotates node so that the node's Z axis points in the specified direction. The node is rotated around its Z axis such that the Y axis points as much as possible in the world -Z direction.
Getting and setting <node>.dir
now respects the current coordinate system. Previously, this property was always in world coordinates.
<node>.max: Point3, read-only --max coordinates of node's bounding box
<node>.min: Point3, read-only --min coordinates of node's bounding box
<node>.center: Point3 --coordinates of center of node's bounding box
<node>.transform: Matrix3 --node's main transformation matrix
Rotation in the internal transformation matrices is left-handed in contradiction to the 3ds Max user interface and MAXScript. Take care when mixing rotation derived from these matrices and rotation used in rotation-related functions or from rotation properties.
<node>.pivot: Point3 -- node's pivot point position
<node>.objectOffsetPos: Point3
<node>.objectOffsetRot: Quat
<node>.objectOffsetScale: Point3
Node geometry's position, rotation, and scale offset from the pivot in world coordinates.
<node>.objectTransform: Matrix3, read-only
Node geometry's offset in world coordinates.
SCRIPT
--Setting a node's rotation relative to world space without --messing with its position: fn setNodeWorldRotation theNode theRot = ( in coordsys (transmatrix theNode.transform.pos) theNode.rotation = theRot ) b = box isSelected:true setNodeWorldRotation $ (eulerangles 45 45 0) -- or: setNodeWorldRotation $ (quat 0 0 0.446743 0.894662)