Removed incorrect Basis::set_scale().

Also added a missing constructor in Basis, and fixed usage of inverse and affine inverse in Transform.
This commit is contained in:
tagcup 2018-05-16 20:32:35 -04:00
parent ba134d44b8
commit 1bba6eeeb9
4 changed files with 11 additions and 21 deletions

View file

@ -242,18 +242,11 @@ void Basis::scale_local(const Vector3 &p_scale) {
Basis Basis::scaled_local(const Vector3 &p_scale) const { Basis Basis::scaled_local(const Vector3 &p_scale) const {
Basis b; Basis b;
b.set_scale(p_scale); b.set_diagonal(p_scale);
return (*this) * b; return (*this) * b;
} }
void Basis::set_scale(const Vector3 &p_scale) {
set_axis(0, get_axis(0).normalized() * p_scale.x);
set_axis(1, get_axis(1).normalized() * p_scale.y);
set_axis(2, get_axis(2).normalized() * p_scale.z);
}
Vector3 Basis::get_scale_abs() const { Vector3 Basis::get_scale_abs() const {
return Vector3( return Vector3(

View file

@ -110,7 +110,6 @@ public:
void scale_local(const Vector3 &p_scale); void scale_local(const Vector3 &p_scale);
Basis scaled_local(const Vector3 &p_scale) const; Basis scaled_local(const Vector3 &p_scale) const;
void set_scale(const Vector3 &p_scale);
Vector3 get_scale() const; Vector3 get_scale() const;
Vector3 get_scale_abs() const; Vector3 get_scale_abs() const;
Vector3 get_scale_local() const; Vector3 get_scale_local() const;
@ -230,10 +229,13 @@ public:
operator Quat() const { return get_quat(); } operator Quat() const { return get_quat(); }
Basis(const Quat &p_quat) { set_quat(p_quat); }; Basis(const Quat &p_quat) { set_quat(p_quat); };
Basis(const Quat &p_quat, const Vector3 &p_scale) { set_quat_scale(p_quat, p_scale); }
Basis(const Vector3 &p_euler) { set_euler(p_euler); } Basis(const Vector3 &p_euler) { set_euler(p_euler); }
Basis(const Vector3 &p_euler, const Vector3 &p_scale) { set_euler_scale(p_euler, p_scale); }
Basis(const Vector3 &p_axis, real_t p_phi) { set_axis_angle(p_axis, p_phi); } Basis(const Vector3 &p_axis, real_t p_phi) { set_axis_angle(p_axis, p_phi); }
Basis(const Vector3 &p_axis, real_t p_phi, const Vector3 &p_scale) { set_axis_angle_scale(p_axis, p_phi, p_scale); } Basis(const Vector3 &p_axis, real_t p_phi, const Vector3 &p_scale) { set_axis_angle_scale(p_axis, p_phi, p_scale); }
Basis(const Quat &p_quat, const Vector3 &p_scale) { set_quat_scale(p_quat, p_scale); }
_FORCE_INLINE_ Basis(const Vector3 &row0, const Vector3 &row1, const Vector3 &row2) { _FORCE_INLINE_ Basis(const Vector3 &row0, const Vector3 &row1, const Vector3 &row2) {
elements[0] = row0; elements[0] = row0;

View file

@ -127,12 +127,11 @@ Transform Transform::interpolate_with(const Transform &p_transform, real_t p_c)
Quat dst_rot = p_transform.basis; Quat dst_rot = p_transform.basis;
Vector3 dst_loc = p_transform.origin; Vector3 dst_loc = p_transform.origin;
Transform dst; //this could be made faster by using a single function in Basis.. Transform interp;
dst.basis = src_rot.slerp(dst_rot, p_c).normalized(); interp.basis.set_quat_scale(src_rot.slerp(dst_rot, p_c).normalized(), src_scale.linear_interpolate(dst_scale, p_c));
dst.basis.set_scale(src_scale.linear_interpolate(dst_scale, p_c)); interp.origin = src_loc.linear_interpolate(dst_loc, p_c);
dst.origin = src_loc.linear_interpolate(dst_loc, p_c);
return dst; return interp;
} }
void Transform::scale(const Vector3 &p_scale) { void Transform::scale(const Vector3 &p_scale) {

View file

@ -632,19 +632,15 @@ void Spatial::scale_object_local(const Vector3 &p_scale) {
void Spatial::global_rotate(const Vector3 &p_axis, float p_angle) { void Spatial::global_rotate(const Vector3 &p_axis, float p_angle) {
Basis rotation(p_axis, p_angle);
Transform t = get_global_transform(); Transform t = get_global_transform();
t.basis = rotation * t.basis; t.basis.rotate(p_axis, p_angle);
set_global_transform(t); set_global_transform(t);
} }
void Spatial::global_scale(const Vector3 &p_scale) { void Spatial::global_scale(const Vector3 &p_scale) {
Basis s;
s.set_scale(p_scale);
Transform t = get_global_transform(); Transform t = get_global_transform();
t.basis = s * t.basis; t.basis.scale(p_scale);
set_global_transform(t); set_global_transform(t);
} }