Merge pull request #66383 from aaronfranke/basis-from-euler

Clean up Basis from Euler code
This commit is contained in:
Clay John 2022-10-27 09:44:21 -07:00 committed by GitHub
commit 682156e1f0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
10 changed files with 15 additions and 18 deletions

View File

@ -1930,7 +1930,7 @@ static void _register_variant_builtin_methods() {
bind_methodv(Basis, rotated, static_cast<Basis (Basis::*)(const Vector3 &, real_t) const>(&Basis::rotated), sarray("axis", "angle"), varray()); bind_methodv(Basis, rotated, static_cast<Basis (Basis::*)(const Vector3 &, real_t) const>(&Basis::rotated), sarray("axis", "angle"), varray());
bind_method(Basis, scaled, sarray("scale"), varray()); bind_method(Basis, scaled, sarray("scale"), varray());
bind_method(Basis, get_scale, sarray(), varray()); bind_method(Basis, get_scale, sarray(), varray());
bind_method(Basis, get_euler, sarray("order"), varray(Basis::EULER_ORDER_YXZ)); bind_method(Basis, get_euler, sarray("order"), varray((int64_t)Basis::EULER_ORDER_YXZ));
bind_method(Basis, tdotx, sarray("with"), varray()); bind_method(Basis, tdotx, sarray("with"), varray());
bind_method(Basis, tdoty, sarray("with"), varray()); bind_method(Basis, tdoty, sarray("with"), varray());
bind_method(Basis, tdotz, sarray("with"), varray()); bind_method(Basis, tdotz, sarray("with"), varray());
@ -1940,7 +1940,7 @@ static void _register_variant_builtin_methods() {
bind_method(Basis, get_rotation_quaternion, sarray(), varray()); bind_method(Basis, get_rotation_quaternion, sarray(), varray());
bind_static_method(Basis, looking_at, sarray("target", "up"), varray(Vector3(0, 1, 0))); bind_static_method(Basis, looking_at, sarray("target", "up"), varray(Vector3(0, 1, 0)));
bind_static_method(Basis, from_scale, sarray("scale"), varray()); bind_static_method(Basis, from_scale, sarray("scale"), varray());
bind_static_method(Basis, from_euler, sarray("euler", "order"), varray(Basis::EULER_ORDER_YXZ)); bind_static_method(Basis, from_euler, sarray("euler", "order"), varray((int64_t)Basis::EULER_ORDER_YXZ));
/* AABB */ /* AABB */

View File

@ -826,7 +826,7 @@ VARIANT_ACCESSOR_NUMBER(Projection::Planes)
template <> template <>
struct VariantInternalAccessor<Basis::EulerOrder> { struct VariantInternalAccessor<Basis::EulerOrder> {
static _FORCE_INLINE_ Basis::EulerOrder get(const Variant *v) { return Basis::EulerOrder(*VariantInternal::get_int(v)); } static _FORCE_INLINE_ Basis::EulerOrder get(const Variant *v) { return Basis::EulerOrder(*VariantInternal::get_int(v)); }
static _FORCE_INLINE_ void set(Variant *v, Basis::EulerOrder p_value) { *VariantInternal::get_int(v) = p_value; } static _FORCE_INLINE_ void set(Variant *v, Basis::EulerOrder p_value) { *VariantInternal::get_int(v) = (int64_t)p_value; }
}; };
template <> template <>

View File

@ -70,7 +70,7 @@
<param index="0" name="euler" type="Vector3" /> <param index="0" name="euler" type="Vector3" />
<param index="1" name="order" type="int" default="2" /> <param index="1" name="order" type="int" default="2" />
<description> <description>
Creates a [Basis] from the given [Vector3] representing Euler angles. [param order] determines in what order rotation components are applied. Defaults to [constant EULER_ORDER_YXZ]. Constructs a pure rotation Basis matrix from Euler angles in the specified Euler rotation order. By default, use YXZ order (most common).
</description> </description>
</method> </method>
<method name="from_scale" qualifiers="static"> <method name="from_scale" qualifiers="static">

View File

@ -474,7 +474,7 @@ Transform3D ResourceImporterScene::get_collision_shapes_transform(const M &p_opt
} }
if (p_options.has(SNAME("primitive/rotation"))) { if (p_options.has(SNAME("primitive/rotation"))) {
transform.basis.set_euler((p_options[SNAME("primitive/rotation")].operator Vector3() / 180.0) * Math_PI); transform.basis = Basis::from_euler(p_options[SNAME("primitive/rotation")].operator Vector3() * (Math_PI / 180.0));
} }
} }
return transform; return transform;

