Expose get_skew for transform2d and add new constructor

Expose set_scale and set_skew for transform2d

Replacing float by real_t

Adding const parameters

Updated transform2d doc
This commit is contained in:
Vincent D 2021-09-02 11:36:19 +02:00
parent 18c0f0b3ba
commit aa82cb6f35
5 changed files with 74 additions and 29 deletions

View File

@ -63,7 +63,7 @@ Transform2D Transform2D::affine_inverse() const {
return inv; return inv;
} }
void Transform2D::rotate(real_t p_phi) { void Transform2D::rotate(const real_t p_phi) {
*this = Transform2D(p_phi, Vector2()) * (*this); *this = Transform2D(p_phi, Vector2()) * (*this);
} }
@ -72,7 +72,7 @@ real_t Transform2D::get_skew() const {
return Math::acos(elements[0].normalized().dot(SGN(det) * elements[1].normalized())) - Math_PI * 0.5; return Math::acos(elements[0].normalized().dot(SGN(det) * elements[1].normalized())) - Math_PI * 0.5;
} }
void Transform2D::set_skew(float p_angle) { void Transform2D::set_skew(const real_t p_angle) {
real_t det = basis_determinant(); real_t det = basis_determinant();
elements[1] = SGN(det) * elements[0].rotated((Math_PI * 0.5 + p_angle)).normalized() * elements[1].length(); elements[1] = SGN(det) * elements[0].rotated((Math_PI * 0.5 + p_angle)).normalized() * elements[1].length();
} }
@ -81,7 +81,7 @@ real_t Transform2D::get_rotation() const {
return Math::atan2(elements[0].y, elements[0].x); return Math::atan2(elements[0].y, elements[0].x);
} }
void Transform2D::set_rotation(real_t p_rot) { void Transform2D::set_rotation(const real_t p_rot) {
Size2 scale = get_scale(); Size2 scale = get_scale();
real_t cr = Math::cos(p_rot); real_t cr = Math::cos(p_rot);
real_t sr = Math::sin(p_rot); real_t sr = Math::sin(p_rot);
@ -92,7 +92,7 @@ void Transform2D::set_rotation(real_t p_rot) {
set_scale(scale); set_scale(scale);
} }
Transform2D::Transform2D(real_t p_rot, const Vector2 &p_pos) { Transform2D::Transform2D(const real_t p_rot, const Vector2 &p_pos) {
real_t cr = Math::cos(p_rot); real_t cr = Math::cos(p_rot);
real_t sr = Math::sin(p_rot); real_t sr = Math::sin(p_rot);
elements[0][0] = cr; elements[0][0] = cr;
@ -102,6 +102,14 @@ Transform2D::Transform2D(real_t p_rot, const Vector2 &p_pos) {
elements[2] = p_pos; elements[2] = p_pos;
} }
Transform2D::Transform2D(const real_t p_rot, const Size2 &p_scale, const real_t p_skew, const Vector2 &p_pos) {
elements[0][0] = Math::cos(p_rot) * p_scale.x;
elements[1][1] = Math::cos(p_rot + p_skew) * p_scale.y;
elements[1][0] = -Math::sin(p_rot + p_skew) * p_scale.y;
elements[0][1] = Math::sin(p_rot) * p_scale.x;
elements[2] = p_pos;
}
Size2 Transform2D::get_scale() const { Size2 Transform2D::get_scale() const {
real_t det_sign = SGN(basis_determinant()); real_t det_sign = SGN(basis_determinant());
return Size2(elements[0].length(), det_sign * elements[1].length()); return Size2(elements[0].length(), det_sign * elements[1].length());
@ -126,7 +134,7 @@ void Transform2D::scale_basis(const Size2 &p_scale) {
elements[1][1] *= p_scale.y; elements[1][1] *= p_scale.y;
} }
void Transform2D::translate(real_t p_tx, real_t p_ty) { void Transform2D::translate(const real_t p_tx, const real_t p_ty) {
translate(Vector2(p_tx, p_ty)); translate(Vector2(p_tx, p_ty));
} }
@ -231,7 +239,7 @@ Transform2D Transform2D::translated(const Vector2 &p_offset) const {
return copy; return copy;
} }
Transform2D Transform2D::rotated(real_t p_phi) const { Transform2D Transform2D::rotated(const real_t p_phi) const {
Transform2D copy = *this; Transform2D copy = *this;
copy.rotate(p_phi); copy.rotate(p_phi);
return copy; return copy;
@ -241,7 +249,7 @@ real_t Transform2D::basis_determinant() const {
return elements[0].x * elements[1].y - elements[0].y * elements[1].x; return elements[0].x * elements[1].y - elements[0].y * elements[1].x;
} }
Transform2D Transform2D::interpolate_with(const Transform2D &p_transform, real_t p_c) const { Transform2D Transform2D::interpolate_with(const Transform2D &p_transform, const real_t p_c) const {
//extract parameters //extract parameters
Vector2 p1 = get_origin(); Vector2 p1 = get_origin();
Vector2 p2 = p_transform.get_origin(); Vector2 p2 = p_transform.get_origin();

View File

@ -68,17 +68,17 @@ struct Transform2D {
void affine_invert(); void affine_invert();
Transform2D affine_inverse() const; Transform2D affine_inverse() const;
void set_rotation(real_t p_rot); void set_rotation(const real_t p_rot);
real_t get_rotation() const; real_t get_rotation() const;
real_t get_skew() const; real_t get_skew() const;
void set_skew(float p_angle); void set_skew(const real_t p_angle);
_FORCE_INLINE_ void set_rotation_and_scale(real_t p_rot, const Size2 &p_scale); _FORCE_INLINE_ void set_rotation_and_scale(const real_t p_rot, const Size2 &p_scale);
_FORCE_INLINE_ void set_rotation_scale_and_skew(real_t p_rot, const Size2 &p_scale, float p_skew); _FORCE_INLINE_ void set_rotation_scale_and_skew(const real_t p_rot, const Size2 &p_scale, const real_t p_skew);
void rotate(real_t p_phi); void rotate(const real_t p_phi);
void scale(const Size2 &p_scale); void scale(const Size2 &p_scale);
void scale_basis(const Size2 &p_scale); void scale_basis(const Size2 &p_scale);
void translate(real_t p_tx, real_t p_ty); void translate(const real_t p_tx, const real_t p_ty);
void translate(const Vector2 &p_translation); void translate(const Vector2 &p_translation);
real_t basis_determinant() const; real_t basis_determinant() const;
@ -92,7 +92,7 @@ struct Transform2D {
Transform2D scaled(const Size2 &p_scale) const; Transform2D scaled(const Size2 &p_scale) const;
Transform2D basis_scaled(const Size2 &p_scale) const; Transform2D basis_scaled(const Size2 &p_scale) const;
Transform2D translated(const Vector2 &p_offset) const; Transform2D translated(const Vector2 &p_offset) const;
Transform2D rotated(real_t p_phi) const; Transform2D rotated(const real_t p_phi) const;
Transform2D untranslated() const; Transform2D untranslated() const;
@ -110,7 +110,7 @@ struct Transform2D {
void operator*=(const real_t p_val); void operator*=(const real_t p_val);
Transform2D operator*(const real_t p_val) const; Transform2D operator*(const real_t p_val) const;
Transform2D interpolate_with(const Transform2D &p_transform, real_t p_c) const; Transform2D interpolate_with(const Transform2D &p_transform, const real_t p_c) const;
_FORCE_INLINE_ Vector2 basis_xform(const Vector2 &p_vec) const; _FORCE_INLINE_ Vector2 basis_xform(const Vector2 &p_vec) const;
_FORCE_INLINE_ Vector2 basis_xform_inv(const Vector2 &p_vec) const; _FORCE_INLINE_ Vector2 basis_xform_inv(const Vector2 &p_vec) const;
@ -123,7 +123,7 @@ struct Transform2D {
operator String() const; operator String() const;
Transform2D(real_t xx, real_t xy, real_t yx, real_t yy, real_t ox, real_t oy) { Transform2D(const real_t xx, const real_t xy, const real_t yx, const real_t yy, const real_t ox, const real_t oy) {
elements[0][0] = xx; elements[0][0] = xx;
elements[0][1] = xy; elements[0][1] = xy;
elements[1][0] = yx; elements[1][0] = yx;
@ -138,7 +138,10 @@ struct Transform2D {
elements[2] = p_origin; elements[2] = p_origin;
} }
Transform2D(real_t p_rot, const Vector2 &p_pos); Transform2D(const real_t p_rot, const Vector2 &p_pos);
Transform2D(const real_t p_rot, const Size2 &p_scale, const real_t p_skew, const Vector2 &p_pos);
Transform2D() { Transform2D() {
elements[0][0] = 1.0; elements[0][0] = 1.0;
elements[1][1] = 1.0; elements[1][1] = 1.0;
@ -185,14 +188,14 @@ Rect2 Transform2D::xform(const Rect2 &p_rect) const {
return new_rect; return new_rect;
} }
void Transform2D::set_rotation_and_scale(real_t p_rot, const Size2 &p_scale) { void Transform2D::set_rotation_and_scale(const real_t p_rot, const Size2 &p_scale) {
elements[0][0] = Math::cos(p_rot) * p_scale.x; elements[0][0] = Math::cos(p_rot) * p_scale.x;
elements[1][1] = Math::cos(p_rot) * p_scale.y; elements[1][1] = Math::cos(p_rot) * p_scale.y;
elements[1][0] = -Math::sin(p_rot) * p_scale.y; elements[1][0] = -Math::sin(p_rot) * p_scale.y;
elements[0][1] = Math::sin(p_rot) * p_scale.x; elements[0][1] = Math::sin(p_rot) * p_scale.x;
} }
void Transform2D::set_rotation_scale_and_skew(real_t p_rot, const Size2 &p_scale, float p_skew) { void Transform2D::set_rotation_scale_and_skew(const real_t p_rot, const Size2 &p_scale, const real_t p_skew) {
elements[0][0] = Math::cos(p_rot) * p_scale.x; elements[0][0] = Math::cos(p_rot) * p_scale.x;
elements[1][1] = Math::cos(p_rot + p_skew) * p_scale.y; elements[1][1] = Math::cos(p_rot + p_skew) * p_scale.y;
elements[1][0] = -Math::sin(p_rot + p_skew) * p_scale.y; elements[1][0] = -Math::sin(p_rot + p_skew) * p_scale.y;

View File

@ -1703,6 +1703,7 @@ static void _register_variant_builtin_methods() {
bind_method(Transform2D, get_rotation, sarray(), varray()); bind_method(Transform2D, get_rotation, sarray(), varray());
bind_method(Transform2D, get_origin, sarray(), varray()); bind_method(Transform2D, get_origin, sarray(), varray());
bind_method(Transform2D, get_scale, sarray(), varray()); bind_method(Transform2D, get_scale, sarray(), varray());
bind_method(Transform2D, get_skew, sarray(), varray());
bind_method(Transform2D, orthonormalized, sarray(), varray()); bind_method(Transform2D, orthonormalized, sarray(), varray());
bind_method(Transform2D, rotated, sarray("phi"), varray()); bind_method(Transform2D, rotated, sarray("phi"), varray());
bind_method(Transform2D, scaled, sarray("scale"), varray()); bind_method(Transform2D, scaled, sarray("scale"), varray());
@ -1712,6 +1713,8 @@ static void _register_variant_builtin_methods() {
bind_method(Transform2D, interpolate_with, sarray("xform", "weight"), varray()); bind_method(Transform2D, interpolate_with, sarray("xform", "weight"), varray());
bind_method(Transform2D, is_equal_approx, sarray("xform"), varray()); bind_method(Transform2D, is_equal_approx, sarray("xform"), varray());
bind_method(Transform2D, set_rotation, sarray("rotation"), varray()); bind_method(Transform2D, set_rotation, sarray("rotation"), varray());
bind_method(Transform2D, set_scale, sarray("scale"), varray());
bind_method(Transform2D, set_skew, sarray("skew"), varray());
bind_method(Transform2D, looking_at, sarray("target"), varray(Vector2())); bind_method(Transform2D, looking_at, sarray("target"), varray(Vector2()));
/* Basis */ /* Basis */

View File

@ -114,6 +114,7 @@ void Variant::_register_variant_constructors() {
add_constructor<VariantConstructNoArgs<Transform2D>>(sarray()); add_constructor<VariantConstructNoArgs<Transform2D>>(sarray());
add_constructor<VariantConstructor<Transform2D, Transform2D>>(sarray("from")); add_constructor<VariantConstructor<Transform2D, Transform2D>>(sarray("from"));
add_constructor<VariantConstructor<Transform2D, float, Vector2>>(sarray("rotation", "position")); add_constructor<VariantConstructor<Transform2D, float, Vector2>>(sarray("rotation", "position"));
add_constructor<VariantConstructor<Transform2D, float, Size2, float, Vector2>>(sarray("rotation", "scale", "skew", "position"));
add_constructor<VariantConstructor<Transform2D, Vector2, Vector2, Vector2>>(sarray("x_axis", "y_axis", "origin")); add_constructor<VariantConstructor<Transform2D, Vector2, Vector2, Vector2>>(sarray("x_axis", "y_axis", "origin"));
add_constructor<VariantConstructNoArgs<Plane>>(sarray()); add_constructor<VariantConstructNoArgs<Plane>>(sarray());

View File

@ -35,6 +35,16 @@
Constructs the transform from a given angle (in radians) and position. Constructs the transform from a given angle (in radians) and position.
</description> </description>
</method> </method>
<method name="Transform2D" qualifiers="constructor">
<return type="Transform2D" />
<argument index="0" name="rotation" type="float" />
<argument index="1" name="scale" type="Vector2" />
<argument index="2" name="skew" type="float" />
<argument index="3" name="position" type="Vector2" />
<description>
Constructs the transform from a given angle (in radians), scale, skew (in radians) and position.
</description>
</method>
<method name="Transform2D" qualifiers="constructor"> <method name="Transform2D" qualifiers="constructor">
<return type="Transform2D" /> <return type="Transform2D" />
<argument index="0" name="x_axis" type="Vector2" /> <argument index="0" name="x_axis" type="Vector2" />
@ -84,6 +94,12 @@
Returns the scale. Returns the scale.
</description> </description>
</method> </method>
<method name="get_skew" qualifiers="const">
<return type="float" />
<description>
Returns the transform's skew (in radians).
</description>
</method>
<method name="interpolate_with" qualifiers="const"> <method name="interpolate_with" qualifiers="const">
<return type="Transform2D" /> <return type="Transform2D" />
<argument index="0" name="xform" type="Transform2D" /> <argument index="0" name="xform" type="Transform2D" />
@ -120,14 +136,8 @@
</description> </description>
</method> </method>
<method name="operator *" qualifiers="operator"> <method name="operator *" qualifiers="operator">
<return type="Vector2" /> <return type="PackedVector2Array" />
<argument index="0" name="right" type="Vector2" /> <argument index="0" name="right" type="PackedVector2Array" />
<description>
</description>
</method>
<method name="operator *" qualifiers="operator">
<return type="Rect2" />
<argument index="0" name="right" type="Rect2" />
<description> <description>
</description> </description>
</method> </method>
@ -138,8 +148,14 @@
</description> </description>
</method> </method>
<method name="operator *" qualifiers="operator"> <method name="operator *" qualifiers="operator">
<return type="PackedVector2Array" /> <return type="Rect2" />
<argument index="0" name="right" type="PackedVector2Array" /> <argument index="0" name="right" type="Rect2" />
<description>
</description>
</method>
<method name="operator *" qualifiers="operator">
<return type="Vector2" />
<argument index="0" name="right" type="Vector2" />
<description> <description>
</description> </description>
</method> </method>
@ -196,6 +212,20 @@
Sets the transform's rotation (in radians). Sets the transform's rotation (in radians).
</description> </description>
</method> </method>
<method name="set_scale">
<return type="void" />
<argument index="0" name="scale" type="Vector2" />
<description>
Sets the transform's scale.
</description>
</method>
<method name="set_skew">
<return type="void" />
<argument index="0" name="skew" type="float" />
<description>
Sets the transform's skew (in radians).
</description>
</method>
<method name="translated" qualifiers="const"> <method name="translated" qualifiers="const">
<return type="Transform2D" /> <return type="Transform2D" />
<argument index="0" name="offset" type="Vector2" /> <argument index="0" name="offset" type="Vector2" />