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. However, it offers certain advantages that are not possible when you make one GameObject the parent of another:
A Parent Constraint does not affect scale.
A Parent Constraint can link to multiple GameObjects.
A GameObject does not have to be a child of the GameObjects that the Parent Constraint links to.
You can vary the effect of the Constraint by specifying a weight, as well as weights for each of its source GameObjects.
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: | Function: | |
---|---|---|
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 checks 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 checks Is Active and Lock. | |
Is Active | Toggles whether or not to evaluate the Constraint. To also apply the Constraint, make sure Lock is checked. | |
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. | |
Constraint Settings | ||
Lock | Toggle to let the Constraint move and rotate the GameObject. Uncheck 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 checked, 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, check 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 are not checked. To edit these fields, uncheck Lock. | |
Rotation At Rest | The X, Y, and Z values to use when Weight is 0 or when the corresponding Freeze Rotation Axes are not checked. To edit these fields, uncheck Lock. | |
Position Offset | The X, Y, and Z position offset from the Transform that the Constraint imposes. To edit these fields, uncheck Lock. | |
Rotation Offset | The X, Y, and Z rotation offset from the Transform that the Constraint imposes. To edit these fields, uncheck Lock. | |
Freeze Position Axes | Check X, Y, or Z to allow the Constraint to control the corresponding position axes. Uncheck an axis to stop the Constraint from controlling it, which allows you to edit, animate, or script it. | |
Freeze Rotation Axes | Check X, Y, or Z to allow the Constraint to control the corresponding rotation axes. Uncheck an axis to stop the Constraint from controlling it, which allows you to edit, animate, or script it. | |
Sources | 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 and drop items in this list. Each source has a weight from 0 to 1. |
2018–03–13 Page published with editorial review
Constraints added in 2018.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?
Is something described here not working as you expect it to? It might be a Known Issue. Please check with the Issue Tracker at issuetracker.unity3d.com.
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:
Thanks for helping to make the Unity documentation better!