Backport improved look_at docs and errors
Take extra constraint info and function description from Node3D.look_at to improve Spatial.look_at docs. Add an explicit error for up == 0
This commit is contained in:
parent
9cdd110cc3
commit
83298da9b8
2 changed files with 4 additions and 2 deletions
|
@ -94,8 +94,9 @@
|
||||||
<argument index="0" name="target" type="Vector3" />
|
<argument index="0" name="target" type="Vector3" />
|
||||||
<argument index="1" name="up" type="Vector3" />
|
<argument index="1" name="up" type="Vector3" />
|
||||||
<description>
|
<description>
|
||||||
Rotates itself so that the local -Z axis points towards the [code]target[/code] position.
|
Rotates the node so that the local forward axis (-Z) points toward the [code]target[/code] position.
|
||||||
The transform will first be rotated around the given [code]up[/code] vector, and then fully aligned to the target by a further rotation around an axis perpendicular to both the [code]target[/code] and [code]up[/code] vectors.
|
The local up axis (+Y) points as close to the [code]up[/code] vector as possible while staying perpendicular to the local forward axis. The resulting transform is orthogonal, and the scale is preserved. Non-uniform scaling may not work correctly.
|
||||||
|
The [code]target[/code] position cannot be the same as the node's position, the [code]up[/code] vector cannot be zero, and the direction from the node's position to the [code]target[/code] vector cannot be parallel to the [code]up[/code] vector.
|
||||||
Operations take place in global space.
|
Operations take place in global space.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
|
|
|
@ -668,6 +668,7 @@ void Spatial::look_at(const Vector3 &p_target, const Vector3 &p_up) {
|
||||||
|
|
||||||
void Spatial::look_at_from_position(const Vector3 &p_pos, const Vector3 &p_target, const Vector3 &p_up) {
|
void Spatial::look_at_from_position(const Vector3 &p_pos, const Vector3 &p_target, const Vector3 &p_up) {
|
||||||
ERR_FAIL_COND_MSG(p_pos == p_target, "Node origin and target are in the same position, look_at() failed.");
|
ERR_FAIL_COND_MSG(p_pos == p_target, "Node origin and target are in the same position, look_at() failed.");
|
||||||
|
ERR_FAIL_COND_MSG(p_up == Vector3(), "The up vector can't be zero, look_at() failed.");
|
||||||
ERR_FAIL_COND_MSG(p_up.cross(p_target - p_pos) == Vector3(), "Up vector and direction between node origin and target are aligned, look_at() failed.");
|
ERR_FAIL_COND_MSG(p_up.cross(p_target - p_pos) == Vector3(), "Up vector and direction between node origin and target are aligned, look_at() failed.");
|
||||||
|
|
||||||
Transform lookat;
|
Transform lookat;
|
||||||
|
|
Loading…
Reference in a new issue