Properly implement Basis constructor using Vector3 of Euler angles
Fixes #13104.
This commit is contained in:
parent
08e6590fd6
commit
a3f8dde502
@ -66,7 +66,7 @@ String Variant::get_type_name(Variant::Type p_type) {
|
|||||||
return "String";
|
return "String";
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
// math types
|
// math types
|
||||||
|
|
||||||
case VECTOR2: {
|
case VECTOR2: {
|
||||||
|
|
||||||
@ -513,6 +513,7 @@ bool Variant::can_convert_strict(Variant::Type p_type_from, Variant::Type p_type
|
|||||||
|
|
||||||
static const Type valid[] = {
|
static const Type valid[] = {
|
||||||
QUAT,
|
QUAT,
|
||||||
|
VECTOR3,
|
||||||
NIL
|
NIL
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -723,7 +724,7 @@ bool Variant::is_zero() const {
|
|||||||
|
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
// math types
|
// math types
|
||||||
|
|
||||||
case VECTOR2: {
|
case VECTOR2: {
|
||||||
|
|
||||||
@ -932,7 +933,7 @@ void Variant::reference(const Variant &p_variant) {
|
|||||||
memnew_placement(_data._mem, String(*reinterpret_cast<const String *>(p_variant._data._mem)));
|
memnew_placement(_data._mem, String(*reinterpret_cast<const String *>(p_variant._data._mem)));
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
// math types
|
// math types
|
||||||
|
|
||||||
case VECTOR2: {
|
case VECTOR2: {
|
||||||
|
|
||||||
@ -1632,7 +1633,9 @@ Variant::operator Basis() const {
|
|||||||
return *_data._basis;
|
return *_data._basis;
|
||||||
else if (type == QUAT)
|
else if (type == QUAT)
|
||||||
return *reinterpret_cast<const Quat *>(_data._mem);
|
return *reinterpret_cast<const Quat *>(_data._mem);
|
||||||
else if (type == TRANSFORM)
|
else if (type == VECTOR3) {
|
||||||
|
return Basis(*reinterpret_cast<const Vector3 *>(_data._mem));
|
||||||
|
} else if (type == TRANSFORM) // unexposed in Variant::can_convert?
|
||||||
return _data._transform->basis;
|
return _data._transform->basis;
|
||||||
else
|
else
|
||||||
return Basis();
|
return Basis();
|
||||||
@ -2502,7 +2505,7 @@ void Variant::operator=(const Variant &p_variant) {
|
|||||||
*reinterpret_cast<String *>(_data._mem) = *reinterpret_cast<const String *>(p_variant._data._mem);
|
*reinterpret_cast<String *>(_data._mem) = *reinterpret_cast<const String *>(p_variant._data._mem);
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
// math types
|
// math types
|
||||||
|
|
||||||
case VECTOR2: {
|
case VECTOR2: {
|
||||||
|
|
||||||
@ -2642,7 +2645,7 @@ uint32_t Variant::hash() const {
|
|||||||
|
|
||||||
return reinterpret_cast<const String *>(_data._mem)->hash();
|
return reinterpret_cast<const String *>(_data._mem)->hash();
|
||||||
} break;
|
} break;
|
||||||
// math types
|
// math types
|
||||||
|
|
||||||
case VECTOR2: {
|
case VECTOR2: {
|
||||||
|
|
||||||
|
@ -899,11 +899,6 @@ struct _VariantCall {
|
|||||||
r_ret = Basis(p_args[0]->operator Vector3(), p_args[1]->operator real_t());
|
r_ret = Basis(p_args[0]->operator Vector3(), p_args[1]->operator real_t());
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Basis_init3(Variant &r_ret, const Variant **p_args) {
|
|
||||||
|
|
||||||
r_ret = Basis(p_args[0]->operator Vector3());
|
|
||||||
}
|
|
||||||
|
|
||||||
static void Transform_init1(Variant &r_ret, const Variant **p_args) {
|
static void Transform_init1(Variant &r_ret, const Variant **p_args) {
|
||||||
|
|
||||||
Transform t;
|
Transform t;
|
||||||
@ -1799,7 +1794,6 @@ void register_variant_methods() {
|
|||||||
|
|
||||||
_VariantCall::add_constructor(_VariantCall::Basis_init1, Variant::BASIS, "x_axis", Variant::VECTOR3, "y_axis", Variant::VECTOR3, "z_axis", Variant::VECTOR3);
|
_VariantCall::add_constructor(_VariantCall::Basis_init1, Variant::BASIS, "x_axis", Variant::VECTOR3, "y_axis", Variant::VECTOR3, "z_axis", Variant::VECTOR3);
|
||||||
_VariantCall::add_constructor(_VariantCall::Basis_init2, Variant::BASIS, "axis", Variant::VECTOR3, "phi", Variant::REAL);
|
_VariantCall::add_constructor(_VariantCall::Basis_init2, Variant::BASIS, "axis", Variant::VECTOR3, "phi", Variant::REAL);
|
||||||
_VariantCall::add_constructor(_VariantCall::Basis_init3, Variant::BASIS, "euler", Variant::VECTOR3);
|
|
||||||
|
|
||||||
_VariantCall::add_constructor(_VariantCall::Transform_init1, Variant::TRANSFORM, "x_axis", Variant::VECTOR3, "y_axis", Variant::VECTOR3, "z_axis", Variant::VECTOR3, "origin", Variant::VECTOR3);
|
_VariantCall::add_constructor(_VariantCall::Transform_init1, Variant::TRANSFORM, "x_axis", Variant::VECTOR3, "y_axis", Variant::VECTOR3, "z_axis", Variant::VECTOR3, "origin", Variant::VECTOR3);
|
||||||
_VariantCall::add_constructor(_VariantCall::Transform_init2, Variant::TRANSFORM, "basis", Variant::BASIS, "origin", Variant::VECTOR3);
|
_VariantCall::add_constructor(_VariantCall::Transform_init2, Variant::TRANSFORM, "basis", Variant::BASIS, "origin", Variant::VECTOR3);
|
||||||
|
Loading…
Reference in New Issue
Block a user