View File

@ -2986,7 +2986,7 @@ void Node3DEditorViewport::_menu_option(int p_option) {
Transform3D xform; Transform3D xform;
if (orthogonal) { if (orthogonal) {
xform = sp->get_global_transform(); xform = sp->get_global_transform();
xform.basis.set_euler(camera_transform.basis.get_euler()); xform.basis = Basis::from_euler(camera_transform.basis.get_euler());
} else { } else {
xform = camera_transform; xform = camera_transform;
xform.scale_basis(sp->get_scale()); xform.scale_basis(sp->get_scale());
@ -7615,7 +7615,7 @@ void Node3DEditor::_preview_settings_changed() {
{ // preview sun { // preview sun
Transform3D t; Transform3D t;
t.basis = Basis(Vector3(sun_rotation.x, sun_rotation.y, 0)); t.basis = Basis::from_euler(Vector3(sun_rotation.x, sun_rotation.y, 0));
preview_sun->set_transform(t); preview_sun->set_transform(t);
sun_direction->queue_redraw(); sun_direction->queue_redraw();
preview_sun->set_param(Light3D::PARAM_ENERGY, sun_energy->get_value()); preview_sun->set_param(Light3D::PARAM_ENERGY, sun_energy->get_value());

View File

@ -253,9 +253,7 @@ Vector3 Node3D::get_global_rotation() const {
void Node3D::set_global_rotation(const Vector3 &p_euler_rad) { void Node3D::set_global_rotation(const Vector3 &p_euler_rad) {
Transform3D transform = get_global_transform(); Transform3D transform = get_global_transform();
Basis new_basis = transform.get_basis(); transform.basis = Basis::from_euler(p_euler_rad);
new_basis.set_euler(p_euler_rad);
transform.set_basis(new_basis);
set_global_transform(transform); set_global_transform(transform);
} }

View File

@ -78,7 +78,7 @@ float Environment::get_sky_custom_fov() const {
void Environment::set_sky_rotation(const Vector3 &p_rotation) { void Environment::set_sky_rotation(const Vector3 &p_rotation) {
bg_sky_rotation = p_rotation; bg_sky_rotation = p_rotation;
RS::get_singleton()->environment_set_sky_orientation(environment, Basis(p_rotation)); RS::get_singleton()->environment_set_sky_orientation(environment, Basis::from_euler(p_rotation));
} }
Vector3 Environment::get_sky_rotation() const { Vector3 Environment::get_sky_rotation() const {

View File

@ -1620,7 +1620,7 @@ void RendererCanvasRenderRD::light_update_shadow(RID p_rid, int p_shadow_index,
projection.set_frustum(xmin, xmax, ymin, ymax, nearp, farp); projection.set_frustum(xmin, xmax, ymin, ymax, nearp, farp);
} }
Vector3 cam_target = Basis(Vector3(0, 0, Math_TAU * ((i + 3) / 4.0))).xform(Vector3(0, 1, 0)); Vector3 cam_target = Basis::from_euler(Vector3(0, 0, Math_TAU * ((i + 3) / 4.0))).xform(Vector3(0, 1, 0));
projection = projection * Projection(Transform3D().looking_at(cam_target, Vector3(0, 0, -1)).affine_inverse()); projection = projection * Projection(Transform3D().looking_at(cam_target, Vector3(0, 0, -1)).affine_inverse());
ShadowRenderPushConstant push_constant; ShadowRenderPushConstant push_constant;

View File

@ -170,8 +170,7 @@ void test_rotation(Vector3 deg_original_euler, RotOrder rot_order) {
// Double check `to_rotation` decomposing with XYZ rotation order. // Double check `to_rotation` decomposing with XYZ rotation order.
const Vector3 euler_xyz_from_rotation = to_rotation.get_euler(Basis::EULER_ORDER_XYZ); const Vector3 euler_xyz_from_rotation = to_rotation.get_euler(Basis::EULER_ORDER_XYZ);
Basis rotation_from_xyz_computed_euler; Basis rotation_from_xyz_computed_euler = Basis::from_euler(euler_xyz_from_rotation, Basis::EULER_ORDER_XYZ);
rotation_from_xyz_computed_euler.set_euler(euler_xyz_from_rotation, Basis::EULER_ORDER_XYZ);
res = to_rotation.inverse() * rotation_from_xyz_computed_euler; res = to_rotation.inverse() * rotation_from_xyz_computed_euler;

View File

@ -192,7 +192,7 @@ TEST_CASE("[Quaternion] Construct Basis Euler") {
double roll = Math::deg_to_rad(10.0); double roll = Math::deg_to_rad(10.0);
Vector3 euler_yxz(pitch, yaw, roll); Vector3 euler_yxz(pitch, yaw, roll);
Quaternion q_yxz(euler_yxz); Quaternion q_yxz(euler_yxz);
Basis basis_axes(euler_yxz); Basis basis_axes = Basis::from_euler(euler_yxz);
Quaternion q(basis_axes); Quaternion q(basis_axes);
CHECK(q.is_equal_approx(q_yxz)); CHECK(q.is_equal_approx(q_yxz));
} }
@ -218,7 +218,7 @@ TEST_CASE("[Quaternion] Construct Basis Axes") {
// This is by design, but may be subject to change. // This is by design, but may be subject to change.
// Workaround by constructing Basis from Euler angles. // Workaround by constructing Basis from Euler angles.
// basis_axes = Basis(i_unit, j_unit, k_unit); // basis_axes = Basis(i_unit, j_unit, k_unit);
Basis basis_axes(euler_yxz); Basis basis_axes = Basis::from_euler(euler_yxz);
Quaternion q(basis_axes); Quaternion q(basis_axes);
CHECK(basis_axes.get_column(0).is_equal_approx(i_unit)); CHECK(basis_axes.get_column(0).is_equal_approx(i_unit));
@ -334,7 +334,7 @@ TEST_CASE("[Quaternion] xform unit vectors") {
TEST_CASE("[Quaternion] xform vector") { TEST_CASE("[Quaternion] xform vector") {
// Arbitrary quaternion rotates an arbitrary vector. // Arbitrary quaternion rotates an arbitrary vector.
Vector3 euler_yzx(Math::deg_to_rad(31.41), Math::deg_to_rad(-49.16), Math::deg_to_rad(12.34)); Vector3 euler_yzx(Math::deg_to_rad(31.41), Math::deg_to_rad(-49.16), Math::deg_to_rad(12.34));
Basis basis_axes(euler_yzx); Basis basis_axes = Basis::from_euler(euler_yzx);
Quaternion q(basis_axes); Quaternion q(basis_axes);
Vector3 v_arb(3.0, 4.0, 5.0); Vector3 v_arb(3.0, 4.0, 5.0);
@ -347,7 +347,7 @@ TEST_CASE("[Quaternion] xform vector") {
// Test vector xform for a single combination of Quaternion and Vector. // Test vector xform for a single combination of Quaternion and Vector.
void test_quat_vec_rotate(Vector3 euler_yzx, Vector3 v_in) { void test_quat_vec_rotate(Vector3 euler_yzx, Vector3 v_in) {
Basis basis_axes(euler_yzx); Basis basis_axes = Basis::from_euler(euler_yzx);
Quaternion q(basis_axes); Quaternion q(basis_axes);
Vector3 v_rot = q.xform(v_in); Vector3 v_rot = q.xform(v_in);