A Parent Constraint moves and rotates a GameObjectThe fundamental object in Unity scenes, which can represent characters, props, scenery, cameras, waypoints, and more. A GameObject’s functionality is defined by the Components attached to it. More info
See in Glossary as if it is the child of another GameObject in the Hierarchy window. It has certain advantages that are impossible when you make one GameObject the parent of another:
For example, to place a sword in the hand of a character, add a Parent Constraint component to the sword GameObject. In the Sources list of the Parent Constraint, link to the character’s hand. This way, the movement of the sword is constrained to the position and rotation of the hand.
Property | Description |
---|---|
Activate | After you move and rotate the constrained GameObject and its source GameObjects, click Activate to save this information. Activate saves the current offset from the source GameObjects in Rotation At Rest, Position At Rest, Position Offset, and Rotation Offset, then enables Is Active and Lock. |
Zero | Sets the position and rotation of the constrained GameObject to the source GameObjects. Zero resets the Rotation At Rest, Position At Rest, Position Offset, and Rotation Offset fields then enables Is Active and Lock. |
Is Active | Toggles whether to evaluate the Constraint. To also apply the Constraint, make sure Lock is enabled. |
Weight | The strength of the Constraint. A weight of 1 causes the Constraint to move and rotate this GameObject at the same rate as its source GameObjects. A weight of 0 removes the effect of the Constraint completely. This weight affects all source GameObjects. Each GameObject in the Sources list also has a weight. |
Property | Description |
---|---|
Lock | Toggle to let the Constraint move and rotate the GameObject. Disable this property to edit the position and rotation of this GameObject. You can also edit the Rotation At Rest, Position At Rest, Position Offset, and Rotation Offset properties. If Is Active is enabled, the Constraint updates the Rotation At Rest, Position At Rest, Position Offset, or Rotation Offset properties for you as you move and rotate the GameObject or its Source GameObjects. When you are satisfied with your changes, enable Lock to let the Constraint to control this GameObject. This property has no effect in Play mode. |
Position At Rest | The X, Y, and Z values to use when Weight is 0 or when the corresponding Freeze Position Axes aren’t enabled. To edit these fields, disable Lock. |
Rotation At Rest | The X, Y, and Z values to use when Weight is 0 or when the corresponding Freeze Rotation Axes aren’t enabled. To edit these fields, disable Lock. |
Position Offset | The X, Y, and Z position offset from the Transform that the Constraint imposes. To edit these fields, disable Lock. |
Rotation Offset | The X, Y, and Z rotation offset from the Transform that the Constraint imposes. To edit these fields, disable Lock. |
Freeze Position Axes | Enable X, Y, or Z to allow the Constraint to control the corresponding position axes. Disable an axis to stop the Constraint from controlling it, which allows you to edit, animate, or script it. |
Freeze Rotation Axes | Enable X, Y, or Z to allow the Constraint to control the corresponding rotation axes. Disable an axis to stop the Constraint from controlling it, which allows you to edit, animate, or script it. |
The list of GameObjects that constrain this GameObject. Unity evaluates source GameObjects in the order they appear in this list. This order affects how this Constraint moves and rotates the constrained GameObject. To get the result you want, drag items in this list. Each source has a weight from 0 to 1.
Did you find this page useful? Please give it a rating:
Thanks for rating this page!
What kind of problem would you like to report?
Thanks for letting us know! This page has been marked for review based on your feedback.
If you have time, you can provide more information to help us fix the problem faster.
Provide more information
You've told us this page needs code samples. If you'd like to help us further, you could provide a code sample, or tell us about what kind of code sample you'd like to see:
You've told us there are code samples on this page which don't work. If you know how to fix it, or have something better we could use instead, please let us know:
You've told us there is information missing from this page. Please tell us more about what's missing:
You've told us there is incorrect information on this page. If you know what we should change to make it correct, please tell us:
You've told us this page has unclear or confusing information. Please tell us more about what you found unclear or confusing, or let us know how we could make it clearer:
You've told us there is a spelling or grammar error on this page. Please tell us what's wrong:
You've told us this page has a problem. Please tell us more about what's wrong:
Thank you for helping to make the Unity documentation better!
Your feedback has been submitted as a ticket for our documentation team to review.
We are not able to reply to every ticket submitted.