Merge pull request #38430 from aaronfranke/transform3d

This commit is contained in:
Rémi Verschelde 2021-06-03 23:07:21 +02:00 committed by GitHub
commit 5d9cab3aeb
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
324 changed files with 2018 additions and 2021 deletions

View File

@ -583,7 +583,7 @@ void register_global_constants() {
BIND_CORE_ENUM_CONSTANT_CUSTOM("TYPE_QUAT", Variant::QUAT); BIND_CORE_ENUM_CONSTANT_CUSTOM("TYPE_QUAT", Variant::QUAT);
BIND_CORE_ENUM_CONSTANT_CUSTOM("TYPE_AABB", Variant::AABB); BIND_CORE_ENUM_CONSTANT_CUSTOM("TYPE_AABB", Variant::AABB);
BIND_CORE_ENUM_CONSTANT_CUSTOM("TYPE_BASIS", Variant::BASIS); BIND_CORE_ENUM_CONSTANT_CUSTOM("TYPE_BASIS", Variant::BASIS);
BIND_CORE_ENUM_CONSTANT_CUSTOM("TYPE_TRANSFORM", Variant::TRANSFORM); BIND_CORE_ENUM_CONSTANT_CUSTOM("TYPE_TRANSFORM3D", Variant::TRANSFORM3D);
BIND_CORE_ENUM_CONSTANT_CUSTOM("TYPE_COLOR", Variant::COLOR); BIND_CORE_ENUM_CONSTANT_CUSTOM("TYPE_COLOR", Variant::COLOR);
BIND_CORE_ENUM_CONSTANT_CUSTOM("TYPE_STRING_NAME", Variant::STRING_NAME); BIND_CORE_ENUM_CONSTANT_CUSTOM("TYPE_STRING_NAME", Variant::STRING_NAME);
BIND_CORE_ENUM_CONSTANT_CUSTOM("TYPE_NODE_PATH", Variant::NODE_PATH); BIND_CORE_ENUM_CONSTANT_CUSTOM("TYPE_NODE_PATH", Variant::NODE_PATH);

View File

@ -325,9 +325,9 @@ Error decode_variant(Variant &r_variant, const uint8_t *p_buffer, int p_len, int
} }
} break; } break;
case Variant::TRANSFORM: { case Variant::TRANSFORM3D: {
ERR_FAIL_COND_V(len < 4 * 12, ERR_INVALID_DATA); ERR_FAIL_COND_V(len < 4 * 12, ERR_INVALID_DATA);
Transform val; Transform3D val;
for (int i = 0; i < 3; i++) { for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++) { for (int j = 0; j < 3; j++) {
val.basis.elements[i][j] = decode_float(&buf[(i * 3 + j) * 4]); val.basis.elements[i][j] = decode_float(&buf[(i * 3 + j) * 4]);
@ -1138,9 +1138,9 @@ Error encode_variant(const Variant &p_variant, uint8_t *r_buffer, int &r_len, bo
r_len += 9 * 4; r_len += 9 * 4;
} break; } break;
case Variant::TRANSFORM: { case Variant::TRANSFORM3D: {
if (buf) { if (buf) {
Transform val = p_variant; Transform3D val = p_variant;
for (int i = 0; i < 3; i++) { for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++) { for (int j = 0; j < 3; j++) {
memcpy(&buf[(i * 3 + j) * 4], &val.basis.elements[i][j], sizeof(float)); memcpy(&buf[(i * 3 + j) * 4], &val.basis.elements[i][j], sizeof(float));

View File

@ -230,7 +230,7 @@ uint32_t PackedDataContainer::_pack(const Variant &p_data, Vector<uint8_t> &tmpd
case Variant::QUAT: case Variant::QUAT:
case Variant::AABB: case Variant::AABB:
case Variant::BASIS: case Variant::BASIS:
case Variant::TRANSFORM: case Variant::TRANSFORM3D:
case Variant::PACKED_BYTE_ARRAY: case Variant::PACKED_BYTE_ARRAY:
case Variant::PACKED_INT32_ARRAY: case Variant::PACKED_INT32_ARRAY:
case Variant::PACKED_INT64_ARRAY: case Variant::PACKED_INT64_ARRAY:

View File

@ -245,7 +245,7 @@ Error ResourceLoaderBinary::parse_variant(Variant &r_v) {
} break; } break;
case VARIANT_TRANSFORM: { case VARIANT_TRANSFORM: {
Transform v; Transform3D v;
v.basis.elements[0].x = f->get_real(); v.basis.elements[0].x = f->get_real();
v.basis.elements[0].y = f->get_real(); v.basis.elements[0].y = f->get_real();
v.basis.elements[0].z = f->get_real(); v.basis.elements[0].z = f->get_real();
@ -1416,9 +1416,9 @@ void ResourceFormatSaverBinaryInstance::write_variant(FileAccess *f, const Varia
f->store_real(val.elements[2].z); f->store_real(val.elements[2].z);
} break; } break;
case Variant::TRANSFORM: { case Variant::TRANSFORM3D: {
f->store_32(VARIANT_TRANSFORM); f->store_32(VARIANT_TRANSFORM);
Transform val = p_property; Transform3D val = p_property;
f->store_real(val.basis.elements[0].x); f->store_real(val.basis.elements[0].x);
f->store_real(val.basis.elements[0].y); f->store_real(val.basis.elements[0].y);
f->store_real(val.basis.elements[0].z); f->store_real(val.basis.elements[0].z);

View File

@ -315,8 +315,8 @@ Vector2 CameraMatrix::get_far_plane_half_extents() const {
return Vector2(res.x, res.y); return Vector2(res.x, res.y);
} }
bool CameraMatrix::get_endpoints(const Transform &p_transform, Vector3 *p_8points) const { bool CameraMatrix::get_endpoints(const Transform3D &p_transform, Vector3 *p_8points) const {
Vector<Plane> planes = get_projection_planes(Transform()); Vector<Plane> planes = get_projection_planes(Transform3D());
const Planes intersections[8][3] = { const Planes intersections[8][3] = {
{ PLANE_FAR, PLANE_LEFT, PLANE_TOP }, { PLANE_FAR, PLANE_LEFT, PLANE_TOP },
{ PLANE_FAR, PLANE_LEFT, PLANE_BOTTOM }, { PLANE_FAR, PLANE_LEFT, PLANE_BOTTOM },
@ -338,7 +338,7 @@ bool CameraMatrix::get_endpoints(const Transform &p_transform, Vector3 *p_8point
return true; return true;
} }
Vector<Plane> CameraMatrix::get_projection_planes(const Transform &p_transform) const { Vector<Plane> CameraMatrix::get_projection_planes(const Transform3D &p_transform) const {
/** Fast Plane Extraction from combined modelview/projection matrices. /** Fast Plane Extraction from combined modelview/projection matrices.
* References: * References:
* https://web.archive.org/web/20011221205252/http://www.markmorley.com/opengl/frustumculling.html * https://web.archive.org/web/20011221205252/http://www.markmorley.com/opengl/frustumculling.html
@ -707,8 +707,8 @@ void CameraMatrix::scale_translate_to_fit(const AABB &p_aabb) {
matrix[3][3] = 1; matrix[3][3] = 1;
} }
CameraMatrix::operator Transform() const { CameraMatrix::operator Transform3D() const {
Transform tr; Transform3D tr;
const real_t *m = &matrix[0][0]; const real_t *m = &matrix[0][0];
tr.basis.elements[0][0] = m[0]; tr.basis.elements[0][0] = m[0];
@ -730,8 +730,8 @@ CameraMatrix::operator Transform() const {
return tr; return tr;
} }
CameraMatrix::CameraMatrix(const Transform &p_transform) { CameraMatrix::CameraMatrix(const Transform3D &p_transform) {
const Transform &tr = p_transform; const Transform3D &tr = p_transform;
real_t *m = &matrix[0][0]; real_t *m = &matrix[0][0];
m[0] = tr.basis.elements[0][0]; m[0] = tr.basis.elements[0][0];

View File

@ -32,7 +32,7 @@
#define CAMERA_MATRIX_H #define CAMERA_MATRIX_H
#include "core/math/rect2.h" #include "core/math/rect2.h"
#include "core/math/transform.h" #include "core/math/transform_3d.h"
struct CameraMatrix { struct CameraMatrix {
enum Planes { enum Planes {
@ -71,9 +71,9 @@ struct CameraMatrix {
real_t get_fov() const; real_t get_fov() const;
bool is_orthogonal() const; bool is_orthogonal() const;
Vector<Plane> get_projection_planes(const Transform &p_transform) const; Vector<Plane> get_projection_planes(const Transform3D &p_transform) const;
bool get_endpoints(const Transform &p_transform, Vector3 *p_8points) const; bool get_endpoints(const Transform3D &p_transform, Vector3 *p_8points) const;
Vector2 get_viewport_half_extents() const; Vector2 get_viewport_half_extents() const;
Vector2 get_far_plane_half_extents() const; Vector2 get_far_plane_half_extents() const;
@ -90,7 +90,7 @@ struct CameraMatrix {
void scale_translate_to_fit(const AABB &p_aabb); void scale_translate_to_fit(const AABB &p_aabb);
void make_scale(const Vector3 &p_scale); void make_scale(const Vector3 &p_scale);
int get_pixels_per_meter(int p_for_pixel_width) const; int get_pixels_per_meter(int p_for_pixel_width) const;
operator Transform() const; operator Transform3D() const;
void flip_y(); void flip_y();
@ -112,7 +112,7 @@ struct CameraMatrix {
float get_lod_multiplier() const; float get_lod_multiplier() const;
CameraMatrix(); CameraMatrix();
CameraMatrix(const Transform &p_transform); CameraMatrix(const Transform3D &p_transform);
~CameraMatrix(); ~CameraMatrix();
}; };

View File

@ -230,7 +230,7 @@ bool Face3::intersects_aabb(const AABB &p_aabb) const {
real_t minA, maxA, minB, maxB; real_t minA, maxA, minB, maxB;
p_aabb.project_range_in_plane(Plane(axis, 0), minA, maxA); p_aabb.project_range_in_plane(Plane(axis, 0), minA, maxA);
project_range(axis, Transform(), minB, maxB); project_range(axis, Transform3D(), minB, maxB);
if (maxA < minB || maxB < minA) { if (maxA < minB || maxB < minA) {
return false; return false;
@ -244,7 +244,7 @@ Face3::operator String() const {
return String() + vertex[0] + ", " + vertex[1] + ", " + vertex[2]; return String() + vertex[0] + ", " + vertex[1] + ", " + vertex[2];
} }
void Face3::project_range(const Vector3 &p_normal, const Transform &p_transform, real_t &r_min, real_t &r_max) const { void Face3::project_range(const Vector3 &p_normal, const Transform3D &p_transform, real_t &r_min, real_t &r_max) const {
for (int i = 0; i < 3; i++) { for (int i = 0; i < 3; i++) {
Vector3 v = p_transform.xform(vertex[i]); Vector3 v = p_transform.xform(vertex[i]);
real_t d = p_normal.dot(v); real_t d = p_normal.dot(v);
@ -259,7 +259,7 @@ void Face3::project_range(const Vector3 &p_normal, const Transform &p_transform,
} }
} }
void Face3::get_support(const Vector3 &p_normal, const Transform &p_transform, Vector3 *p_vertices, int *p_count, int p_max) const { void Face3::get_support(const Vector3 &p_normal, const Transform3D &p_transform, Vector3 *p_vertices, int *p_count, int p_max) const {
#define _FACE_IS_VALID_SUPPORT_THRESHOLD 0.98 #define _FACE_IS_VALID_SUPPORT_THRESHOLD 0.98
#define _EDGE_IS_VALID_SUPPORT_THRESHOLD 0.05 #define _EDGE_IS_VALID_SUPPORT_THRESHOLD 0.05

View File

@ -33,7 +33,7 @@
#include "core/math/aabb.h" #include "core/math/aabb.h"
#include "core/math/plane.h" #include "core/math/plane.h"
#include "core/math/transform.h" #include "core/math/transform_3d.h"
#include "core/math/vector3.h" #include "core/math/vector3.h"
class Face3 { class Face3 {
@ -74,8 +74,8 @@ public:
ClockDirection get_clock_dir() const; ///< todo, test if this is returning the proper clockwisity ClockDirection get_clock_dir() const; ///< todo, test if this is returning the proper clockwisity
void get_support(const Vector3 &p_normal, const Transform &p_transform, Vector3 *p_vertices, int *p_count, int p_max) const; void get_support(const Vector3 &p_normal, const Transform3D &p_transform, Vector3 *p_vertices, int *p_count, int p_max) const;
void project_range(const Vector3 &p_normal, const Transform &p_transform, real_t &r_min, real_t &r_max) const; void project_range(const Vector3 &p_normal, const Transform3D &p_transform, real_t &r_min, real_t &r_max) const;
AABB get_aabb() const { AABB get_aabb() const {
AABB aabb(vertex[0], Vector3()); AABB aabb(vertex[0], Vector3());

View File

@ -141,8 +141,8 @@ Variant fieldwise_assign(const Variant &p_target, const Variant &p_source, const
return target; return target;
} }
case Variant::TRANSFORM: { case Variant::TRANSFORM3D: {
SETUP_TYPE(Transform) SETUP_TYPE(Transform3D)
/**/ TRY_TRANSFER_FIELD("xx", basis.elements[0][0]) /**/ TRY_TRANSFER_FIELD("xx", basis.elements[0][0])
else TRY_TRANSFER_FIELD("xy", basis.elements[0][1]) else TRY_TRANSFER_FIELD("xy", basis.elements[0][1])

View File

@ -1,5 +1,5 @@
/*************************************************************************/ /*************************************************************************/
/* transform.cpp */ /* transform_3d.cpp */
/*************************************************************************/ /*************************************************************************/
/* This file is part of: */ /* This file is part of: */
/* GODOT ENGINE */ /* GODOT ENGINE */
@ -28,54 +28,54 @@
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ /* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
/*************************************************************************/ /*************************************************************************/
#include "transform.h" #include "transform_3d.h"
#include "core/math/math_funcs.h" #include "core/math/math_funcs.h"
#include "core/string/print_string.h" #include "core/string/print_string.h"
void Transform::affine_invert() { void Transform3D::affine_invert() {
basis.invert(); basis.invert();
origin = basis.xform(-origin); origin = basis.xform(-origin);
} }
Transform Transform::affine_inverse() const { Transform3D Transform3D::affine_inverse() const {
Transform ret = *this; Transform3D ret = *this;
ret.affine_invert(); ret.affine_invert();
return ret; return ret;
} }
void Transform::invert() { void Transform3D::invert() {
basis.transpose(); basis.transpose();
origin = basis.xform(-origin); origin = basis.xform(-origin);
} }
Transform Transform::inverse() const { Transform3D Transform3D::inverse() const {
// FIXME: this function assumes the basis is a rotation matrix, with no scaling. // FIXME: this function assumes the basis is a rotation matrix, with no scaling.
// Transform::affine_inverse can handle matrices with scaling, so GDScript should eventually use that. // Transform3D::affine_inverse can handle matrices with scaling, so GDScript should eventually use that.
Transform ret = *this; Transform3D ret = *this;
ret.invert(); ret.invert();
return ret; return ret;
} }
void Transform::rotate(const Vector3 &p_axis, real_t p_phi) { void Transform3D::rotate(const Vector3 &p_axis, real_t p_phi) {
*this = rotated(p_axis, p_phi); *this = rotated(p_axis, p_phi);
} }
Transform Transform::rotated(const Vector3 &p_axis, real_t p_phi) const { Transform3D Transform3D::rotated(const Vector3 &p_axis, real_t p_phi) const {
return Transform(Basis(p_axis, p_phi), Vector3()) * (*this); return Transform3D(Basis(p_axis, p_phi), Vector3()) * (*this);
} }
void Transform::rotate_basis(const Vector3 &p_axis, real_t p_phi) { void Transform3D::rotate_basis(const Vector3 &p_axis, real_t p_phi) {
basis.rotate(p_axis, p_phi); basis.rotate(p_axis, p_phi);
} }
Transform Transform::looking_at(const Vector3 &p_target, const Vector3 &p_up) const { Transform3D Transform3D::looking_at(const Vector3 &p_target, const Vector3 &p_up) const {
Transform t = *this; Transform3D t = *this;
t.set_look_at(origin, p_target, p_up); t.set_look_at(origin, p_target, p_up);
return t; return t;
} }
void Transform::set_look_at(const Vector3 &p_eye, const Vector3 &p_target, const Vector3 &p_up) { void Transform3D::set_look_at(const Vector3 &p_eye, const Vector3 &p_target, const Vector3 &p_up) {
#ifdef MATH_CHECKS #ifdef MATH_CHECKS
ERR_FAIL_COND(p_eye == p_target); ERR_FAIL_COND(p_eye == p_target);
ERR_FAIL_COND(p_up.length() == 0); ERR_FAIL_COND(p_up.length() == 0);
@ -108,7 +108,7 @@ void Transform::set_look_at(const Vector3 &p_eye, const Vector3 &p_target, const
origin = p_eye; origin = p_eye;
} }
Transform Transform::interpolate_with(const Transform &p_transform, real_t p_c) const { Transform3D Transform3D::interpolate_with(const Transform3D &p_transform, real_t p_c) const {
/* not sure if very "efficient" but good enough? */ /* not sure if very "efficient" but good enough? */
Vector3 src_scale = basis.get_scale(); Vector3 src_scale = basis.get_scale();
@ -119,94 +119,94 @@ Transform Transform::interpolate_with(const Transform &p_transform, real_t p_c)
Quat dst_rot = p_transform.basis.get_rotation_quat(); Quat dst_rot = p_transform.basis.get_rotation_quat();
Vector3 dst_loc = p_transform.origin; Vector3 dst_loc = p_transform.origin;
Transform interp; Transform3D interp;
interp.basis.set_quat_scale(src_rot.slerp(dst_rot, p_c).normalized(), src_scale.lerp(dst_scale, p_c)); interp.basis.set_quat_scale(src_rot.slerp(dst_rot, p_c).normalized(), src_scale.lerp(dst_scale, p_c));
interp.origin = src_loc.lerp(dst_loc, p_c); interp.origin = src_loc.lerp(dst_loc, p_c);
return interp; return interp;
} }
void Transform::scale(const Vector3 &p_scale) { void Transform3D::scale(const Vector3 &p_scale) {
basis.scale(p_scale); basis.scale(p_scale);
origin *= p_scale; origin *= p_scale;
} }
Transform Transform::scaled(const Vector3 &p_scale) const { Transform3D Transform3D::scaled(const Vector3 &p_scale) const {
Transform t = *this; Transform3D t = *this;
t.scale(p_scale); t.scale(p_scale);
return t; return t;
} }
void Transform::scale_basis(const Vector3 &p_scale) { void Transform3D::scale_basis(const Vector3 &p_scale) {
basis.scale(p_scale); basis.scale(p_scale);
} }
void Transform::translate(real_t p_tx, real_t p_ty, real_t p_tz) { void Transform3D::translate(real_t p_tx, real_t p_ty, real_t p_tz) {
translate(Vector3(p_tx, p_ty, p_tz)); translate(Vector3(p_tx, p_ty, p_tz));
} }
void Transform::translate(const Vector3 &p_translation) { void Transform3D::translate(const Vector3 &p_translation) {
for (int i = 0; i < 3; i++) { for (int i = 0; i < 3; i++) {
origin[i] += basis[i].dot(p_translation); origin[i] += basis[i].dot(p_translation);
} }
} }
Transform Transform::translated(const Vector3 &p_translation) const { Transform3D Transform3D::translated(const Vector3 &p_translation) const {
Transform t = *this; Transform3D t = *this;
t.translate(p_translation); t.translate(p_translation);
return t; return t;
} }
void Transform::orthonormalize() { void Transform3D::orthonormalize() {
basis.orthonormalize(); basis.orthonormalize();
} }
Transform Transform::orthonormalized() const { Transform3D Transform3D::orthonormalized() const {
Transform _copy = *this; Transform3D _copy = *this;
_copy.orthonormalize(); _copy.orthonormalize();
return _copy; return _copy;
} }
bool Transform::is_equal_approx(const Transform &p_transform) const { bool Transform3D::is_equal_approx(const Transform3D &p_transform) const {
return basis.is_equal_approx(p_transform.basis) && origin.is_equal_approx(p_transform.origin); return basis.is_equal_approx(p_transform.basis) && origin.is_equal_approx(p_transform.origin);
} }
bool Transform::operator==(const Transform &p_transform) const { bool Transform3D::operator==(const Transform3D &p_transform) const {
return (basis == p_transform.basis && origin == p_transform.origin); return (basis == p_transform.basis && origin == p_transform.origin);
} }
bool Transform::operator!=(const Transform &p_transform) const { bool Transform3D::operator!=(const Transform3D &p_transform) const {
return (basis != p_transform.basis || origin != p_transform.origin); return (basis != p_transform.basis || origin != p_transform.origin);
} }
void Transform::operator*=(const Transform &p_transform) { void Transform3D::operator*=(const Transform3D &p_transform) {
origin = xform(p_transform.origin); origin = xform(p_transform.origin);
basis *= p_transform.basis; basis *= p_transform.basis;
} }
Transform Transform::operator*(const Transform &p_transform) const { Transform3D Transform3D::operator*(const Transform3D &p_transform) const {
Transform t = *this; Transform3D t = *this;
t *= p_transform; t *= p_transform;
return t; return t;
} }
Transform::operator String() const { Transform3D::operator String() const {
return basis.operator String() + " - " + origin.operator String(); return basis.operator String() + " - " + origin.operator String();
} }
Transform::Transform(const Basis &p_basis, const Vector3 &p_origin) : Transform3D::Transform3D(const Basis &p_basis, const Vector3 &p_origin) :
basis(p_basis), basis(p_basis),
origin(p_origin) { origin(p_origin) {
} }
Transform::Transform(const Vector3 &p_x, const Vector3 &p_y, const Vector3 &p_z, const Vector3 &p_origin) : Transform3D::Transform3D(const Vector3 &p_x, const Vector3 &p_y, const Vector3 &p_z, const Vector3 &p_origin) :
origin(p_origin) { origin(p_origin) {
basis.set_axis(0, p_x); basis.set_axis(0, p_x);
basis.set_axis(1, p_y); basis.set_axis(1, p_y);
basis.set_axis(2, p_z); basis.set_axis(2, p_z);
} }
Transform::Transform(real_t xx, real_t xy, real_t xz, real_t yx, real_t yy, real_t yz, real_t zx, real_t zy, real_t zz, real_t ox, real_t oy, real_t oz) { Transform3D::Transform3D(real_t xx, real_t xy, real_t xz, real_t yx, real_t yy, real_t yz, real_t zx, real_t zy, real_t zz, real_t ox, real_t oy, real_t oz) {
basis = Basis(xx, xy, xz, yx, yy, yz, zx, zy, zz); basis = Basis(xx, xy, xz, yx, yy, yz, zx, zy, zz);
origin = Vector3(ox, oy, oz); origin = Vector3(ox, oy, oz);
} }

View File

@ -1,5 +1,5 @@
/*************************************************************************/ /*************************************************************************/
/* transform.h */ /* transform_3d.h */
/*************************************************************************/ /*************************************************************************/
/* This file is part of: */ /* This file is part of: */
/* GODOT ENGINE */ /* GODOT ENGINE */
@ -35,31 +35,31 @@
#include "core/math/basis.h" #include "core/math/basis.h"
#include "core/math/plane.h" #include "core/math/plane.h"
class Transform { class Transform3D {
public: public:
Basis basis; Basis basis;
Vector3 origin; Vector3 origin;
void invert(); void invert();
Transform inverse() const; Transform3D inverse() const;
void affine_invert(); void affine_invert();
Transform affine_inverse() const; Transform3D affine_inverse() const;
Transform rotated(const Vector3 &p_axis, real_t p_phi) const; Transform3D rotated(const Vector3 &p_axis, real_t p_phi) const;
void rotate(const Vector3 &p_axis, real_t p_phi); void rotate(const Vector3 &p_axis, real_t p_phi);
void rotate_basis(const Vector3 &p_axis, real_t p_phi); void rotate_basis(const Vector3 &p_axis, real_t p_phi);
void set_look_at(const Vector3 &p_eye, const Vector3 &p_target, const Vector3 &p_up = Vector3(0, 1, 0)); void set_look_at(const Vector3 &p_eye, const Vector3 &p_target, const Vector3 &p_up = Vector3(0, 1, 0));
Transform looking_at(const Vector3 &p_target, const Vector3 &p_up = Vector3(0, 1, 0)) const; Transform3D looking_at(const Vector3 &p_target, const Vector3 &p_up = Vector3(0, 1, 0)) const;
void scale(const Vector3 &p_scale); void scale(const Vector3 &p_scale);
Transform scaled(const Vector3 &p_scale) const; Transform3D scaled(const Vector3 &p_scale) const;
void scale_basis(const Vector3 &p_scale); void scale_basis(const Vector3 &p_scale);
void translate(real_t p_tx, real_t p_ty, real_t p_tz); void translate(real_t p_tx, real_t p_ty, real_t p_tz);
void translate(const Vector3 &p_translation); void translate(const Vector3 &p_translation);
Transform translated(const Vector3 &p_translation) const; Transform3D translated(const Vector3 &p_translation) const;
const Basis &get_basis() const { return basis; } const Basis &get_basis() const { return basis; }
void set_basis(const Basis &p_basis) { basis = p_basis; } void set_basis(const Basis &p_basis) { basis = p_basis; }
@ -68,11 +68,11 @@ public:
void set_origin(const Vector3 &p_origin) { origin = p_origin; } void set_origin(const Vector3 &p_origin) { origin = p_origin; }
void orthonormalize(); void orthonormalize();
Transform orthonormalized() const; Transform3D orthonormalized() const;
bool is_equal_approx(const Transform &p_transform) const; bool is_equal_approx(const Transform3D &p_transform) const;
bool operator==(const Transform &p_transform) const; bool operator==(const Transform3D &p_transform) const;
bool operator!=(const Transform &p_transform) const; bool operator!=(const Transform3D &p_transform) const;
_FORCE_INLINE_ Vector3 xform(const Vector3 &p_vector) const; _FORCE_INLINE_ Vector3 xform(const Vector3 &p_vector) const;
_FORCE_INLINE_ Vector3 xform_inv(const Vector3 &p_vector) const; _FORCE_INLINE_ Vector3 xform_inv(const Vector3 &p_vector) const;
@ -86,14 +86,14 @@ public:
_FORCE_INLINE_ Vector<Vector3> xform(const Vector<Vector3> &p_array) const; _FORCE_INLINE_ Vector<Vector3> xform(const Vector<Vector3> &p_array) const;
_FORCE_INLINE_ Vector<Vector3> xform_inv(const Vector<Vector3> &p_array) const; _FORCE_INLINE_ Vector<Vector3> xform_inv(const Vector<Vector3> &p_array) const;
void operator*=(const Transform &p_transform); void operator*=(const Transform3D &p_transform);
Transform operator*(const Transform &p_transform) const; Transform3D operator*(const Transform3D &p_transform) const;
Transform interpolate_with(const Transform &p_transform, real_t p_c) const; Transform3D interpolate_with(const Transform3D &p_transform, real_t p_c) const;
_FORCE_INLINE_ Transform inverse_xform(const Transform &t) const { _FORCE_INLINE_ Transform3D inverse_xform(const Transform3D &t) const {
Vector3 v = t.origin - origin; Vector3 v = t.origin - origin;
return Transform(basis.transpose_xform(t.basis), return Transform3D(basis.transpose_xform(t.basis),
basis.xform(v)); basis.xform(v));
} }
@ -106,20 +106,20 @@ public:
operator String() const; operator String() const;
Transform() {} Transform3D() {}
Transform(const Basis &p_basis, const Vector3 &p_origin = Vector3()); Transform3D(const Basis &p_basis, const Vector3 &p_origin = Vector3());
Transform(const Vector3 &p_x, const Vector3 &p_y, const Vector3 &p_z, const Vector3 &p_origin); Transform3D(const Vector3 &p_x, const Vector3 &p_y, const Vector3 &p_z, const Vector3 &p_origin);
Transform(real_t xx, real_t xy, real_t xz, real_t yx, real_t yy, real_t yz, real_t zx, real_t zy, real_t zz, real_t ox, real_t oy, real_t oz); Transform3D(real_t xx, real_t xy, real_t xz, real_t yx, real_t yy, real_t yz, real_t zx, real_t zy, real_t zz, real_t ox, real_t oy, real_t oz);
}; };
_FORCE_INLINE_ Vector3 Transform::xform(const Vector3 &p_vector) const { _FORCE_INLINE_ Vector3 Transform3D::xform(const Vector3 &p_vector) const {
return Vector3( return Vector3(
basis[0].dot(p_vector) + origin.x, basis[0].dot(p_vector) + origin.x,
basis[1].dot(p_vector) + origin.y, basis[1].dot(p_vector) + origin.y,
basis[2].dot(p_vector) + origin.z); basis[2].dot(p_vector) + origin.z);
} }
_FORCE_INLINE_ Vector3 Transform::xform_inv(const Vector3 &p_vector) const { _FORCE_INLINE_ Vector3 Transform3D::xform_inv(const Vector3 &p_vector) const {
Vector3 v = p_vector - origin; Vector3 v = p_vector - origin;
return Vector3( return Vector3(
@ -128,7 +128,7 @@ _FORCE_INLINE_ Vector3 Transform::xform_inv(const Vector3 &p_vector) const {
(basis.elements[0][2] * v.x) + (basis.elements[1][2] * v.y) + (basis.elements[2][2] * v.z)); (basis.elements[0][2] * v.x) + (basis.elements[1][2] * v.y) + (basis.elements[2][2] * v.z));
} }
_FORCE_INLINE_ Plane Transform::xform(const Plane &p_plane) const { _FORCE_INLINE_ Plane Transform3D::xform(const Plane &p_plane) const {
Vector3 point = p_plane.normal * p_plane.d; Vector3 point = p_plane.normal * p_plane.d;
Vector3 point_dir = point + p_plane.normal; Vector3 point_dir = point + p_plane.normal;
point = xform(point); point = xform(point);
@ -141,7 +141,7 @@ _FORCE_INLINE_ Plane Transform::xform(const Plane &p_plane) const {
return Plane(normal, d); return Plane(normal, d);
} }
_FORCE_INLINE_ Plane Transform::xform_inv(const Plane &p_plane) const { _FORCE_INLINE_ Plane Transform3D::xform_inv(const Plane &p_plane) const {
Vector3 point = p_plane.normal * p_plane.d; Vector3 point = p_plane.normal * p_plane.d;
Vector3 point_dir = point + p_plane.normal; Vector3 point_dir = point + p_plane.normal;
point = xform_inv(point); point = xform_inv(point);
@ -154,7 +154,7 @@ _FORCE_INLINE_ Plane Transform::xform_inv(const Plane &p_plane) const {
return Plane(normal, d); return Plane(normal, d);
} }
_FORCE_INLINE_ AABB Transform::xform(const AABB &p_aabb) const { _FORCE_INLINE_ AABB Transform3D::xform(const AABB &p_aabb) const {
/* http://dev.theomader.com/transform-bounding-boxes/ */ /* http://dev.theomader.com/transform-bounding-boxes/ */
Vector3 min = p_aabb.position; Vector3 min = p_aabb.position;
Vector3 max = p_aabb.position + p_aabb.size; Vector3 max = p_aabb.position + p_aabb.size;
@ -179,7 +179,7 @@ _FORCE_INLINE_ AABB Transform::xform(const AABB &p_aabb) const {
return r_aabb; return r_aabb;
} }
_FORCE_INLINE_ AABB Transform::xform_inv(const AABB &p_aabb) const { _FORCE_INLINE_ AABB Transform3D::xform_inv(const AABB &p_aabb) const {
/* define vertices */ /* define vertices */
Vector3 vertices[8] = { Vector3 vertices[8] = {
Vector3(p_aabb.position.x + p_aabb.size.x, p_aabb.position.y + p_aabb.size.y, p_aabb.position.z + p_aabb.size.z), Vector3(p_aabb.position.x + p_aabb.size.x, p_aabb.position.y + p_aabb.size.y, p_aabb.position.z + p_aabb.size.z),
@ -203,7 +203,7 @@ _FORCE_INLINE_ AABB Transform::xform_inv(const AABB &p_aabb) const {
return ret; return ret;
} }
Vector<Vector3> Transform::xform(const Vector<Vector3> &p_array) const { Vector<Vector3> Transform3D::xform(const Vector<Vector3> &p_array) const {
Vector<Vector3> array; Vector<Vector3> array;
array.resize(p_array.size()); array.resize(p_array.size());
@ -216,7 +216,7 @@ Vector<Vector3> Transform::xform(const Vector<Vector3> &p_array) const {
return array; return array;
} }
Vector<Vector3> Transform::xform_inv(const Vector<Vector3> &p_array) const { Vector<Vector3> Transform3D::xform_inv(const Vector<Vector3> &p_array) const {
Vector<Vector3> array; Vector<Vector3> array;
array.resize(p_array.size()); array.resize(p_array.size());

View File

@ -600,7 +600,7 @@ bool TriangleMesh::inside_convex_shape(const Plane *p_planes, int p_plane_count,
const Vector3 *vertexptr = vertices.ptr(); const Vector3 *vertexptr = vertices.ptr();
const BVH *bvhptr = bvh.ptr(); const BVH *bvhptr = bvh.ptr();
Transform scale(Basis().scaled(p_scale)); Transform3D scale(Basis().scaled(p_scale));
int pos = bvh.size() - 1; int pos = bvh.size() - 1;

View File

@ -125,7 +125,7 @@ MAKE_PTRARG_BY_REFERENCE(Plane);
MAKE_PTRARG(Quat); MAKE_PTRARG(Quat);
MAKE_PTRARG_BY_REFERENCE(AABB); MAKE_PTRARG_BY_REFERENCE(AABB);
MAKE_PTRARG_BY_REFERENCE(Basis); MAKE_PTRARG_BY_REFERENCE(Basis);
MAKE_PTRARG_BY_REFERENCE(Transform); MAKE_PTRARG_BY_REFERENCE(Transform3D);
MAKE_PTRARG_BY_REFERENCE(Color); MAKE_PTRARG_BY_REFERENCE(Color);
MAKE_PTRARG(StringName); MAKE_PTRARG(StringName);
MAKE_PTRARG(NodePath); MAKE_PTRARG(NodePath);

View File

@ -149,7 +149,7 @@ MAKE_TYPE_INFO(Plane, Variant::PLANE)
MAKE_TYPE_INFO(Quat, Variant::QUAT) MAKE_TYPE_INFO(Quat, Variant::QUAT)
MAKE_TYPE_INFO(AABB, Variant::AABB) MAKE_TYPE_INFO(AABB, Variant::AABB)
MAKE_TYPE_INFO(Basis, Variant::BASIS) MAKE_TYPE_INFO(Basis, Variant::BASIS)
MAKE_TYPE_INFO(Transform, Variant::TRANSFORM) MAKE_TYPE_INFO(Transform3D, Variant::TRANSFORM3D)
MAKE_TYPE_INFO(Color, Variant::COLOR) MAKE_TYPE_INFO(Color, Variant::COLOR)
MAKE_TYPE_INFO(StringName, Variant::STRING_NAME) MAKE_TYPE_INFO(StringName, Variant::STRING_NAME)
MAKE_TYPE_INFO(NodePath, Variant::NODE_PATH) MAKE_TYPE_INFO(NodePath, Variant::NODE_PATH)

View File

@ -101,7 +101,7 @@ MAKE_TYPED_ARRAY(Plane, Variant::PLANE)
MAKE_TYPED_ARRAY(Quat, Variant::QUAT) MAKE_TYPED_ARRAY(Quat, Variant::QUAT)
MAKE_TYPED_ARRAY(AABB, Variant::AABB) MAKE_TYPED_ARRAY(AABB, Variant::AABB)
MAKE_TYPED_ARRAY(Basis, Variant::BASIS) MAKE_TYPED_ARRAY(Basis, Variant::BASIS)
MAKE_TYPED_ARRAY(Transform, Variant::TRANSFORM) MAKE_TYPED_ARRAY(Transform3D, Variant::TRANSFORM3D)
MAKE_TYPED_ARRAY(Color, Variant::COLOR) MAKE_TYPED_ARRAY(Color, Variant::COLOR)
MAKE_TYPED_ARRAY(StringName, Variant::STRING_NAME) MAKE_TYPED_ARRAY(StringName, Variant::STRING_NAME)
MAKE_TYPED_ARRAY(NodePath, Variant::NODE_PATH) MAKE_TYPED_ARRAY(NodePath, Variant::NODE_PATH)
@ -199,7 +199,7 @@ MAKE_TYPED_ARRAY_INFO(Plane, Variant::PLANE)
MAKE_TYPED_ARRAY_INFO(Quat, Variant::QUAT) MAKE_TYPED_ARRAY_INFO(Quat, Variant::QUAT)
MAKE_TYPED_ARRAY_INFO(AABB, Variant::AABB) MAKE_TYPED_ARRAY_INFO(AABB, Variant::AABB)
MAKE_TYPED_ARRAY_INFO(Basis, Variant::BASIS) MAKE_TYPED_ARRAY_INFO(Basis, Variant::BASIS)
MAKE_TYPED_ARRAY_INFO(Transform, Variant::TRANSFORM) MAKE_TYPED_ARRAY_INFO(Transform3D, Variant::TRANSFORM3D)
MAKE_TYPED_ARRAY_INFO(Color, Variant::COLOR) MAKE_TYPED_ARRAY_INFO(Color, Variant::COLOR)
MAKE_TYPED_ARRAY_INFO(StringName, Variant::STRING_NAME) MAKE_TYPED_ARRAY_INFO(StringName, Variant::STRING_NAME)
MAKE_TYPED_ARRAY_INFO(NodePath, Variant::NODE_PATH) MAKE_TYPED_ARRAY_INFO(NodePath, Variant::NODE_PATH)

View File

@ -99,8 +99,8 @@ String Variant::get_type_name(Variant::Type p_type) {
return "Basis"; return "Basis";
} break; } break;
case TRANSFORM: { case TRANSFORM3D: {
return "Transform"; return "Transform3D";
} break; } break;
@ -275,7 +275,7 @@ bool Variant::can_convert(Variant::Type p_type_from, Variant::Type p_type_to) {
} break; } break;
case TRANSFORM2D: { case TRANSFORM2D: {
static const Type valid[] = { static const Type valid[] = {
TRANSFORM, TRANSFORM3D,
NIL NIL
}; };
@ -319,7 +319,7 @@ bool Variant::can_convert(Variant::Type p_type_from, Variant::Type p_type_to) {
valid_types = valid; valid_types = valid;
} break; } break;
case TRANSFORM: { case TRANSFORM3D: {
static const Type valid[] = { static const Type valid[] = {
TRANSFORM2D, TRANSFORM2D,
QUAT, QUAT,
@ -582,7 +582,7 @@ bool Variant::can_convert_strict(Variant::Type p_type_from, Variant::Type p_type
} break; } break;
case TRANSFORM2D: { case TRANSFORM2D: {
static const Type valid[] = { static const Type valid[] = {
TRANSFORM, TRANSFORM3D,
NIL NIL
}; };
@ -626,7 +626,7 @@ bool Variant::can_convert_strict(Variant::Type p_type_from, Variant::Type p_type
valid_types = valid; valid_types = valid;
} break; } break;
case TRANSFORM: { case TRANSFORM3D: {
static const Type valid[] = { static const Type valid[] = {
TRANSFORM2D, TRANSFORM2D,
QUAT, QUAT,
@ -881,8 +881,8 @@ bool Variant::is_zero() const {
return *_data._basis == Basis(); return *_data._basis == Basis();
} break; } break;
case TRANSFORM: { case TRANSFORM3D: {
return *_data._transform == Transform(); return *_data._transform3d == Transform3D();
} break; } break;
@ -1100,8 +1100,8 @@ void Variant::reference(const Variant &p_variant) {
_data._basis = memnew(Basis(*p_variant._data._basis)); _data._basis = memnew(Basis(*p_variant._data._basis));
} break; } break;
case TRANSFORM: { case TRANSFORM3D: {
_data._transform = memnew(Transform(*p_variant._data._transform)); _data._transform3d = memnew(Transform3D(*p_variant._data._transform3d));
} break; } break;
// misc types // misc types
@ -1289,8 +1289,8 @@ void Variant::_clear_internal() {
case BASIS: { case BASIS: {
memdelete(_data._basis); memdelete(_data._basis);
} break; } break;
case TRANSFORM: { case TRANSFORM3D: {
memdelete(_data._transform); memdelete(_data._transform3d);
} break; } break;
// misc types // misc types
@ -1682,8 +1682,8 @@ String Variant::stringify(List<const void *> &stack) const {
return mtx + ")"; return mtx + ")";
} break; } break;
case TRANSFORM: case TRANSFORM3D:
return operator Transform(); return operator Transform3D();
case STRING_NAME: case STRING_NAME:
return operator StringName(); return operator StringName();
case NODE_PATH: case NODE_PATH:
@ -1960,8 +1960,8 @@ Variant::operator Basis() const {
return *reinterpret_cast<const Quat *>(_data._mem); return *reinterpret_cast<const Quat *>(_data._mem);
} else if (type == VECTOR3) { } else if (type == VECTOR3) {
return Basis(*reinterpret_cast<const Vector3 *>(_data._mem)); return Basis(*reinterpret_cast<const Vector3 *>(_data._mem));
} else if (type == TRANSFORM) { // unexposed in Variant::can_convert? } else if (type == TRANSFORM3D) { // unexposed in Variant::can_convert?
return _data._transform->basis; return _data._transform3d->basis;
} else { } else {
return Basis(); return Basis();
} }
@ -1972,23 +1972,23 @@ Variant::operator Quat() const {
return *reinterpret_cast<const Quat *>(_data._mem); return *reinterpret_cast<const Quat *>(_data._mem);
} else if (type == BASIS) { } else if (type == BASIS) {
return *_data._basis; return *_data._basis;
} else if (type == TRANSFORM) { } else if (type == TRANSFORM3D) {
return _data._transform->basis; return _data._transform3d->basis;
} else { } else {
return Quat(); return Quat();
} }
} }
Variant::operator Transform() const { Variant::operator Transform3D() const {
if (type == TRANSFORM) { if (type == TRANSFORM3D) {
return *_data._transform; return *_data._transform3d;
} else if (type == BASIS) { } else if (type == BASIS) {
return Transform(*_data._basis, Vector3()); return Transform3D(*_data._basis, Vector3());
} else if (type == QUAT) { } else if (type == QUAT) {
return Transform(Basis(*reinterpret_cast<const Quat *>(_data._mem)), Vector3()); return Transform3D(Basis(*reinterpret_cast<const Quat *>(_data._mem)), Vector3());
} else if (type == TRANSFORM2D) { } else if (type == TRANSFORM2D) {
const Transform2D &t = *_data._transform2d; const Transform2D &t = *_data._transform2d;
Transform m; Transform3D m;
m.basis.elements[0][0] = t.elements[0][0]; m.basis.elements[0][0] = t.elements[0][0];
m.basis.elements[1][0] = t.elements[0][1]; m.basis.elements[1][0] = t.elements[0][1];
m.basis.elements[0][1] = t.elements[1][0]; m.basis.elements[0][1] = t.elements[1][0];
@ -1997,15 +1997,15 @@ Variant::operator Transform() const {
m.origin[1] = t.elements[2][1]; m.origin[1] = t.elements[2][1];
return m; return m;
} else { } else {
return Transform(); return Transform3D();
} }
} }
Variant::operator Transform2D() const { Variant::operator Transform2D() const {
if (type == TRANSFORM2D) { if (type == TRANSFORM2D) {
return *_data._transform2d; return *_data._transform2d;
} else if (type == TRANSFORM) { } else if (type == TRANSFORM3D) {
const Transform &t = *_data._transform; const Transform3D &t = *_data._transform3d;
Transform2D m; Transform2D m;
m.elements[0][0] = t.basis.elements[0][0]; m.elements[0][0] = t.basis.elements[0][0];
m.elements[0][1] = t.basis.elements[1][0]; m.elements[0][1] = t.basis.elements[1][0];
@ -2500,9 +2500,9 @@ Variant::Variant(const Quat &p_quat) {
memnew_placement(_data._mem, Quat(p_quat)); memnew_placement(_data._mem, Quat(p_quat));
} }
Variant::Variant(const Transform &p_transform) { Variant::Variant(const Transform3D &p_transform) {
type = TRANSFORM; type = TRANSFORM3D;
_data._transform = memnew(Transform(p_transform)); _data._transform3d = memnew(Transform3D(p_transform));
} }
Variant::Variant(const Transform2D &p_transform) { Variant::Variant(const Transform2D &p_transform) {
@ -2745,8 +2745,8 @@ void Variant::operator=(const Variant &p_variant) {
case BASIS: { case BASIS: {
*_data._basis = *(p_variant._data._basis); *_data._basis = *(p_variant._data._basis);
} break; } break;
case TRANSFORM: { case TRANSFORM3D: {
*_data._transform = *(p_variant._data._transform); *_data._transform3d = *(p_variant._data._transform3d);
} break; } break;
// misc types // misc types
@ -2934,13 +2934,13 @@ uint32_t Variant::hash() const {
return hash; return hash;
} break; } break;
case TRANSFORM: { case TRANSFORM3D: {
uint32_t hash = 5831; uint32_t hash = 5831;
for (int i = 0; i < 3; i++) { for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++) { for (int j = 0; j < 3; j++) {
hash = hash_djb2_one_float(_data._transform->basis.elements[i][j], hash); hash = hash_djb2_one_float(_data._transform3d->basis.elements[i][j], hash);
} }
hash = hash_djb2_one_float(_data._transform->origin[i], hash); hash = hash_djb2_one_float(_data._transform3d->origin[i], hash);
} }
return hash; return hash;
@ -3255,9 +3255,9 @@ bool Variant::hash_compare(const Variant &p_variant) const {
return true; return true;
} break; } break;
case TRANSFORM: { case TRANSFORM3D: {
const Transform *l = _data._transform; const Transform3D *l = _data._transform3d;
const Transform *r = p_variant._data._transform; const Transform3D *r = p_variant._data._transform3d;
for (int i = 0; i < 3; i++) { for (int i = 0; i < 3; i++) {
if (!(hash_compare_vector3(l->basis.elements[i], r->basis.elements[i]))) { if (!(hash_compare_vector3(l->basis.elements[i], r->basis.elements[i]))) {

View File

@ -38,8 +38,8 @@
#include "core/math/face3.h" #include "core/math/face3.h"
#include "core/math/plane.h" #include "core/math/plane.h"
#include "core/math/quat.h" #include "core/math/quat.h"
#include "core/math/transform.h"
#include "core/math/transform_2d.h" #include "core/math/transform_2d.h"
#include "core/math/transform_3d.h"
#include "core/math/vector3.h" #include "core/math/vector3.h"
#include "core/math/vector3i.h" #include "core/math/vector3i.h"
#include "core/object/object_id.h" #include "core/object/object_id.h"
@ -91,7 +91,7 @@ public:
QUAT, QUAT,
AABB, AABB,
BASIS, BASIS,
TRANSFORM, TRANSFORM3D,
// misc types // misc types
COLOR, COLOR,
@ -200,7 +200,7 @@ private:
Transform2D *_transform2d; Transform2D *_transform2d;
::AABB *_aabb; ::AABB *_aabb;
Basis *_basis; Basis *_basis;
Transform *_transform; Transform3D *_transform3d;
PackedArrayRefBase *packed_array; PackedArrayRefBase *packed_array;
void *_ptr; //generic pointer void *_ptr; //generic pointer
uint8_t _mem[sizeof(ObjData) > (sizeof(real_t) * 4) ? sizeof(ObjData) : (sizeof(real_t) * 4)]; uint8_t _mem[sizeof(ObjData) > (sizeof(real_t) * 4) ? sizeof(ObjData) : (sizeof(real_t) * 4)];
@ -322,8 +322,8 @@ public:
operator ::AABB() const; operator ::AABB() const;
operator Quat() const; operator Quat() const;
operator Basis() const; operator Basis() const;
operator Transform() const;
operator Transform2D() const; operator Transform2D() const;
operator Transform3D() const;
operator Color() const; operator Color() const;
operator NodePath() const; operator NodePath() const;
@ -395,7 +395,7 @@ public:
Variant(const Quat &p_quat); Variant(const Quat &p_quat);
Variant(const Basis &p_matrix); Variant(const Basis &p_matrix);
Variant(const Transform2D &p_transform); Variant(const Transform2D &p_transform);
Variant(const Transform &p_transform); Variant(const Transform3D &p_transform);
Variant(const Color &p_color); Variant(const Color &p_color);
Variant(const NodePath &p_node_path); Variant(const NodePath &p_node_path);
Variant(const ::RID &p_rid); Variant(const ::RID &p_rid);

View File

@ -1696,17 +1696,17 @@ static void _register_variant_builtin_methods() {
bind_methodv(AABB, intersects_segment, &AABB::intersects_segment_bind, sarray("from", "to"), varray()); bind_methodv(AABB, intersects_segment, &AABB::intersects_segment_bind, sarray("from", "to"), varray());
bind_methodv(AABB, intersects_ray, &AABB::intersects_ray_bind, sarray("from", "dir"), varray()); bind_methodv(AABB, intersects_ray, &AABB::intersects_ray_bind, sarray("from", "dir"), varray());
/* Transform */ /* Transform3D */
bind_method(Transform, inverse, sarray(), varray()); bind_method(Transform3D, inverse, sarray(), varray());
bind_method(Transform, affine_inverse, sarray(), varray()); bind_method(Transform3D, affine_inverse, sarray(), varray());
bind_method(Transform, orthonormalized, sarray(), varray()); bind_method(Transform3D, orthonormalized, sarray(), varray());
bind_method(Transform, rotated, sarray("axis", "phi"), varray()); bind_method(Transform3D, rotated, sarray("axis", "phi"), varray());
bind_method(Transform, scaled, sarray("scale"), varray()); bind_method(Transform3D, scaled, sarray("scale"), varray());
bind_method(Transform, translated, sarray("offset"), varray()); bind_method(Transform3D, translated, sarray("offset"), varray());
bind_method(Transform, looking_at, sarray("target", "up"), varray(Vector3(0, 1, 0))); bind_method(Transform3D, looking_at, sarray("target", "up"), varray(Vector3(0, 1, 0)));
bind_method(Transform, interpolate_with, sarray("xform", "weight"), varray()); bind_method(Transform3D, interpolate_with, sarray("xform", "weight"), varray());
bind_method(Transform, is_equal_approx, sarray("xform"), varray()); bind_method(Transform3D, is_equal_approx, sarray("xform"), varray());
/* Dictionary */ /* Dictionary */
@ -2025,14 +2025,14 @@ static void _register_variant_builtin_methods() {
_VariantCall::add_variant_constant(Variant::TRANSFORM2D, "FLIP_X", Transform2D(-1, 0, 0, 1, 0, 0)); _VariantCall::add_variant_constant(Variant::TRANSFORM2D, "FLIP_X", Transform2D(-1, 0, 0, 1, 0, 0));
_VariantCall::add_variant_constant(Variant::TRANSFORM2D, "FLIP_Y", Transform2D(1, 0, 0, -1, 0, 0)); _VariantCall::add_variant_constant(Variant::TRANSFORM2D, "FLIP_Y", Transform2D(1, 0, 0, -1, 0, 0));
Transform identity_transform = Transform(); Transform3D identity_transform = Transform3D();
Transform flip_x_transform = Transform(-1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0); Transform3D flip_x_transform = Transform3D(-1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0);
Transform flip_y_transform = Transform(1, 0, 0, 0, -1, 0, 0, 0, 1, 0, 0, 0); Transform3D flip_y_transform = Transform3D(1, 0, 0, 0, -1, 0, 0, 0, 1, 0, 0, 0);
Transform flip_z_transform = Transform(1, 0, 0, 0, 1, 0, 0, 0, -1, 0, 0, 0); Transform3D flip_z_transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, -1, 0, 0, 0);
_VariantCall::add_variant_constant(Variant::TRANSFORM, "IDENTITY", identity_transform); _VariantCall::add_variant_constant(Variant::TRANSFORM3D, "IDENTITY", identity_transform);
_VariantCall::add_variant_constant(Variant::TRANSFORM, "FLIP_X", flip_x_transform); _VariantCall::add_variant_constant(Variant::TRANSFORM3D, "FLIP_X", flip_x_transform);
_VariantCall::add_variant_constant(Variant::TRANSFORM, "FLIP_Y", flip_y_transform); _VariantCall::add_variant_constant(Variant::TRANSFORM3D, "FLIP_Y", flip_y_transform);
_VariantCall::add_variant_constant(Variant::TRANSFORM, "FLIP_Z", flip_z_transform); _VariantCall::add_variant_constant(Variant::TRANSFORM3D, "FLIP_Z", flip_z_transform);
Basis identity_basis = Basis(); Basis identity_basis = Basis();
Basis flip_x_basis = Basis(-1, 0, 0, 0, 1, 0, 0, 0, 1); Basis flip_x_basis = Basis(-1, 0, 0, 0, 1, 0, 0, 0, 1);

View File

@ -65,7 +65,7 @@ MAKE_PTRCONSTRUCT(Plane);
MAKE_PTRCONSTRUCT(Quat); MAKE_PTRCONSTRUCT(Quat);
MAKE_PTRCONSTRUCT(AABB); MAKE_PTRCONSTRUCT(AABB);
MAKE_PTRCONSTRUCT(Basis); MAKE_PTRCONSTRUCT(Basis);
MAKE_PTRCONSTRUCT(Transform); MAKE_PTRCONSTRUCT(Transform3D);
MAKE_PTRCONSTRUCT(Color); MAKE_PTRCONSTRUCT(Color);
MAKE_PTRCONSTRUCT(StringName); MAKE_PTRCONSTRUCT(StringName);
MAKE_PTRCONSTRUCT(NodePath); MAKE_PTRCONSTRUCT(NodePath);
@ -678,10 +678,10 @@ void Variant::_register_variant_constructors() {
add_constructor<VariantConstructor<Basis, Vector3, double>>(sarray("axis", "phi")); add_constructor<VariantConstructor<Basis, Vector3, double>>(sarray("axis", "phi"));
add_constructor<VariantConstructor<Basis, Vector3, Vector3, Vector3>>(sarray("x_axis", "y_axis", "z_axis")); add_constructor<VariantConstructor<Basis, Vector3, Vector3, Vector3>>(sarray("x_axis", "y_axis", "z_axis"));
add_constructor<VariantConstructNoArgs<Transform>>(sarray()); add_constructor<VariantConstructNoArgs<Transform3D>>(sarray());
add_constructor<VariantConstructor<Transform, Transform>>(sarray("from")); add_constructor<VariantConstructor<Transform3D, Transform3D>>(sarray("from"));
add_constructor<VariantConstructor<Transform, Basis, Vector3>>(sarray("basis", "origin")); add_constructor<VariantConstructor<Transform3D, Basis, Vector3>>(sarray("basis", "origin"));
add_constructor<VariantConstructor<Transform, Vector3, Vector3, Vector3, Vector3>>(sarray("x_axis", "y_axis", "z_axis", "origin")); add_constructor<VariantConstructor<Transform3D, Vector3, Vector3, Vector3, Vector3>>(sarray("x_axis", "y_axis", "z_axis", "origin"));
add_constructor<VariantConstructNoArgs<Color>>(sarray()); add_constructor<VariantConstructNoArgs<Color>>(sarray());
add_constructor<VariantConstructor<Color, Color>>(sarray("from")); add_constructor<VariantConstructor<Color, Color>>(sarray("from"));

View File

@ -55,7 +55,7 @@ public:
case Variant::BASIS: case Variant::BASIS:
init_basis(v); init_basis(v);
break; break;
case Variant::TRANSFORM: case Variant::TRANSFORM3D:
init_transform(v); init_transform(v);
break; break;
case Variant::STRING_NAME: case Variant::STRING_NAME:
@ -144,8 +144,8 @@ public:
_FORCE_INLINE_ static const ::AABB *get_aabb(const Variant *v) { return v->_data._aabb; } _FORCE_INLINE_ static const ::AABB *get_aabb(const Variant *v) { return v->_data._aabb; }
_FORCE_INLINE_ static Basis *get_basis(Variant *v) { return v->_data._basis; } _FORCE_INLINE_ static Basis *get_basis(Variant *v) { return v->_data._basis; }
_FORCE_INLINE_ static const Basis *get_basis(const Variant *v) { return v->_data._basis; } _FORCE_INLINE_ static const Basis *get_basis(const Variant *v) { return v->_data._basis; }
_FORCE_INLINE_ static Transform *get_transform(Variant *v) { return v->_data._transform; } _FORCE_INLINE_ static Transform3D *get_transform(Variant *v) { return v->_data._transform3d; }
_FORCE_INLINE_ static const Transform *get_transform(const Variant *v) { return v->_data._transform; } _FORCE_INLINE_ static const Transform3D *get_transform(const Variant *v) { return v->_data._transform3d; }
// Misc types. // Misc types.
_FORCE_INLINE_ static Color *get_color(Variant *v) { return reinterpret_cast<Color *>(v->_data._mem); } _FORCE_INLINE_ static Color *get_color(Variant *v) { return reinterpret_cast<Color *>(v->_data._mem); }
@ -217,8 +217,8 @@ public:
v->type = Variant::BASIS; v->type = Variant::BASIS;
} }
_FORCE_INLINE_ static void init_transform(Variant *v) { _FORCE_INLINE_ static void init_transform(Variant *v) {
v->_data._transform = memnew(Transform); v->_data._transform3d = memnew(Transform3D);
v->type = Variant::TRANSFORM; v->type = Variant::TRANSFORM3D;
} }
_FORCE_INLINE_ static void init_string_name(Variant *v) { _FORCE_INLINE_ static void init_string_name(Variant *v) {
memnew_placement(v->_data._mem, StringName); memnew_placement(v->_data._mem, StringName);
@ -320,7 +320,7 @@ public:
return get_rect2(v); return get_rect2(v);
case Variant::RECT2I: case Variant::RECT2I:
return get_rect2i(v); return get_rect2i(v);
case Variant::TRANSFORM: case Variant::TRANSFORM3D:
return get_transform(v); return get_transform(v);
case Variant::TRANSFORM2D: case Variant::TRANSFORM2D:
return get_transform2d(v); return get_transform2d(v);
@ -398,7 +398,7 @@ public:
return get_rect2(v); return get_rect2(v);
case Variant::RECT2I: case Variant::RECT2I:
return get_rect2i(v); return get_rect2i(v);
case Variant::TRANSFORM: case Variant::TRANSFORM3D:
return get_transform(v); return get_transform(v);
case Variant::TRANSFORM2D: case Variant::TRANSFORM2D:
return get_transform2d(v); return get_transform2d(v);
@ -590,9 +590,9 @@ struct VariantGetInternalPtr<Transform2D> {
}; };
template <> template <>
struct VariantGetInternalPtr<Transform> { struct VariantGetInternalPtr<Transform3D> {
static Transform *get_ptr(Variant *v) { return VariantInternal::get_transform(v); } static Transform3D *get_ptr(Variant *v) { return VariantInternal::get_transform(v); }
static const Transform *get_ptr(const Variant *v) { return VariantInternal::get_transform(v); } static const Transform3D *get_ptr(const Variant *v) { return VariantInternal::get_transform(v); }
}; };
template <> template <>
@ -819,9 +819,9 @@ struct VariantInternalAccessor<Transform2D> {
}; };
template <> template <>
struct VariantInternalAccessor<Transform> { struct VariantInternalAccessor<Transform3D> {
static _FORCE_INLINE_ const Transform &get(const Variant *v) { return *VariantInternal::get_transform(v); } static _FORCE_INLINE_ const Transform3D &get(const Variant *v) { return *VariantInternal::get_transform(v); }
static _FORCE_INLINE_ void set(Variant *v, const Transform &p_value) { *VariantInternal::get_transform(v) = p_value; } static _FORCE_INLINE_ void set(Variant *v, const Transform3D &p_value) { *VariantInternal::get_transform(v) = p_value; }
}; };
template <> template <>
@ -1082,7 +1082,7 @@ struct VariantInitializer<Basis> {
}; };
template <> template <>
struct VariantInitializer<Transform> { struct VariantInitializer<Transform3D> {
static _FORCE_INLINE_ void init(Variant *v) { VariantInternal::init_transform(v); } static _FORCE_INLINE_ void init(Variant *v) { VariantInternal::init_transform(v); }
}; };
@ -1256,8 +1256,8 @@ struct VariantZeroAssigner<Basis> {
}; };
template <> template <>
struct VariantZeroAssigner<Transform> { struct VariantZeroAssigner<Transform3D> {
static _FORCE_INLINE_ void zero(Variant *v) { *VariantInternal::get_transform(v) = Transform(); } static _FORCE_INLINE_ void zero(Variant *v) { *VariantInternal::get_transform(v) = Transform3D(); }
}; };
template <> template <>

View File

@ -1465,13 +1465,13 @@ void Variant::_register_variant_operators() {
register_op<OperatorEvaluatorXForm<Vector<Vector2>, Transform2D, Vector<Vector2>>>(Variant::OP_MULTIPLY, Variant::TRANSFORM2D, Variant::PACKED_VECTOR2_ARRAY); register_op<OperatorEvaluatorXForm<Vector<Vector2>, Transform2D, Vector<Vector2>>>(Variant::OP_MULTIPLY, Variant::TRANSFORM2D, Variant::PACKED_VECTOR2_ARRAY);
register_op<OperatorEvaluatorXFormInv<Vector<Vector2>, Vector<Vector2>, Transform2D>>(Variant::OP_MULTIPLY, Variant::PACKED_VECTOR2_ARRAY, Variant::TRANSFORM2D); register_op<OperatorEvaluatorXFormInv<Vector<Vector2>, Vector<Vector2>, Transform2D>>(Variant::OP_MULTIPLY, Variant::PACKED_VECTOR2_ARRAY, Variant::TRANSFORM2D);
register_op<OperatorEvaluatorMul<Transform, Transform, Transform>>(Variant::OP_MULTIPLY, Variant::TRANSFORM, Variant::TRANSFORM); register_op<OperatorEvaluatorMul<Transform3D, Transform3D, Transform3D>>(Variant::OP_MULTIPLY, Variant::TRANSFORM3D, Variant::TRANSFORM3D);
register_op<OperatorEvaluatorXForm<Vector3, Transform, Vector3>>(Variant::OP_MULTIPLY, Variant::TRANSFORM, Variant::VECTOR3); register_op<OperatorEvaluatorXForm<Vector3, Transform3D, Vector3>>(Variant::OP_MULTIPLY, Variant::TRANSFORM3D, Variant::VECTOR3);
register_op<OperatorEvaluatorXFormInv<Vector3, Vector3, Transform>>(Variant::OP_MULTIPLY, Variant::VECTOR3, Variant::TRANSFORM); register_op<OperatorEvaluatorXFormInv<Vector3, Vector3, Transform3D>>(Variant::OP_MULTIPLY, Variant::VECTOR3, Variant::TRANSFORM3D);
register_op<OperatorEvaluatorXForm<::AABB, Transform, ::AABB>>(Variant::OP_MULTIPLY, Variant::TRANSFORM, Variant::AABB); register_op<OperatorEvaluatorXForm<::AABB, Transform3D, ::AABB>>(Variant::OP_MULTIPLY, Variant::TRANSFORM3D, Variant::AABB);
register_op<OperatorEvaluatorXFormInv<::AABB, ::AABB, Transform>>(Variant::OP_MULTIPLY, Variant::AABB, Variant::TRANSFORM); register_op<OperatorEvaluatorXFormInv<::AABB, ::AABB, Transform3D>>(Variant::OP_MULTIPLY, Variant::AABB, Variant::TRANSFORM3D);
register_op<OperatorEvaluatorXForm<Vector<Vector3>, Transform, Vector<Vector3>>>(Variant::OP_MULTIPLY, Variant::TRANSFORM, Variant::PACKED_VECTOR3_ARRAY); register_op<OperatorEvaluatorXForm<Vector<Vector3>, Transform3D, Vector<Vector3>>>(Variant::OP_MULTIPLY, Variant::TRANSFORM3D, Variant::PACKED_VECTOR3_ARRAY);
register_op<OperatorEvaluatorXFormInv<Vector<Vector3>, Vector<Vector3>, Transform>>(Variant::OP_MULTIPLY, Variant::PACKED_VECTOR3_ARRAY, Variant::TRANSFORM); register_op<OperatorEvaluatorXFormInv<Vector<Vector3>, Vector<Vector3>, Transform3D>>(Variant::OP_MULTIPLY, Variant::PACKED_VECTOR3_ARRAY, Variant::TRANSFORM3D);
register_op<OperatorEvaluatorMul<Basis, Basis, Basis>>(Variant::OP_MULTIPLY, Variant::BASIS, Variant::BASIS); register_op<OperatorEvaluatorMul<Basis, Basis, Basis>>(Variant::OP_MULTIPLY, Variant::BASIS, Variant::BASIS);
register_op<OperatorEvaluatorXForm<Vector3, Basis, Vector3>>(Variant::OP_MULTIPLY, Variant::BASIS, Variant::VECTOR3); register_op<OperatorEvaluatorXForm<Vector3, Basis, Vector3>>(Variant::OP_MULTIPLY, Variant::BASIS, Variant::VECTOR3);
@ -1547,7 +1547,7 @@ void Variant::_register_variant_operators() {
register_op<OperatorEvaluatorStringModT<Quat>>(Variant::OP_MODULE, Variant::STRING, Variant::QUAT); register_op<OperatorEvaluatorStringModT<Quat>>(Variant::OP_MODULE, Variant::STRING, Variant::QUAT);
register_op<OperatorEvaluatorStringModT<::AABB>>(Variant::OP_MODULE, Variant::STRING, Variant::AABB); register_op<OperatorEvaluatorStringModT<::AABB>>(Variant::OP_MODULE, Variant::STRING, Variant::AABB);
register_op<OperatorEvaluatorStringModT<Basis>>(Variant::OP_MODULE, Variant::STRING, Variant::BASIS); register_op<OperatorEvaluatorStringModT<Basis>>(Variant::OP_MODULE, Variant::STRING, Variant::BASIS);
register_op<OperatorEvaluatorStringModT<Transform>>(Variant::OP_MODULE, Variant::STRING, Variant::TRANSFORM); register_op<OperatorEvaluatorStringModT<Transform3D>>(Variant::OP_MODULE, Variant::STRING, Variant::TRANSFORM3D);
register_op<OperatorEvaluatorStringModT<Color>>(Variant::OP_MODULE, Variant::STRING, Variant::COLOR); register_op<OperatorEvaluatorStringModT<Color>>(Variant::OP_MODULE, Variant::STRING, Variant::COLOR);
register_op<OperatorEvaluatorStringModT<StringName>>(Variant::OP_MODULE, Variant::STRING, Variant::STRING_NAME); register_op<OperatorEvaluatorStringModT<StringName>>(Variant::OP_MODULE, Variant::STRING, Variant::STRING_NAME);
@ -1615,7 +1615,7 @@ void Variant::_register_variant_operators() {
register_op<OperatorEvaluatorEqual<Quat, Quat>>(Variant::OP_EQUAL, Variant::QUAT, Variant::QUAT); register_op<OperatorEvaluatorEqual<Quat, Quat>>(Variant::OP_EQUAL, Variant::QUAT, Variant::QUAT);
register_op<OperatorEvaluatorEqual<::AABB, ::AABB>>(Variant::OP_EQUAL, Variant::AABB, Variant::AABB); register_op<OperatorEvaluatorEqual<::AABB, ::AABB>>(Variant::OP_EQUAL, Variant::AABB, Variant::AABB);
register_op<OperatorEvaluatorEqual<Basis, Basis>>(Variant::OP_EQUAL, Variant::BASIS, Variant::BASIS); register_op<OperatorEvaluatorEqual<Basis, Basis>>(Variant::OP_EQUAL, Variant::BASIS, Variant::BASIS);
register_op<OperatorEvaluatorEqual<Transform, Transform>>(Variant::OP_EQUAL, Variant::TRANSFORM, Variant::TRANSFORM); register_op<OperatorEvaluatorEqual<Transform3D, Transform3D>>(Variant::OP_EQUAL, Variant::TRANSFORM3D, Variant::TRANSFORM3D);
register_op<OperatorEvaluatorEqual<Color, Color>>(Variant::OP_EQUAL, Variant::COLOR, Variant::COLOR); register_op<OperatorEvaluatorEqual<Color, Color>>(Variant::OP_EQUAL, Variant::COLOR, Variant::COLOR);
register_op<OperatorEvaluatorEqual<StringName, String>>(Variant::OP_EQUAL, Variant::STRING_NAME, Variant::STRING); register_op<OperatorEvaluatorEqual<StringName, String>>(Variant::OP_EQUAL, Variant::STRING_NAME, Variant::STRING);
@ -1661,7 +1661,7 @@ void Variant::_register_variant_operators() {
register_op<OperatorEvaluatorNotEqual<Quat, Quat>>(Variant::OP_NOT_EQUAL, Variant::QUAT, Variant::QUAT); register_op<OperatorEvaluatorNotEqual<Quat, Quat>>(Variant::OP_NOT_EQUAL, Variant::QUAT, Variant::QUAT);
register_op<OperatorEvaluatorNotEqual<::AABB, ::AABB>>(Variant::OP_NOT_EQUAL, Variant::AABB, Variant::AABB); register_op<OperatorEvaluatorNotEqual<::AABB, ::AABB>>(Variant::OP_NOT_EQUAL, Variant::AABB, Variant::AABB);
register_op<OperatorEvaluatorNotEqual<Basis, Basis>>(Variant::OP_NOT_EQUAL, Variant::BASIS, Variant::BASIS); register_op<OperatorEvaluatorNotEqual<Basis, Basis>>(Variant::OP_NOT_EQUAL, Variant::BASIS, Variant::BASIS);
register_op<OperatorEvaluatorNotEqual<Transform, Transform>>(Variant::OP_NOT_EQUAL, Variant::TRANSFORM, Variant::TRANSFORM); register_op<OperatorEvaluatorNotEqual<Transform3D, Transform3D>>(Variant::OP_NOT_EQUAL, Variant::TRANSFORM3D, Variant::TRANSFORM3D);
register_op<OperatorEvaluatorNotEqual<Color, Color>>(Variant::OP_NOT_EQUAL, Variant::COLOR, Variant::COLOR); register_op<OperatorEvaluatorNotEqual<Color, Color>>(Variant::OP_NOT_EQUAL, Variant::COLOR, Variant::COLOR);
register_op<OperatorEvaluatorNotEqual<StringName, String>>(Variant::OP_NOT_EQUAL, Variant::STRING_NAME, Variant::STRING); register_op<OperatorEvaluatorNotEqual<StringName, String>>(Variant::OP_NOT_EQUAL, Variant::STRING_NAME, Variant::STRING);
@ -1852,7 +1852,7 @@ void Variant::_register_variant_operators() {
register_op<OperatorEvaluatorInDictionaryHas<Quat>>(Variant::OP_IN, Variant::QUAT, Variant::DICTIONARY); register_op<OperatorEvaluatorInDictionaryHas<Quat>>(Variant::OP_IN, Variant::QUAT, Variant::DICTIONARY);
register_op<OperatorEvaluatorInDictionaryHas<::AABB>>(Variant::OP_IN, Variant::AABB, Variant::DICTIONARY); register_op<OperatorEvaluatorInDictionaryHas<::AABB>>(Variant::OP_IN, Variant::AABB, Variant::DICTIONARY);
register_op<OperatorEvaluatorInDictionaryHas<Basis>>(Variant::OP_IN, Variant::BASIS, Variant::DICTIONARY); register_op<OperatorEvaluatorInDictionaryHas<Basis>>(Variant::OP_IN, Variant::BASIS, Variant::DICTIONARY);
register_op<OperatorEvaluatorInDictionaryHas<Transform>>(Variant::OP_IN, Variant::TRANSFORM, Variant::DICTIONARY); register_op<OperatorEvaluatorInDictionaryHas<Transform3D>>(Variant::OP_IN, Variant::TRANSFORM3D, Variant::DICTIONARY);
register_op<OperatorEvaluatorInDictionaryHas<Color>>(Variant::OP_IN, Variant::COLOR, Variant::DICTIONARY); register_op<OperatorEvaluatorInDictionaryHas<Color>>(Variant::OP_IN, Variant::COLOR, Variant::DICTIONARY);
register_op<OperatorEvaluatorInDictionaryHas<StringName>>(Variant::OP_IN, Variant::STRING_NAME, Variant::DICTIONARY); register_op<OperatorEvaluatorInDictionaryHas<StringName>>(Variant::OP_IN, Variant::STRING_NAME, Variant::DICTIONARY);
@ -1889,7 +1889,7 @@ void Variant::_register_variant_operators() {
register_op<OperatorEvaluatorInArrayFind<Quat, Array>>(Variant::OP_IN, Variant::QUAT, Variant::ARRAY); register_op<OperatorEvaluatorInArrayFind<Quat, Array>>(Variant::OP_IN, Variant::QUAT, Variant::ARRAY);
register_op<OperatorEvaluatorInArrayFind<::AABB, Array>>(Variant::OP_IN, Variant::AABB, Variant::ARRAY); register_op<OperatorEvaluatorInArrayFind<::AABB, Array>>(Variant::OP_IN, Variant::AABB, Variant::ARRAY);
register_op<OperatorEvaluatorInArrayFind<Basis, Array>>(Variant::OP_IN, Variant::BASIS, Variant::ARRAY); register_op<OperatorEvaluatorInArrayFind<Basis, Array>>(Variant::OP_IN, Variant::BASIS, Variant::ARRAY);
register_op<OperatorEvaluatorInArrayFind<Transform, Array>>(Variant::OP_IN, Variant::TRANSFORM, Variant::ARRAY); register_op<OperatorEvaluatorInArrayFind<Transform3D, Array>>(Variant::OP_IN, Variant::TRANSFORM3D, Variant::ARRAY);
register_op<OperatorEvaluatorInArrayFind<Color, Array>>(Variant::OP_IN, Variant::COLOR, Variant::ARRAY); register_op<OperatorEvaluatorInArrayFind<Color, Array>>(Variant::OP_IN, Variant::COLOR, Variant::ARRAY);
register_op<OperatorEvaluatorInArrayFind<StringName, Array>>(Variant::OP_IN, Variant::STRING_NAME, Variant::ARRAY); register_op<OperatorEvaluatorInArrayFind<StringName, Array>>(Variant::OP_IN, Variant::STRING_NAME, Variant::ARRAY);

View File

@ -653,7 +653,7 @@ Error VariantParser::parse_value(Token &token, Variant &value, Stream *p_stream,
} }
value = Basis(args[0], args[1], args[2], args[3], args[4], args[5], args[6], args[7], args[8]); value = Basis(args[0], args[1], args[2], args[3], args[4], args[5], args[6], args[7], args[8]);
} else if (id == "Transform") { } else if (id == "Transform3D") {
Vector<real_t> args; Vector<real_t> args;
Error err = _parse_construct<real_t>(p_stream, args, line, r_err_str); Error err = _parse_construct<real_t>(p_stream, args, line, r_err_str);
if (err) { if (err) {
@ -665,7 +665,7 @@ Error VariantParser::parse_value(Token &token, Variant &value, Stream *p_stream,
return ERR_PARSE_ERROR; return ERR_PARSE_ERROR;
} }
value = Transform(Basis(args[0], args[1], args[2], args[3], args[4], args[5], args[6], args[7], args[8]), Vector3(args[9], args[10], args[11])); value = Transform3D(Basis(args[0], args[1], args[2], args[3], args[4], args[5], args[6], args[7], args[8]), Vector3(args[9], args[10], args[11]));
} else if (id == "Color") { } else if (id == "Color") {
Vector<float> args; Vector<float> args;
Error err = _parse_construct<float>(p_stream, args, line, r_err_str); Error err = _parse_construct<float>(p_stream, args, line, r_err_str);
@ -1489,9 +1489,9 @@ Error VariantWriter::write(const Variant &p_variant, StoreStringFunc p_store_str
p_store_string_func(p_store_string_ud, s + " )"); p_store_string_func(p_store_string_ud, s + " )");
} break; } break;
case Variant::TRANSFORM: { case Variant::TRANSFORM3D: {
String s = "Transform( "; String s = "Transform3D( ";
Transform t = p_variant; Transform3D t = p_variant;
Basis &m3 = t.basis; Basis &m3 = t.basis;
for (int i = 0; i < 3; i++) { for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++) { for (int j = 0; j < 3; j++) {

View File

@ -288,8 +288,8 @@ SETGET_STRUCT_FUNC_INDEX(Basis, Vector3, x, set_axis, get_axis, 0)
SETGET_STRUCT_FUNC_INDEX(Basis, Vector3, y, set_axis, get_axis, 1) SETGET_STRUCT_FUNC_INDEX(Basis, Vector3, y, set_axis, get_axis, 1)
SETGET_STRUCT_FUNC_INDEX(Basis, Vector3, z, set_axis, get_axis, 2) SETGET_STRUCT_FUNC_INDEX(Basis, Vector3, z, set_axis, get_axis, 2)
SETGET_STRUCT(Transform, Basis, basis) SETGET_STRUCT(Transform3D, Basis, basis)
SETGET_STRUCT(Transform, Vector3, origin) SETGET_STRUCT(Transform3D, Vector3, origin)
SETGET_NUMBER_STRUCT(Color, double, r) SETGET_NUMBER_STRUCT(Color, double, r)
SETGET_NUMBER_STRUCT(Color, double, g) SETGET_NUMBER_STRUCT(Color, double, g)
@ -383,8 +383,8 @@ void register_named_setters_getters() {
REGISTER_MEMBER(Basis, y); REGISTER_MEMBER(Basis, y);
REGISTER_MEMBER(Basis, z); REGISTER_MEMBER(Basis, z);
REGISTER_MEMBER(Transform, basis); REGISTER_MEMBER(Transform3D, basis);
REGISTER_MEMBER(Transform, origin); REGISTER_MEMBER(Transform3D, origin);
REGISTER_MEMBER(Color, r); REGISTER_MEMBER(Color, r);
REGISTER_MEMBER(Color, g); REGISTER_MEMBER(Color, g);
@ -2304,11 +2304,11 @@ void Variant::interpolate(const Variant &a, const Variant &b, float c, Variant &
} }
return; return;
case BASIS: { case BASIS: {
r_dst = Transform(*a._data._basis).interpolate_with(Transform(*b._data._basis), c).basis; r_dst = Transform3D(*a._data._basis).interpolate_with(Transform3D(*b._data._basis), c).basis;
} }
return; return;
case TRANSFORM: { case TRANSFORM3D: {
r_dst = a._data._transform->interpolate_with(*b._data._transform, c); r_dst = a._data._transform3d->interpolate_with(*b._data._transform3d, c);
} }
return; return;
case COLOR: { case COLOR: {

View File

@ -2605,8 +2605,8 @@
<constant name="TYPE_BASIS" value="15" enum="Variant.Type"> <constant name="TYPE_BASIS" value="15" enum="Variant.Type">
Variable is of type [Basis]. Variable is of type [Basis].
</constant> </constant>
<constant name="TYPE_TRANSFORM" value="16" enum="Variant.Type"> <constant name="TYPE_TRANSFORM3D" value="16" enum="Variant.Type">
Variable is of type [Transform]. Variable is of type [Transform3D].
</constant> </constant>
<constant name="TYPE_COLOR" value="17" enum="Variant.Type"> <constant name="TYPE_COLOR" value="17" enum="Variant.Type">
Variable is of type [Color]. Variable is of type [Color].

View File

@ -242,7 +242,7 @@
<method name="operator *" qualifiers="operator"> <method name="operator *" qualifiers="operator">
<return type="AABB"> <return type="AABB">
</return> </return>
<argument index="0" name="right" type="Transform"> <argument index="0" name="right" type="Transform3D">
</argument> </argument>
<description> <description>
</description> </description>

View File

@ -21,10 +21,10 @@
</description> </description>
</method> </method>
<method name="get_root_motion_transform" qualifiers="const"> <method name="get_root_motion_transform" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<description> <description>
Retrieve the motion of the [member root_motion_track] as a [Transform] that can be used elsewhere. If [member root_motion_track] is not a path to a track of type [constant Animation.TYPE_TRANSFORM], returns an identity transformation. Retrieve the motion of the [member root_motion_track] as a [Transform3D] that can be used elsewhere. If [member root_motion_track] is not a path to a track of type [constant Animation.TYPE_TRANSFORM], returns an identity transformation.
</description> </description>
</method> </method>
<method name="rename_parameter"> <method name="rename_parameter">

View File

@ -113,7 +113,7 @@
<method name="lightmap_unwrap"> <method name="lightmap_unwrap">
<return type="int" enum="Error"> <return type="int" enum="Error">
</return> </return>
<argument index="0" name="transform" type="Transform"> <argument index="0" name="transform" type="Transform3D">
</argument> </argument>
<argument index="1" name="texel_size" type="float"> <argument index="1" name="texel_size" type="float">
</argument> </argument>

View File

@ -4,7 +4,7 @@
3×3 matrix datatype. 3×3 matrix datatype.
</brief_description> </brief_description>
<description> <description>
3×3 matrix used for 3D rotation and scale. Almost always used as an orthogonal basis for a Transform. 3×3 matrix used for 3D rotation and scale. Almost always used as an orthogonal basis for a [Transform3D].
Contains 3 vector fields X, Y and Z as its columns, which are typically interpreted as the local basis vectors of a transformation. For such use, it is composed of a scaling and a rotation matrix, in that order (M = R.S). Contains 3 vector fields X, Y and Z as its columns, which are typically interpreted as the local basis vectors of a transformation. For such use, it is composed of a scaling and a rotation matrix, in that order (M = R.S).
Can also be accessed as array of 3D vectors. These vectors are normally orthogonal to each other, but are not necessarily normalized (due to scaling). Can also be accessed as array of 3D vectors. These vectors are normally orthogonal to each other, but are not necessarily normalized (due to scaling).
For more information, read the "Matrices and transforms" documentation article. For more information, read the "Matrices and transforms" documentation article.

View File

@ -27,7 +27,7 @@
</description> </description>
</method> </method>
<method name="get_camera_transform" qualifiers="const"> <method name="get_camera_transform" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<description> <description>
Gets the camera transform. Subclassed cameras such as [ClippedCamera3D] may provide different transforms than the [Node] transform. Gets the camera transform. Subclassed cameras such as [ClippedCamera3D] may provide different transforms than the [Node] transform.

View File

@ -179,12 +179,12 @@
</description> </description>
</method> </method>
<method name="shape_owner_get_transform" qualifiers="const"> <method name="shape_owner_get_transform" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="owner_id" type="int"> <argument index="0" name="owner_id" type="int">
</argument> </argument>
<description> <description>
Returns the shape owner's [Transform]. Returns the shape owner's [Transform3D].
</description> </description>
</method> </method>
<method name="shape_owner_remove_shape"> <method name="shape_owner_remove_shape">
@ -214,10 +214,10 @@
</return> </return>
<argument index="0" name="owner_id" type="int"> <argument index="0" name="owner_id" type="int">
</argument> </argument>
<argument index="1" name="transform" type="Transform"> <argument index="1" name="transform" type="Transform3D">
</argument> </argument>
<description> <description>
Sets the [Transform] of the given shape owner. Sets the [Transform3D] of the given shape owner.
</description> </description>
</method> </method>
</methods> </methods>

View File

@ -11,7 +11,7 @@
<method name="allocate"> <method name="allocate">
<return type="void"> <return type="void">
</return> </return>
<argument index="0" name="to_cell_xform" type="Transform"> <argument index="0" name="to_cell_xform" type="Transform3D">
</argument> </argument>
<argument index="1" name="aabb" type="AABB"> <argument index="1" name="aabb" type="AABB">
</argument> </argument>
@ -59,7 +59,7 @@
</description> </description>
</method> </method>
<method name="get_to_cell_xform" qualifiers="const"> <method name="get_to_cell_xform" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<description> <description>
</description> </description>

View File

@ -22,7 +22,7 @@
<method name="emit_particle"> <method name="emit_particle">
<return type="void"> <return type="void">
</return> </return>
<argument index="0" name="xform" type="Transform"> <argument index="0" name="xform" type="Transform3D">
</argument> </argument>
<argument index="1" name="velocity" type="Vector3"> <argument index="1" name="velocity" type="Vector3">
</argument> </argument>

View File

@ -155,14 +155,14 @@
<method name="test_move"> <method name="test_move">
<return type="bool"> <return type="bool">
</return> </return>
<argument index="0" name="from" type="Transform"> <argument index="0" name="from" type="Transform3D">
</argument> </argument>
<argument index="1" name="rel_vec" type="Vector3"> <argument index="1" name="rel_vec" type="Vector3">
</argument> </argument>
<argument index="2" name="infinite_inertia" type="bool" default="true"> <argument index="2" name="infinite_inertia" type="bool" default="true">
</argument> </argument>
<description> <description>
Checks for collisions without moving the body. Virtually sets the node's position, scale and rotation to that of the given [Transform], then tries to move the body along the vector [code]rel_vec[/code]. Returns [code]true[/code] if a collision would occur. Checks for collisions without moving the body. Virtually sets the node's position, scale and rotation to that of the given [Transform3D], then tries to move the body along the vector [code]rel_vec[/code]. Returns [code]true[/code] if a collision would occur.
</description> </description>
</method> </method>
</methods> </methods>

View File

@ -18,10 +18,10 @@
</description> </description>
</method> </method>
<method name="get_listener_transform" qualifiers="const"> <method name="get_listener_transform" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<description> <description>
Returns the listener's global orthonormalized [Transform]. Returns the listener's global orthonormalized [Transform3D].
</description> </description>
</method> </method>
<method name="is_current" qualifiers="const"> <method name="is_current" qualifiers="const">

View File

@ -72,7 +72,7 @@
</description> </description>
</method> </method>
<method name="get_item_navmesh_transform" qualifiers="const"> <method name="get_item_navmesh_transform" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="id" type="int"> <argument index="0" name="id" type="int">
</argument> </argument>
@ -96,7 +96,7 @@
</argument> </argument>
<description> <description>
Returns an item's collision shapes. Returns an item's collision shapes.
The array consists of each [Shape3D] followed by its [Transform]. The array consists of each [Shape3D] followed by its [Transform3D].
</description> </description>
</method> </method>
<method name="get_last_unused_item_id" qualifiers="const"> <method name="get_last_unused_item_id" qualifiers="const">
@ -154,7 +154,7 @@
</return> </return>
<argument index="0" name="id" type="int"> <argument index="0" name="id" type="int">
</argument> </argument>
<argument index="1" name="navmesh" type="Transform"> <argument index="1" name="navmesh" type="Transform3D">
</argument> </argument>
<description> <description>
Sets the transform to apply to the item's navigation mesh. Sets the transform to apply to the item's navigation mesh.
@ -180,7 +180,7 @@
</argument> </argument>
<description> <description>
Sets an item's collision shapes. Sets an item's collision shapes.
The array should consist of [Shape3D] objects, each followed by a [Transform] that will be applied to it. For shapes that should not have a transform, use [constant Transform.IDENTITY]. The array should consist of [Shape3D] objects, each followed by a [Transform3D] that will be applied to it. For shapes that should not have a transform, use [constant Transform3D.IDENTITY].
</description> </description>
</method> </method>
</methods> </methods>

View File

@ -40,12 +40,12 @@
</description> </description>
</method> </method>
<method name="get_instance_transform" qualifiers="const"> <method name="get_instance_transform" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="instance" type="int"> <argument index="0" name="instance" type="int">
</argument> </argument>
<description> <description>
Returns the [Transform] of a specific instance. Returns the [Transform3D] of a specific instance.
</description> </description>
</method> </method>
<method name="get_instance_transform_2d" qualifiers="const"> <method name="get_instance_transform_2d" qualifiers="const">
@ -86,10 +86,10 @@
</return> </return>
<argument index="0" name="instance" type="int"> <argument index="0" name="instance" type="int">
</argument> </argument>
<argument index="1" name="transform" type="Transform"> <argument index="1" name="transform" type="Transform3D">
</argument> </argument>
<description> <description>
Sets the [Transform] for a specific instance. Sets the [Transform3D] for a specific instance.
</description> </description>
</method> </method>
<method name="set_instance_transform_2d"> <method name="set_instance_transform_2d">

View File

@ -413,7 +413,7 @@
</return> </return>
<argument index="0" name="region" type="RID"> <argument index="0" name="region" type="RID">
</argument> </argument>
<argument index="1" name="transform" type="Transform"> <argument index="1" name="transform" type="Transform3D">
</argument> </argument>
<description> <description>
Sets the global transformation for the region. Sets the global transformation for the region.

View File

@ -4,7 +4,7 @@
Most basic 3D game object, parent of all 3D-related nodes. Most basic 3D game object, parent of all 3D-related nodes.
</brief_description> </brief_description>
<description> <description>
Most basic 3D game object, with a 3D [Transform] and visibility settings. All other 3D game objects inherit from Node3D. Use [Node3D] as a parent node to move, scale, rotate and show/hide children in a 3D project. Most basic 3D game object, with a 3D [Transform3D] and visibility settings. All other 3D game objects inherit from Node3D. Use [Node3D] as a parent node to move, scale, rotate and show/hide children in a 3D project.
Affine operations (rotate, scale, translate) happen in parent's local coordinate system, unless the [Node3D] object is set as top-level. Affine operations in this coordinate system correspond to direct affine operations on the [Node3D]'s transform. The word local below refers to this coordinate system. The coordinate system that is attached to the [Node3D] object itself is referred to as object-local coordinate system. Affine operations (rotate, scale, translate) happen in parent's local coordinate system, unless the [Node3D] object is set as top-level. Affine operations in this coordinate system correspond to direct affine operations on the [Node3D]'s transform. The word local below refers to this coordinate system. The coordinate system that is attached to the [Node3D] object itself is referred to as object-local coordinate system.
[b]Note:[/b] Unless otherwise specified, all methods that have angle parameters must have angles specified as [i]radians[/i]. To convert degrees to radians, use [method @GlobalScope.deg2rad]. [b]Note:[/b] Unless otherwise specified, all methods that have angle parameters must have angles specified as [i]radians[/i]. To convert degrees to radians, use [method @GlobalScope.deg2rad].
</description> </description>
@ -128,7 +128,7 @@
<return type="void"> <return type="void">
</return> </return>
<description> <description>
Resets this node's transformations (like scale, skew and taper) preserving its rotation and translation by performing Gram-Schmidt orthonormalization on this node's [Transform]. Resets this node's transformations (like scale, skew and taper) preserving its rotation and translation by performing Gram-Schmidt orthonormalization on this node's [Transform3D].
</description> </description>
</method> </method>
<method name="rotate"> <method name="rotate">
@ -202,7 +202,7 @@
<return type="void"> <return type="void">
</return> </return>
<description> <description>
Reset all transformations for this node (sets its [Transform] to the identity matrix). Reset all transformations for this node (sets its [Transform3D] to the identity matrix).
</description> </description>
</method> </method>
<method name="set_ignore_transform_notification"> <method name="set_ignore_transform_notification">
@ -288,8 +288,8 @@
<member name="gizmo" type="Node3DGizmo" setter="set_gizmo" getter="get_gizmo"> <member name="gizmo" type="Node3DGizmo" setter="set_gizmo" getter="get_gizmo">
The [Node3DGizmo] for this node. Used for example in [EditorNode3DGizmo] as custom visualization and editing handles in Editor. The [Node3DGizmo] for this node. Used for example in [EditorNode3DGizmo] as custom visualization and editing handles in Editor.
</member> </member>
<member name="global_transform" type="Transform" setter="set_global_transform" getter="get_global_transform"> <member name="global_transform" type="Transform3D" setter="set_global_transform" getter="get_global_transform">
World3D space (global) [Transform] of this node. World3D space (global) [Transform3D] of this node.
</member> </member>
<member name="rotation" type="Vector3" setter="set_rotation" getter="get_rotation"> <member name="rotation" type="Vector3" setter="set_rotation" getter="get_rotation">
Rotation part of the local transformation in radians, specified in terms of YXZ-Euler angles in the format (X angle, Y angle, Z angle). Rotation part of the local transformation in radians, specified in terms of YXZ-Euler angles in the format (X angle, Y angle, Z angle).
@ -304,8 +304,8 @@
<member name="top_level" type="bool" setter="set_as_top_level" getter="is_set_as_top_level" default="false"> <member name="top_level" type="bool" setter="set_as_top_level" getter="is_set_as_top_level" default="false">
If [code]true[/code], the node will not inherit its transformations from its parent. Node transformations are only in global space. If [code]true[/code], the node will not inherit its transformations from its parent. Node transformations are only in global space.
</member> </member>
<member name="transform" type="Transform" setter="set_transform" getter="get_transform" default="Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )"> <member name="transform" type="Transform3D" setter="set_transform" getter="get_transform" default="Transform3D( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )">
Local space [Transform] of this node, with respect to the parent node. Local space [Transform3D] of this node, with respect to the parent node.
</member> </member>
<member name="translation" type="Vector3" setter="set_translation" getter="get_translation" default="Vector3( 0, 0, 0 )"> <member name="translation" type="Vector3" setter="set_translation" getter="get_translation" default="Vector3( 0, 0, 0 )">
Local translation of this node. Local translation of this node.

View File

@ -106,7 +106,7 @@
<method name="operator *" qualifiers="operator"> <method name="operator *" qualifiers="operator">
<return type="PackedVector3Array"> <return type="PackedVector3Array">
</return> </return>
<argument index="0" name="right" type="Transform"> <argument index="0" name="right" type="Transform3D">
</argument> </argument>
<description> <description>
</description> </description>

View File

@ -84,7 +84,7 @@
<member name="axis_lock_linear_z" type="bool" setter="set_axis_lock" getter="get_axis_lock" default="false"> <member name="axis_lock_linear_z" type="bool" setter="set_axis_lock" getter="get_axis_lock" default="false">
Lock the body's movement in the Z axis. Lock the body's movement in the Z axis.
</member> </member>
<member name="body_offset" type="Transform" setter="set_body_offset" getter="get_body_offset" default="Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )"> <member name="body_offset" type="Transform3D" setter="set_body_offset" getter="get_body_offset" default="Transform3D( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )">
Sets the body's transform. Sets the body's transform.
</member> </member>
<member name="bounce" type="float" setter="set_bounce" getter="get_bounce" default="0.0"> <member name="bounce" type="float" setter="set_bounce" getter="get_bounce" default="0.0">
@ -99,7 +99,7 @@
<member name="gravity_scale" type="float" setter="set_gravity_scale" getter="get_gravity_scale" default="1.0"> <member name="gravity_scale" type="float" setter="set_gravity_scale" getter="get_gravity_scale" default="1.0">
This is multiplied by the global 3D gravity setting found in [b]Project &gt; Project Settings &gt; Physics &gt; 3d[/b] to produce the body's gravity. For example, a value of 1 will be normal gravity, 2 will apply double gravity, and 0.5 will apply half gravity to this object. This is multiplied by the global 3D gravity setting found in [b]Project &gt; Project Settings &gt; Physics &gt; 3d[/b] to produce the body's gravity. For example, a value of 1 will be normal gravity, 2 will apply double gravity, and 0.5 will apply half gravity to this object.
</member> </member>
<member name="joint_offset" type="Transform" setter="set_joint_offset" getter="get_joint_offset" default="Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )"> <member name="joint_offset" type="Transform3D" setter="set_joint_offset" getter="get_joint_offset" default="Transform3D( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )">
Sets the joint's transform. Sets the joint's transform.
</member> </member>
<member name="joint_rotation" type="Vector3" setter="set_joint_rotation" getter="get_joint_rotation"> <member name="joint_rotation" type="Vector3" setter="set_joint_rotation" getter="get_joint_rotation">

View File

@ -214,7 +214,7 @@
<member name="total_linear_damp" type="float" setter="" getter="get_total_linear_damp"> <member name="total_linear_damp" type="float" setter="" getter="get_total_linear_damp">
The rate at which the body stops moving, if there are not any other forces moving it. The rate at which the body stops moving, if there are not any other forces moving it.
</member> </member>
<member name="transform" type="Transform" setter="set_transform" getter="get_transform"> <member name="transform" type="Transform3D" setter="set_transform" getter="get_transform">
The body's transformation matrix. The body's transformation matrix.
</member> </member>
</members> </members>

View File

@ -16,7 +16,7 @@
</argument> </argument>
<argument index="1" name="shape" type="RID"> <argument index="1" name="shape" type="RID">
</argument> </argument>
<argument index="2" name="transform" type="Transform" default="Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )"> <argument index="2" name="transform" type="Transform3D" default="Transform3D( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )">
</argument> </argument>
<argument index="3" name="disabled" type="bool" default="false"> <argument index="3" name="disabled" type="bool" default="false">
</argument> </argument>
@ -92,7 +92,7 @@
</description> </description>
</method> </method>
<method name="area_get_shape_transform" qualifiers="const"> <method name="area_get_shape_transform" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="area" type="RID"> <argument index="0" name="area" type="RID">
</argument> </argument>
@ -121,7 +121,7 @@
</description> </description>
</method> </method>
<method name="area_get_transform" qualifiers="const"> <method name="area_get_transform" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="area" type="RID"> <argument index="0" name="area" type="RID">
</argument> </argument>
@ -258,7 +258,7 @@
</argument> </argument>
<argument index="1" name="shape_idx" type="int"> <argument index="1" name="shape_idx" type="int">
</argument> </argument>
<argument index="2" name="transform" type="Transform"> <argument index="2" name="transform" type="Transform3D">
</argument> </argument>
<description> <description>
Sets the transform matrix for an area shape. Sets the transform matrix for an area shape.
@ -291,7 +291,7 @@
</return> </return>
<argument index="0" name="area" type="RID"> <argument index="0" name="area" type="RID">
</argument> </argument>
<argument index="1" name="transform" type="Transform"> <argument index="1" name="transform" type="Transform3D">
</argument> </argument>
<description> <description>
Sets the transform matrix for an area. Sets the transform matrix for an area.
@ -337,7 +337,7 @@
</argument> </argument>
<argument index="1" name="shape" type="RID"> <argument index="1" name="shape" type="RID">
</argument> </argument>
<argument index="2" name="transform" type="Transform" default="Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )"> <argument index="2" name="transform" type="Transform3D" default="Transform3D( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )">
</argument> </argument>
<argument index="3" name="disabled" type="bool" default="false"> <argument index="3" name="disabled" type="bool" default="false">
</argument> </argument>
@ -510,7 +510,7 @@
</description> </description>
</method> </method>
<method name="body_get_shape_transform" qualifiers="const"> <method name="body_get_shape_transform" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="body" type="RID"> <argument index="0" name="body" type="RID">
</argument> </argument>
@ -760,7 +760,7 @@
</argument> </argument>
<argument index="1" name="shape_idx" type="int"> <argument index="1" name="shape_idx" type="int">
</argument> </argument>
<argument index="2" name="transform" type="Transform"> <argument index="2" name="transform" type="Transform3D">
</argument> </argument>
<description> <description>
Sets the transform matrix for a body shape. Sets the transform matrix for a body shape.
@ -1017,11 +1017,11 @@
</argument> </argument>
<argument index="1" name="body_A" type="RID"> <argument index="1" name="body_A" type="RID">
</argument> </argument>
<argument index="2" name="local_ref_A" type="Transform"> <argument index="2" name="local_ref_A" type="Transform3D">
</argument> </argument>
<argument index="3" name="body_B" type="RID"> <argument index="3" name="body_B" type="RID">
</argument> </argument>
<argument index="4" name="local_ref_B" type="Transform"> <argument index="4" name="local_ref_B" type="Transform3D">
</argument> </argument>
<description> <description>
</description> </description>
@ -1033,11 +1033,11 @@
</argument> </argument>
<argument index="1" name="body_A" type="RID"> <argument index="1" name="body_A" type="RID">
</argument> </argument>
<argument index="2" name="local_ref_A" type="Transform"> <argument index="2" name="local_ref_A" type="Transform3D">
</argument> </argument>
<argument index="3" name="body_B" type="RID"> <argument index="3" name="body_B" type="RID">
</argument> </argument>
<argument index="4" name="local_ref_B" type="Transform"> <argument index="4" name="local_ref_B" type="Transform3D">
</argument> </argument>
<description> <description>
</description> </description>
@ -1049,11 +1049,11 @@
</argument> </argument>
<argument index="1" name="body_A" type="RID"> <argument index="1" name="body_A" type="RID">
</argument> </argument>
<argument index="2" name="hinge_A" type="Transform"> <argument index="2" name="hinge_A" type="Transform3D">
</argument> </argument>
<argument index="3" name="body_B" type="RID"> <argument index="3" name="body_B" type="RID">
</argument> </argument>
<argument index="4" name="hinge_B" type="Transform"> <argument index="4" name="hinge_B" type="Transform3D">
</argument> </argument>
<description> <description>
</description> </description>
@ -1081,11 +1081,11 @@
</argument> </argument>
<argument index="1" name="body_A" type="RID"> <argument index="1" name="body_A" type="RID">
</argument> </argument>
<argument index="2" name="local_ref_A" type="Transform"> <argument index="2" name="local_ref_A" type="Transform3D">
</argument> </argument>
<argument index="3" name="body_B" type="RID"> <argument index="3" name="body_B" type="RID">
</argument> </argument>
<argument index="4" name="local_ref_B" type="Transform"> <argument index="4" name="local_ref_B" type="Transform3D">
</argument> </argument>
<description> <description>
</description> </description>

View File

@ -60,7 +60,7 @@
[/csharp] [/csharp]
[/codeblocks] [/codeblocks]
</member> </member>
<member name="transform" type="Transform" setter="set_transform" getter="get_transform" default="Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )"> <member name="transform" type="Transform3D" setter="set_transform" getter="get_transform" default="Transform3D( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )">
The queried shape's transform matrix. The queried shape's transform matrix.
</member> </member>
</members> </members>

View File

@ -1,10 +1,10 @@
<?xml version="1.0" encoding="UTF-8" ?> <?xml version="1.0" encoding="UTF-8" ?>
<class name="RemoteTransform3D" inherits="Node3D" version="4.0"> <class name="RemoteTransform3D" inherits="Node3D" version="4.0">
<brief_description> <brief_description>
RemoteTransform3D pushes its own [Transform] to another [Node3D] derived Node in the scene. RemoteTransform3D pushes its own [Transform3D] to another [Node3D] derived Node in the scene.
</brief_description> </brief_description>
<description> <description>
RemoteTransform3D pushes its own [Transform] to another [Node3D] derived Node (called the remote node) in the scene. RemoteTransform3D pushes its own [Transform3D] to another [Node3D] derived Node (called the remote node) in the scene.
It can be set to update another Node's position, rotation and/or scale. It can use either global or local coordinates. It can be set to update another Node's position, rotation and/or scale. It can use either global or local coordinates.
</description> </description>
<tutorials> <tutorials>

View File

@ -130,10 +130,10 @@
</return> </return>
<argument index="0" name="camera" type="RID"> <argument index="0" name="camera" type="RID">
</argument> </argument>
<argument index="1" name="transform" type="Transform"> <argument index="1" name="transform" type="Transform3D">
</argument> </argument>
<description> <description>
Sets [Transform] of camera. Sets [Transform3D] of camera.
</description> </description>
</method> </method>
<method name="camera_set_use_vertical_aspect"> <method name="camera_set_use_vertical_aspect">
@ -1335,7 +1335,7 @@
</return> </return>
<argument index="0" name="instance" type="RID"> <argument index="0" name="instance" type="RID">
</argument> </argument>
<argument index="1" name="transform" type="Transform"> <argument index="1" name="transform" type="Transform3D">
</argument> </argument>
<description> <description>
Sets the world space transform of the instance. Equivalent to [member Node3D.transform]. Sets the world space transform of the instance. Equivalent to [member Node3D.transform].
@ -1894,14 +1894,14 @@
</description> </description>
</method> </method>
<method name="multimesh_instance_get_transform" qualifiers="const"> <method name="multimesh_instance_get_transform" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="multimesh" type="RID"> <argument index="0" name="multimesh" type="RID">
</argument> </argument>
<argument index="1" name="index" type="int"> <argument index="1" name="index" type="int">
</argument> </argument>
<description> <description>
Returns the [Transform] of the specified instance. Returns the [Transform3D] of the specified instance.
</description> </description>
</method> </method>
<method name="multimesh_instance_get_transform_2d" qualifiers="const"> <method name="multimesh_instance_get_transform_2d" qualifiers="const">
@ -1948,10 +1948,10 @@
</argument> </argument>
<argument index="1" name="index" type="int"> <argument index="1" name="index" type="int">
</argument> </argument>
<argument index="2" name="transform" type="Transform"> <argument index="2" name="transform" type="Transform3D">
</argument> </argument>
<description> <description>
Sets the [Transform] for this instance. Equivalent to [method MultiMesh.set_instance_transform]. Sets the [Transform3D] for this instance. Equivalent to [method MultiMesh.set_instance_transform].
</description> </description>
</method> </method>
<method name="multimesh_instance_set_transform_2d"> <method name="multimesh_instance_set_transform_2d">
@ -2142,10 +2142,10 @@
</return> </return>
<argument index="0" name="particles" type="RID"> <argument index="0" name="particles" type="RID">
</argument> </argument>
<argument index="1" name="transform" type="Transform"> <argument index="1" name="transform" type="Transform3D">
</argument> </argument>
<description> <description>
Sets the [Transform] that will be used by the particles when they first emit. Sets the [Transform3D] that will be used by the particles when they first emit.
</description> </description>
</method> </method>
<method name="particles_set_emitting"> <method name="particles_set_emitting">
@ -2590,14 +2590,14 @@
</description> </description>
</method> </method>
<method name="skeleton_bone_get_transform" qualifiers="const"> <method name="skeleton_bone_get_transform" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="skeleton" type="RID"> <argument index="0" name="skeleton" type="RID">
</argument> </argument>
<argument index="1" name="bone" type="int"> <argument index="1" name="bone" type="int">
</argument> </argument>
<description> <description>
Returns the [Transform] set for a specific bone of this skeleton. Returns the [Transform3D] set for a specific bone of this skeleton.
</description> </description>
</method> </method>
<method name="skeleton_bone_get_transform_2d" qualifiers="const"> <method name="skeleton_bone_get_transform_2d" qualifiers="const">
@ -2618,10 +2618,10 @@
</argument> </argument>
<argument index="1" name="bone" type="int"> <argument index="1" name="bone" type="int">
</argument> </argument>
<argument index="2" name="transform" type="Transform"> <argument index="2" name="transform" type="Transform3D">
</argument> </argument>
<description> <description>
Sets the [Transform] for a specific bone of this skeleton. Sets the [Transform3D] for a specific bone of this skeleton.
</description> </description>
</method> </method>
<method name="skeleton_bone_set_transform_2d"> <method name="skeleton_bone_set_transform_2d">
@ -3267,7 +3267,7 @@
Use [Transform2D] to store MultiMesh transform. Use [Transform2D] to store MultiMesh transform.
</constant> </constant>
<constant name="MULTIMESH_TRANSFORM_3D" value="1" enum="MultimeshTransformFormat"> <constant name="MULTIMESH_TRANSFORM_3D" value="1" enum="MultimeshTransformFormat">
Use [Transform] to store MultiMesh transform. Use [Transform3D] to store MultiMesh transform.
</constant> </constant>
<constant name="LIGHT_DIRECTIONAL" value="0" enum="LightType"> <constant name="LIGHT_DIRECTIONAL" value="0" enum="LightType">
Is a directional (sun) light. Is a directional (sun) light.

View File

@ -23,9 +23,9 @@
</description> </description>
</method> </method>
<method name="bone_transform_to_world_transform"> <method name="bone_transform_to_world_transform">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="bone_transform" type="Transform"> <argument index="0" name="bone_transform" type="Transform3D">
</argument> </argument>
<description> <description>
Takes the given bone pose/transform and converts it to a world transform, relative to the [Skeleton3D] node. Takes the given bone pose/transform and converts it to a world transform, relative to the [Skeleton3D] node.
@ -63,7 +63,7 @@
</description> </description>
</method> </method>
<method name="get_bone_custom_pose" qualifiers="const"> <method name="get_bone_custom_pose" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="bone_idx" type="int"> <argument index="0" name="bone_idx" type="int">
</argument> </argument>
@ -72,7 +72,7 @@
</description> </description>
</method> </method>
<method name="get_bone_global_pose" qualifiers="const"> <method name="get_bone_global_pose" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="bone_idx" type="int"> <argument index="0" name="bone_idx" type="int">
</argument> </argument>
@ -81,7 +81,7 @@
</description> </description>
</method> </method>
<method name="get_bone_global_pose_no_override" qualifiers="const"> <method name="get_bone_global_pose_no_override" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="bone_idx" type="int"> <argument index="0" name="bone_idx" type="int">
</argument> </argument>
@ -109,7 +109,7 @@
</description> </description>
</method> </method>
<method name="get_bone_pose" qualifiers="const"> <method name="get_bone_pose" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="bone_idx" type="int"> <argument index="0" name="bone_idx" type="int">
</argument> </argument>
@ -124,7 +124,7 @@
</description> </description>
</method> </method>
<method name="get_bone_rest" qualifiers="const"> <method name="get_bone_rest" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="bone_idx" type="int"> <argument index="0" name="bone_idx" type="int">
</argument> </argument>
@ -199,7 +199,7 @@
</return> </return>
<argument index="0" name="bone_idx" type="int"> <argument index="0" name="bone_idx" type="int">
</argument> </argument>
<argument index="1" name="custom_pose" type="Transform"> <argument index="1" name="custom_pose" type="Transform3D">
</argument> </argument>
<description> <description>
Sets the custom pose transform, [code]custom_pose[/code], for the bone at [code]bone_idx[/code]. This pose is an addition to the bone rest pose. Sets the custom pose transform, [code]custom_pose[/code], for the bone at [code]bone_idx[/code]. This pose is an addition to the bone rest pose.
@ -222,7 +222,7 @@
</return> </return>
<argument index="0" name="bone_idx" type="int"> <argument index="0" name="bone_idx" type="int">
</argument> </argument>
<argument index="1" name="pose" type="Transform"> <argument index="1" name="pose" type="Transform3D">
</argument> </argument>
<argument index="2" name="amount" type="float"> <argument index="2" name="amount" type="float">
</argument> </argument>
@ -261,7 +261,7 @@
</return> </return>
<argument index="0" name="bone_idx" type="int"> <argument index="0" name="bone_idx" type="int">
</argument> </argument>
<argument index="1" name="pose" type="Transform"> <argument index="1" name="pose" type="Transform3D">
</argument> </argument>
<description> <description>
Sets the pose transform for bone [code]bone_idx[/code]. Sets the pose transform for bone [code]bone_idx[/code].
@ -273,7 +273,7 @@
</return> </return>
<argument index="0" name="bone_idx" type="int"> <argument index="0" name="bone_idx" type="int">
</argument> </argument>
<argument index="1" name="rest" type="Transform"> <argument index="1" name="rest" type="Transform3D">
</argument> </argument>
<description> <description>
Sets the rest transform for bone [code]bone_idx[/code]. Sets the rest transform for bone [code]bone_idx[/code].
@ -289,9 +289,9 @@
</description> </description>
</method> </method>
<method name="world_transform_to_bone_transform"> <method name="world_transform_to_bone_transform">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="world_transform" type="Transform"> <argument index="0" name="world_transform" type="Transform3D">
</argument> </argument>
<description> <description>
Takes the given world transform, relative to the [Skeleton3D], and converts it to a bone pose/transform. Takes the given world transform, relative to the [Skeleton3D], and converts it to a bone pose/transform.

View File

@ -48,7 +48,7 @@
</member> </member>
<member name="root_bone" type="StringName" setter="set_root_bone" getter="get_root_bone" default="@&quot;&quot;"> <member name="root_bone" type="StringName" setter="set_root_bone" getter="get_root_bone" default="@&quot;&quot;">
</member> </member>
<member name="target" type="Transform" setter="set_target_transform" getter="get_target_transform" default="Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )"> <member name="target" type="Transform3D" setter="set_target_transform" getter="get_target_transform" default="Transform3D( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )">
</member> </member>
<member name="target_node" type="NodePath" setter="set_target_node" getter="get_target_node" default="NodePath(&quot;&quot;)"> <member name="target_node" type="NodePath" setter="set_target_node" getter="get_target_node" default="NodePath(&quot;&quot;)">
</member> </member>

View File

@ -12,7 +12,7 @@
</return> </return>
<argument index="0" name="bone" type="int"> <argument index="0" name="bone" type="int">
</argument> </argument>
<argument index="1" name="pose" type="Transform"> <argument index="1" name="pose" type="Transform3D">
</argument> </argument>
<description> <description>
</description> </description>
@ -46,7 +46,7 @@
</description> </description>
</method> </method>
<method name="get_bind_pose" qualifiers="const"> <method name="get_bind_pose" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="bind_index" type="int"> <argument index="0" name="bind_index" type="int">
</argument> </argument>
@ -86,7 +86,7 @@
</return> </return>
<argument index="0" name="bind_index" type="int"> <argument index="0" name="bind_index" type="int">
</argument> </argument>
<argument index="1" name="pose" type="Transform"> <argument index="1" name="pose" type="Transform3D">
</argument> </argument>
<description> <description>
</description> </description>

View File

@ -76,10 +76,10 @@
</argument> </argument>
<argument index="1" name="surface" type="int"> <argument index="1" name="surface" type="int">
</argument> </argument>
<argument index="2" name="transform" type="Transform"> <argument index="2" name="transform" type="Transform3D">
</argument> </argument>
<description> <description>
Append vertices from a given [Mesh] surface onto the current vertex array with specified [Transform]. Append vertices from a given [Mesh] surface onto the current vertex array with specified [Transform3D].
</description> </description>
</method> </method>
<method name="begin"> <method name="begin">

View File

@ -18,7 +18,7 @@
<return type="Transform2D"> <return type="Transform2D">
</return> </return>
<description> <description>
Constructs a default-initialized [Transform] set to [constant IDENTITY]. Constructs a default-initialized [Transform2D] set to [constant IDENTITY].
</description> </description>
</method> </method>
<method name="Transform2D" qualifiers="constructor"> <method name="Transform2D" qualifiers="constructor">

View File

@ -1,5 +1,5 @@
<?xml version="1.0" encoding="UTF-8" ?> <?xml version="1.0" encoding="UTF-8" ?>
<class name="Transform" version="4.0"> <class name="Transform3D" version="4.0">
<brief_description> <brief_description>
3D transformation (3×4 matrix). 3D transformation (3×4 matrix).
</brief_description> </brief_description>
@ -16,35 +16,35 @@
<link title="2.5D Demo">https://godotengine.org/asset-library/asset/583</link> <link title="2.5D Demo">https://godotengine.org/asset-library/asset/583</link>
</tutorials> </tutorials>
<methods> <methods>
<method name="Transform" qualifiers="constructor"> <method name="Transform3D" qualifiers="constructor">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<description> <description>
Constructs a default-initialized [Transform] set to [constant IDENTITY]. Constructs a default-initialized [Transform3D] set to [constant IDENTITY].
</description> </description>
</method> </method>
<method name="Transform" qualifiers="constructor"> <method name="Transform3D" qualifiers="constructor">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="from" type="Transform"> <argument index="0" name="from" type="Transform3D">
</argument> </argument>
<description> <description>
Constructs a [Transform] as a copy of the given [Transform]. Constructs a [Transform3D] as a copy of the given [Transform3D].
</description> </description>
</method> </method>
<method name="Transform" qualifiers="constructor"> <method name="Transform3D" qualifiers="constructor">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="basis" type="Basis"> <argument index="0" name="basis" type="Basis">
</argument> </argument>
<argument index="1" name="origin" type="Vector3"> <argument index="1" name="origin" type="Vector3">
</argument> </argument>
<description> <description>
Constructs a Transform from a [Basis] and [Vector3]. Constructs a Transform3D from a [Basis] and [Vector3].
</description> </description>
</method> </method>
<method name="Transform" qualifiers="constructor"> <method name="Transform3D" qualifiers="constructor">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="x_axis" type="Vector3"> <argument index="0" name="x_axis" type="Vector3">
</argument> </argument>
@ -55,29 +55,29 @@
<argument index="3" name="origin" type="Vector3"> <argument index="3" name="origin" type="Vector3">
</argument> </argument>
<description> <description>
Constructs a Transform from four [Vector3] values (matrix columns). Each axis corresponds to local basis vectors (some of which may be scaled). Constructs a Transform3D from four [Vector3] values (matrix columns). Each axis corresponds to local basis vectors (some of which may be scaled).
</description> </description>
</method> </method>
<method name="affine_inverse" qualifiers="const"> <method name="affine_inverse" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<description> <description>
Returns the inverse of the transform, under the assumption that the transformation is composed of rotation, scaling and translation. Returns the inverse of the transform, under the assumption that the transformation is composed of rotation, scaling and translation.
</description> </description>
</method> </method>
<method name="interpolate_with" qualifiers="const"> <method name="interpolate_with" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="xform" type="Transform"> <argument index="0" name="xform" type="Transform3D">
</argument> </argument>
<argument index="1" name="weight" type="float"> <argument index="1" name="weight" type="float">
</argument> </argument>
<description> <description>
Interpolates the transform to other Transform by weight amount (on the range of 0.0 to 1.0). Interpolates the transform to other Transform3D by weight amount (on the range of 0.0 to 1.0).
</description> </description>
</method> </method>
<method name="inverse" qualifiers="const"> <method name="inverse" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<description> <description>
Returns the inverse of the transform, under the assumption that the transformation is composed of rotation and translation (no scaling, use affine_inverse for transforms with scaling). Returns the inverse of the transform, under the assumption that the transformation is composed of rotation and translation (no scaling, use affine_inverse for transforms with scaling).
@ -86,14 +86,14 @@
<method name="is_equal_approx" qualifiers="const"> <method name="is_equal_approx" qualifiers="const">
<return type="bool"> <return type="bool">
</return> </return>
<argument index="0" name="xform" type="Transform"> <argument index="0" name="xform" type="Transform3D">
</argument> </argument>
<description> <description>
Returns [code]true[/code] if this transform and [code]transform[/code] are approximately equal, by calling [code]is_equal_approx[/code] on each component. Returns [code]true[/code] if this transform and [code]transform[/code] are approximately equal, by calling [code]is_equal_approx[/code] on each component.
</description> </description>
</method> </method>
<method name="looking_at" qualifiers="const"> <method name="looking_at" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="target" type="Vector3"> <argument index="0" name="target" type="Vector3">
</argument> </argument>
@ -108,7 +108,7 @@
<method name="operator !=" qualifiers="operator"> <method name="operator !=" qualifiers="operator">
<return type="bool"> <return type="bool">
</return> </return>
<argument index="0" name="right" type="Transform"> <argument index="0" name="right" type="Transform3D">
</argument> </argument>
<description> <description>
</description> </description>
@ -122,9 +122,9 @@
</description> </description>
</method> </method>
<method name="operator *" qualifiers="operator"> <method name="operator *" qualifiers="operator">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="right" type="Transform"> <argument index="0" name="right" type="Transform3D">
</argument> </argument>
<description> <description>
</description> </description>
@ -148,20 +148,20 @@
<method name="operator ==" qualifiers="operator"> <method name="operator ==" qualifiers="operator">
<return type="bool"> <return type="bool">
</return> </return>
<argument index="0" name="right" type="Transform"> <argument index="0" name="right" type="Transform3D">
</argument> </argument>
<description> <description>
</description> </description>
</method> </method>
<method name="orthonormalized" qualifiers="const"> <method name="orthonormalized" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<description> <description>
Returns the transform with the basis orthogonal (90 degrees), and normalized axis vectors. Returns the transform with the basis orthogonal (90 degrees), and normalized axis vectors.
</description> </description>
</method> </method>
<method name="rotated" qualifiers="const"> <method name="rotated" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="axis" type="Vector3"> <argument index="0" name="axis" type="Vector3">
</argument> </argument>
@ -172,7 +172,7 @@
</description> </description>
</method> </method>
<method name="scaled" qualifiers="const"> <method name="scaled" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="scale" type="Vector3"> <argument index="0" name="scale" type="Vector3">
</argument> </argument>
@ -181,7 +181,7 @@
</description> </description>
</method> </method>
<method name="translated" qualifiers="const"> <method name="translated" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="offset" type="Vector3"> <argument index="0" name="offset" type="Vector3">
</argument> </argument>
@ -200,17 +200,17 @@
</member> </member>
</members> </members>
<constants> <constants>
<constant name="IDENTITY" value="Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )"> <constant name="IDENTITY" value="Transform3D( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )">
[Transform] with no translation, rotation or scaling applied. When applied to other data structures, [constant IDENTITY] performs no transformation. [Transform3D] with no translation, rotation or scaling applied. When applied to other data structures, [constant IDENTITY] performs no transformation.
</constant> </constant>
<constant name="FLIP_X" value="Transform( -1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )"> <constant name="FLIP_X" value="Transform3D( -1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )">
[Transform] with mirroring applied perpendicular to the YZ plane. [Transform3D] with mirroring applied perpendicular to the YZ plane.
</constant> </constant>
<constant name="FLIP_Y" value="Transform( 1, 0, 0, 0, -1, 0, 0, 0, 1, 0, 0, 0 )"> <constant name="FLIP_Y" value="Transform3D( 1, 0, 0, 0, -1, 0, 0, 0, 1, 0, 0, 0 )">
[Transform] with mirroring applied perpendicular to the XZ plane. [Transform3D] with mirroring applied perpendicular to the XZ plane.
</constant> </constant>
<constant name="FLIP_Z" value="Transform( 1, 0, 0, 0, 1, 0, 0, 0, -1, 0, 0, 0 )"> <constant name="FLIP_Z" value="Transform3D( 1, 0, 0, 0, 1, 0, 0, 0, -1, 0, 0, 0 )">
[Transform] with mirroring applied perpendicular to the XY plane. [Transform3D] with mirroring applied perpendicular to the XY plane.
</constant> </constant>
</constants> </constants>
</class> </class>

View File

@ -294,7 +294,7 @@
<method name="operator *" qualifiers="operator"> <method name="operator *" qualifiers="operator">
<return type="Vector3"> <return type="Vector3">
</return> </return>
<argument index="0" name="right" type="Transform"> <argument index="0" name="right" type="Transform3D">
</argument> </argument>
<description> <description>
</description> </description>

View File

@ -44,7 +44,7 @@
</return> </return>
<description> <description>
Returns the transformed [AABB] (also known as the bounding box) for this [VisualInstance3D]. Returns the transformed [AABB] (also known as the bounding box) for this [VisualInstance3D].
Transformed in this case means the [AABB] plus the position, rotation, and scale of the [Node3D]'s [Transform]. See also [method get_aabb]. Transformed in this case means the [AABB] plus the position, rotation, and scale of the [Node3D]'s [Transform3D]. See also [method get_aabb].
</description> </description>
</method> </method>
<method name="set_base"> <method name="set_base">

View File

@ -1,7 +1,7 @@
<?xml version="1.0" encoding="UTF-8" ?> <?xml version="1.0" encoding="UTF-8" ?>
<class name="VisualShaderNodeDeterminant" inherits="VisualShaderNode" version="4.0"> <class name="VisualShaderNodeDeterminant" inherits="VisualShaderNode" version="4.0">
<brief_description> <brief_description>
Calculates the determinant of a [Transform] within the visual shader graph. Calculates the determinant of a [Transform3D] within the visual shader graph.
</brief_description> </brief_description>
<description> <description>
Translates to [code]determinant(x)[/code] in the shader language. Translates to [code]determinant(x)[/code] in the shader language.

View File

@ -1,7 +1,7 @@
<?xml version="1.0" encoding="UTF-8" ?> <?xml version="1.0" encoding="UTF-8" ?>
<class name="VisualShaderNodeTransformCompose" inherits="VisualShaderNode" version="4.0"> <class name="VisualShaderNodeTransformCompose" inherits="VisualShaderNode" version="4.0">
<brief_description> <brief_description>
Composes a [Transform] from four [Vector3]s within the visual shader graph. Composes a [Transform3D] from four [Vector3]s within the visual shader graph.
</brief_description> </brief_description>
<description> <description>
Creates a 4x4 transform matrix using four vectors of type [code]vec3[/code]. Each vector is one row in the matrix and the last column is a [code]vec4(0, 0, 0, 1)[/code]. Creates a 4x4 transform matrix using four vectors of type [code]vec3[/code]. Each vector is one row in the matrix and the last column is a [code]vec4(0, 0, 0, 1)[/code].

View File

@ -1,18 +1,18 @@
<?xml version="1.0" encoding="UTF-8" ?> <?xml version="1.0" encoding="UTF-8" ?>
<class name="VisualShaderNodeTransformConstant" inherits="VisualShaderNodeConstant" version="4.0"> <class name="VisualShaderNodeTransformConstant" inherits="VisualShaderNodeConstant" version="4.0">
<brief_description> <brief_description>
A [Transform] constant for use within the visual shader graph. A [Transform3D] constant for use within the visual shader graph.
</brief_description> </brief_description>
<description> <description>
A constant [Transform], which can be used as an input node. A constant [Transform3D], which can be used as an input node.
</description> </description>
<tutorials> <tutorials>
</tutorials> </tutorials>
<methods> <methods>
</methods> </methods>
<members> <members>
<member name="constant" type="Transform" setter="set_constant" getter="get_constant" default="Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )"> <member name="constant" type="Transform3D" setter="set_constant" getter="get_constant" default="Transform3D( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )">
A [Transform] constant which represents the state of this node. A [Transform3D] constant which represents the state of this node.
</member> </member>
</members> </members>
<constants> <constants>

View File

@ -1,7 +1,7 @@
<?xml version="1.0" encoding="UTF-8" ?> <?xml version="1.0" encoding="UTF-8" ?>
<class name="VisualShaderNodeTransformDecompose" inherits="VisualShaderNode" version="4.0"> <class name="VisualShaderNodeTransformDecompose" inherits="VisualShaderNode" version="4.0">
<brief_description> <brief_description>
Decomposes a [Transform] into four [Vector3]s within the visual shader graph. Decomposes a [Transform3D] into four [Vector3]s within the visual shader graph.
</brief_description> </brief_description>
<description> <description>
Takes a 4x4 transform matrix and decomposes it into four [code]vec3[/code] values, one from each row of the matrix. Takes a 4x4 transform matrix and decomposes it into four [code]vec3[/code] values, one from each row of the matrix.

View File

@ -1,10 +1,10 @@
<?xml version="1.0" encoding="UTF-8" ?> <?xml version="1.0" encoding="UTF-8" ?>
<class name="VisualShaderNodeTransformFunc" inherits="VisualShaderNode" version="4.0"> <class name="VisualShaderNodeTransformFunc" inherits="VisualShaderNode" version="4.0">
<brief_description> <brief_description>
Computes a [Transform] function within the visual shader graph. Computes a [Transform3D] function within the visual shader graph.
</brief_description> </brief_description>
<description> <description>
Computes an inverse or transpose function on the provided [Transform]. Computes an inverse or transpose function on the provided [Transform3D].
</description> </description>
<tutorials> <tutorials>
</tutorials> </tutorials>
@ -17,10 +17,10 @@
</members> </members>
<constants> <constants>
<constant name="FUNC_INVERSE" value="0" enum="Function"> <constant name="FUNC_INVERSE" value="0" enum="Function">
Perform the inverse operation on the [Transform] matrix. Perform the inverse operation on the [Transform3D] matrix.
</constant> </constant>
<constant name="FUNC_TRANSPOSE" value="1" enum="Function"> <constant name="FUNC_TRANSPOSE" value="1" enum="Function">
Perform the transpose operation on the [Transform] matrix. Perform the transpose operation on the [Transform3D] matrix.
</constant> </constant>
</constants> </constants>
</class> </class>

View File

@ -1,7 +1,7 @@
<?xml version="1.0" encoding="UTF-8" ?> <?xml version="1.0" encoding="UTF-8" ?>
<class name="VisualShaderNodeTransformMult" inherits="VisualShaderNode" version="4.0"> <class name="VisualShaderNodeTransformMult" inherits="VisualShaderNode" version="4.0">
<brief_description> <brief_description>
Multiplies [Transform] by [Transform] within the visual shader graph. Multiplies [Transform3D] by [Transform3D] within the visual shader graph.
</brief_description> </brief_description>
<description> <description>
A multiplication operation on two transforms (4x4 matrices), with support for different multiplication operators. A multiplication operation on two transforms (4x4 matrices), with support for different multiplication operators.

View File

@ -1,7 +1,7 @@
<?xml version="1.0" encoding="UTF-8" ?> <?xml version="1.0" encoding="UTF-8" ?>
<class name="VisualShaderNodeTransformUniform" inherits="VisualShaderNodeUniform" version="4.0"> <class name="VisualShaderNodeTransformUniform" inherits="VisualShaderNodeUniform" version="4.0">
<brief_description> <brief_description>
A [Transform] uniform for use within the visual shader graph. A [Transform3D] uniform for use within the visual shader graph.
</brief_description> </brief_description>
<description> <description>
Translated to [code]uniform mat4[/code] in the shader language. Translated to [code]uniform mat4[/code] in the shader language.
@ -11,7 +11,7 @@
<methods> <methods>
</methods> </methods>
<members> <members>
<member name="default_value" type="Transform" setter="set_default_value" getter="get_default_value" default="Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )"> <member name="default_value" type="Transform3D" setter="set_default_value" getter="get_default_value" default="Transform3D( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0 )">
A default value to be assigned within the shader. A default value to be assigned within the shader.
</member> </member>
<member name="default_value_enabled" type="bool" setter="set_default_value_enabled" getter="is_default_value_enabled" default="false"> <member name="default_value_enabled" type="bool" setter="set_default_value_enabled" getter="is_default_value_enabled" default="false">

View File

@ -1,7 +1,7 @@
<?xml version="1.0" encoding="UTF-8" ?> <?xml version="1.0" encoding="UTF-8" ?>
<class name="VisualShaderNodeTransformVecMult" inherits="VisualShaderNode" version="4.0"> <class name="VisualShaderNodeTransformVecMult" inherits="VisualShaderNode" version="4.0">
<brief_description> <brief_description>
Multiplies a [Transform] and a [Vector3] within the visual shader graph. Multiplies a [Transform3D] and a [Vector3] within the visual shader graph.
</brief_description> </brief_description>
<description> <description>
A multiplication operation on a transform (4x4 matrix) and a vector, with support for different multiplication operators. A multiplication operation on a transform (4x4 matrix) and a vector, with support for different multiplication operators.

View File

@ -69,7 +69,7 @@
</description> </description>
</method> </method>
<method name="get_transform" qualifiers="const"> <method name="get_transform" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<argument index="0" name="adjust_by_reference_frame" type="bool"> <argument index="0" name="adjust_by_reference_frame" type="bool">
</argument> </argument>

View File

@ -63,7 +63,7 @@
</description> </description>
</method> </method>
<method name="get_hmd_transform"> <method name="get_hmd_transform">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<description> <description>
Returns the primary interface's transformation. Returns the primary interface's transformation.
@ -114,7 +114,7 @@
</description> </description>
</method> </method>
<method name="get_reference_frame" qualifiers="const"> <method name="get_reference_frame" qualifiers="const">
<return type="Transform"> <return type="Transform3D">
</return> </return>
<description> <description>
Returns the reference frame transform. Mostly used internally and exposed for GDNative build interfaces. Returns the reference frame transform. Mostly used internally and exposed for GDNative build interfaces.

View File

@ -3459,7 +3459,7 @@ void AnimationTrackEditor::_insert_delay(bool p_create_reset, bool p_create_bezi
insert_queue = false; insert_queue = false;
} }
void AnimationTrackEditor::insert_transform_key(Node3D *p_node, const String &p_sub, const Transform &p_xform) { void AnimationTrackEditor::insert_transform_key(Node3D *p_node, const String &p_sub, const Transform3D &p_xform) {
if (!keying) { if (!keying) {
return; return;
} }
@ -3915,7 +3915,7 @@ AnimationTrackEditor::TrackIndices AnimationTrackEditor::_confirm_insert(InsertD
h.type == Variant::COLOR || h.type == Variant::COLOR ||
h.type == Variant::PLANE || h.type == Variant::PLANE ||
h.type == Variant::TRANSFORM2D || h.type == Variant::TRANSFORM2D ||
h.type == Variant::TRANSFORM) { h.type == Variant::TRANSFORM3D) {
update_mode = Animation::UPDATE_CONTINUOUS; update_mode = Animation::UPDATE_CONTINUOUS;
} }
@ -3946,7 +3946,7 @@ AnimationTrackEditor::TrackIndices AnimationTrackEditor::_confirm_insert(InsertD
} break; } break;
case Animation::TYPE_TRANSFORM: { case Animation::TYPE_TRANSFORM: {
Transform tr = p_id.value; Transform3D tr = p_id.value;
Dictionary d; Dictionary d;
d["location"] = tr.origin; d["location"] = tr.origin;
d["scale"] = tr.basis.get_scale(); d["scale"] = tr.basis.get_scale();
@ -4468,7 +4468,7 @@ void AnimationTrackEditor::_new_track_property_selected(String p_name) {
h.type == Variant::COLOR || h.type == Variant::COLOR ||
h.type == Variant::PLANE || h.type == Variant::PLANE ||
h.type == Variant::TRANSFORM2D || h.type == Variant::TRANSFORM2D ||
h.type == Variant::TRANSFORM) { h.type == Variant::TRANSFORM3D) {
update_mode = Animation::UPDATE_CONTINUOUS; update_mode = Animation::UPDATE_CONTINUOUS;
} }
@ -4560,7 +4560,7 @@ void AnimationTrackEditor::_insert_key_from_track(float p_ofs, int p_track) {
return; return;
} }
Transform xf = base->get_transform(); Transform3D xf = base->get_transform();
Vector3 loc = xf.get_origin(); Vector3 loc = xf.get_origin();
Vector3 scale = xf.basis.get_scale_local(); Vector3 scale = xf.basis.get_scale_local();

View File

@ -526,7 +526,7 @@ public:
void set_anim_pos(float p_pos); void set_anim_pos(float p_pos);
void insert_node_value_key(Node *p_node, const String &p_property, const Variant &p_value, bool p_only_if_exists = false); void insert_node_value_key(Node *p_node, const String &p_property, const Variant &p_value, bool p_only_if_exists = false);
void insert_value_key(const String &p_property, const Variant &p_value, bool p_advance); void insert_value_key(const String &p_property, const Variant &p_value, bool p_advance);
void insert_transform_key(Node3D *p_node, const String &p_sub, const Transform &p_xform); void insert_transform_key(Node3D *p_node, const String &p_sub, const Transform3D &p_xform);
void show_select_node_warning(bool p_show); void show_select_node_warning(bool p_show);

View File

@ -212,8 +212,8 @@ void ConnectDialog::_add_bind() {
case Variant::BASIS: case Variant::BASIS:
value = Basis(); value = Basis();
break; break;
case Variant::TRANSFORM: case Variant::TRANSFORM3D:
value = Transform(); value = Transform3D();
break; break;
case Variant::COLOR: case Variant::COLOR:
value = Color(); value = Color();
@ -446,7 +446,7 @@ ConnectDialog::ConnectDialog() {
type_list->add_item("Quat", Variant::QUAT); type_list->add_item("Quat", Variant::QUAT);
type_list->add_item("AABB", Variant::AABB); type_list->add_item("AABB", Variant::AABB);
type_list->add_item("Basis", Variant::BASIS); type_list->add_item("Basis", Variant::BASIS);
type_list->add_item("Transform", Variant::TRANSFORM); type_list->add_item("Transform", Variant::TRANSFORM3D);
type_list->add_item("Color", Variant::COLOR); type_list->add_item("Color", Variant::COLOR);
type_list->select(0); type_list->select(0);

View File

@ -60,7 +60,7 @@ Array EditorInterface::_make_mesh_previews(const Array &p_meshes, int p_preview_
return ret; return ret;
} }
Vector<Ref<Texture2D>> EditorInterface::make_mesh_previews(const Vector<Ref<Mesh>> &p_meshes, Vector<Transform> *p_transforms, int p_preview_size) { Vector<Ref<Texture2D>> EditorInterface::make_mesh_previews(const Vector<Ref<Mesh>> &p_meshes, Vector<Transform3D> *p_transforms, int p_preview_size) {
int size = p_preview_size; int size = p_preview_size;
RID scenario = RS::get_singleton()->scenario_create(); RID scenario = RS::get_singleton()->scenario_create();
@ -94,7 +94,7 @@ Vector<Ref<Texture2D>> EditorInterface::make_mesh_previews(const Vector<Ref<Mesh
continue; continue;
} }
Transform mesh_xform; Transform3D mesh_xform;
if (p_transforms != nullptr) { if (p_transforms != nullptr) {
mesh_xform = (*p_transforms)[i]; mesh_xform = (*p_transforms)[i];
} }
@ -105,7 +105,7 @@ Vector<Ref<Texture2D>> EditorInterface::make_mesh_previews(const Vector<Ref<Mesh
AABB aabb = mesh->get_aabb(); AABB aabb = mesh->get_aabb();
Vector3 ofs = aabb.position + aabb.size * 0.5; Vector3 ofs = aabb.position + aabb.size * 0.5;
aabb.position -= ofs; aabb.position -= ofs;
Transform xform; Transform3D xform;
xform.basis = Basis().rotated(Vector3(0, 1, 0), -Math_PI / 6); xform.basis = Basis().rotated(Vector3(0, 1, 0), -Math_PI / 6);
xform.basis = Basis().rotated(Vector3(1, 0, 0), Math_PI / 6) * xform.basis; xform.basis = Basis().rotated(Vector3(1, 0, 0), Math_PI / 6) * xform.basis;
AABB rot_aabb = xform.xform(aabb); AABB rot_aabb = xform.xform(aabb);
@ -119,11 +119,11 @@ Vector<Ref<Texture2D>> EditorInterface::make_mesh_previews(const Vector<Ref<Mesh
xform.invert(); xform.invert();
xform = mesh_xform * xform; xform = mesh_xform * xform;
RS::get_singleton()->camera_set_transform(camera, xform * Transform(Basis(), Vector3(0, 0, 3))); RS::get_singleton()->camera_set_transform(camera, xform * Transform3D(Basis(), Vector3(0, 0, 3)));
RS::get_singleton()->camera_set_orthogonal(camera, m * 2, 0.01, 1000.0); RS::get_singleton()->camera_set_orthogonal(camera, m * 2, 0.01, 1000.0);
RS::get_singleton()->instance_set_transform(light_instance, xform * Transform().looking_at(Vector3(-2, -1, -1), Vector3(0, 1, 0))); RS::get_singleton()->instance_set_transform(light_instance, xform * Transform3D().looking_at(Vector3(-2, -1, -1), Vector3(0, 1, 0)));
RS::get_singleton()->instance_set_transform(light_instance2, xform * Transform().looking_at(Vector3(+1, -1, -2), Vector3(0, 1, 0))); RS::get_singleton()->instance_set_transform(light_instance2, xform * Transform3D().looking_at(Vector3(+1, -1, -2), Vector3(0, 1, 0)));
ep.step(TTR("Thumbnail..."), i); ep.step(TTR("Thumbnail..."), i);
Main::iteration(); Main::iteration();

View File

@ -113,7 +113,7 @@ public:
Error save_scene(); Error save_scene();
void save_scene_as(const String &p_scene, bool p_with_preview = true); void save_scene_as(const String &p_scene, bool p_with_preview = true);
Vector<Ref<Texture2D>> make_mesh_previews(const Vector<Ref<Mesh>> &p_meshes, Vector<Transform> *p_transforms, int p_preview_size); Vector<Ref<Texture2D>> make_mesh_previews(const Vector<Ref<Mesh>> &p_meshes, Vector<Transform3D> *p_transforms, int p_preview_size);
void set_main_screen_editor(const String &p_name); void set_main_screen_editor(const String &p_name);
void set_distraction_free_mode(bool p_enter); void set_distraction_free_mode(bool p_enter);

View File

@ -2083,7 +2083,7 @@ void EditorPropertyTransform::_value_changed(double val, const String &p_name) {
return; return;
} }
Transform p; Transform3D p;
p.basis[0][0] = spin[0]->get_value(); p.basis[0][0] = spin[0]->get_value();
p.basis[1][0] = spin[1]->get_value(); p.basis[1][0] = spin[1]->get_value();
p.basis[2][0] = spin[2]->get_value(); p.basis[2][0] = spin[2]->get_value();
@ -2104,7 +2104,7 @@ void EditorPropertyTransform::update_property() {
update_using_transform(get_edited_object()->get(get_edited_property())); update_using_transform(get_edited_object()->get(get_edited_property()));
} }
void EditorPropertyTransform::update_using_transform(Transform p_transform) { void EditorPropertyTransform::update_using_transform(Transform3D p_transform) {
setting = true; setting = true;
spin[0]->set_value(p_transform.basis[0][0]); spin[0]->set_value(p_transform.basis[0][0]);
spin[1]->set_value(p_transform.basis[1][0]); spin[1]->set_value(p_transform.basis[1][0]);
@ -3107,7 +3107,7 @@ bool EditorInspectorDefaultPlugin::parse_property(Object *p_object, Variant::Typ
editor->setup(min, max, step, hide_slider); editor->setup(min, max, step, hide_slider);
add_property_editor(p_path, editor); add_property_editor(p_path, editor);
} break; } break;
case Variant::TRANSFORM: { case Variant::TRANSFORM3D: {
EditorPropertyTransform *editor = memnew(EditorPropertyTransform); EditorPropertyTransform *editor = memnew(EditorPropertyTransform);
double min = -65535, max = 65535, step = default_float_step; double min = -65535, max = 65535, step = default_float_step;
bool hide_slider = true; bool hide_slider = true;

View File

@ -541,7 +541,7 @@ protected:
public: public:
virtual void update_property() override; virtual void update_property() override;
virtual void update_using_transform(Transform p_transform); virtual void update_using_transform(Transform3D p_transform);
void setup(double p_min, double p_max, double p_step, bool p_no_slider); void setup(double p_min, double p_max, double p_step, bool p_no_slider);
EditorPropertyTransform(); EditorPropertyTransform();
}; };

View File

@ -868,7 +868,7 @@ void EditorPropertyDictionary::update_property() {
prop = editor; prop = editor;
} break; } break;
case Variant::TRANSFORM: { case Variant::TRANSFORM3D: {
EditorPropertyTransform *editor = memnew(EditorPropertyTransform); EditorPropertyTransform *editor = memnew(EditorPropertyTransform);
editor->setup(-100000, 100000, 0.001, true); editor->setup(-100000, 100000, 0.001, true);
prop = editor; prop = editor;

View File

@ -50,8 +50,8 @@ String Collada::Effect::get_texture_path(const String &p_source, Collada &state)
return state.state.image_map[image].path; return state.state.image_map[image].path;
} }
Transform Collada::get_root_transform() const { Transform3D Collada::get_root_transform() const {
Transform unit_scale_transform; Transform3D unit_scale_transform;
#ifndef COLLADA_IMPORT_SCALE_SCENE #ifndef COLLADA_IMPORT_SCALE_SCENE
unit_scale_transform.scale(Vector3(state.unit_scale, state.unit_scale, state.unit_scale)); unit_scale_transform.scale(Vector3(state.unit_scale, state.unit_scale, state.unit_scale));
#endif #endif
@ -74,8 +74,8 @@ static String _uri_to_id(const String &p_uri) {
/** HELPER FUNCTIONS **/ /** HELPER FUNCTIONS **/
Transform Collada::fix_transform(const Transform &p_transform) { Transform3D Collada::fix_transform(const Transform3D &p_transform) {
Transform tr = p_transform; Transform3D tr = p_transform;
#ifndef NO_UP_AXIS_SWAP #ifndef NO_UP_AXIS_SWAP
@ -102,8 +102,8 @@ Transform Collada::fix_transform(const Transform &p_transform) {
//return state.matrix_fix * p_transform; //return state.matrix_fix * p_transform;
} }
static Transform _read_transform_from_array(const Vector<float> &array, int ofs = 0) { static Transform3D _read_transform_from_array(const Vector<float> &array, int ofs = 0) {
Transform tr; Transform3D tr;
// i wonder why collada matrices are transposed, given that's opposed to opengl.. // i wonder why collada matrices are transposed, given that's opposed to opengl..
tr.basis.elements[0][0] = array[0 + ofs]; tr.basis.elements[0][0] = array[0 + ofs];
tr.basis.elements[0][1] = array[1 + ofs]; tr.basis.elements[0][1] = array[1 + ofs];
@ -122,11 +122,11 @@ static Transform _read_transform_from_array(const Vector<float> &array, int ofs
/* STRUCTURES */ /* STRUCTURES */
Transform Collada::Node::compute_transform(Collada &state) const { Transform3D Collada::Node::compute_transform(Collada &state) const {
Transform xform; Transform3D xform;
for (int i = 0; i < xform_list.size(); i++) { for (int i = 0; i < xform_list.size(); i++) {
Transform xform_step; Transform3D xform_step;
const XForm &xf = xform_list[i]; const XForm &xf = xform_list[i];
switch (xf.op) { switch (xf.op) {
case XForm::OP_ROTATE: { case XForm::OP_ROTATE: {
@ -165,11 +165,11 @@ Transform Collada::Node::compute_transform(Collada &state) const {
return xform; return xform;
} }
Transform Collada::Node::get_transform() const { Transform3D Collada::Node::get_transform() const {
return default_transform; return default_transform;
} }
Transform Collada::Node::get_global_transform() const { Transform3D Collada::Node::get_global_transform() const {
if (parent) { if (parent) {
return parent->get_global_transform() * default_transform; return parent->get_global_transform() * default_transform;
} else { } else {
@ -201,14 +201,14 @@ Vector<float> Collada::AnimationTrack::get_value_at_time(float p_time) const {
if (keys[i].data.size() == 16) { if (keys[i].data.size() == 16) {
//interpolate a matrix //interpolate a matrix
Transform src = _read_transform_from_array(keys[i - 1].data); Transform3D src = _read_transform_from_array(keys[i - 1].data);
Transform dst = _read_transform_from_array(keys[i].data); Transform3D dst = _read_transform_from_array(keys[i].data);
Transform interp = c < 0.001 ? src : src.interpolate_with(dst, c); Transform3D interp = c < 0.001 ? src : src.interpolate_with(dst, c);
Vector<float> ret; Vector<float> ret;
ret.resize(16); ret.resize(16);
Transform tr; Transform3D tr;
// i wonder why collada matrices are transposed, given that's opposed to opengl.. // i wonder why collada matrices are transposed, given that's opposed to opengl..
ret.write[0] = interp.basis.elements[0][0]; ret.write[0] = interp.basis.elements[0][0];
ret.write[1] = interp.basis.elements[0][1]; ret.write[1] = interp.basis.elements[0][1];
@ -410,10 +410,9 @@ Vector<String> Collada::_read_string_array(XMLParser &parser) {
return array; return array;
} }
Transform Collada::_read_transform(XMLParser &parser) { Transform3D Collada::_read_transform(XMLParser &parser) {
if (parser.is_empty()) { if (parser.is_empty())
return Transform(); return Transform3D();
}
Vector<String> array; Vector<String> array;
while (parser.read() == OK) { while (parser.read() == OK) {
@ -429,7 +428,7 @@ Transform Collada::_read_transform(XMLParser &parser) {
} }
} }
ERR_FAIL_COND_V(array.size() != 16, Transform()); ERR_FAIL_COND_V(array.size() != 16, Transform3D());
Vector<float> farr; Vector<float> farr;
farr.resize(16); farr.resize(16);
for (int i = 0; i < 16; i++) { for (int i = 0; i < 16; i++) {
@ -1197,7 +1196,7 @@ void Collada::_parse_skin_controller(XMLParser &parser, String p_id) {
/* STORE REST MATRICES */ /* STORE REST MATRICES */
Vector<Transform> rests; Vector<Transform3D> rests;
ERR_FAIL_COND(!skindata.joints.sources.has("JOINT")); ERR_FAIL_COND(!skindata.joints.sources.has("JOINT"));
ERR_FAIL_COND(!skindata.joints.sources.has("INV_BIND_MATRIX")); ERR_FAIL_COND(!skindata.joints.sources.has("INV_BIND_MATRIX"));
@ -1214,7 +1213,7 @@ void Collada::_parse_skin_controller(XMLParser &parser, String p_id) {
for (int i = 0; i < joint_source.sarray.size(); i++) { for (int i = 0; i < joint_source.sarray.size(); i++) {
String name = joint_source.sarray[i]; String name = joint_source.sarray[i];
Transform xform = _read_transform_from_array(ibm_source.array, i * 16); //<- this is a mistake, it must be applied to vertices Transform3D xform = _read_transform_from_array(ibm_source.array, i * 16); //<- this is a mistake, it must be applied to vertices
xform.affine_invert(); // inverse for rest, because it's an inverse xform.affine_invert(); // inverse for rest, because it's an inverse
#ifdef COLLADA_IMPORT_SCALE_SCENE #ifdef COLLADA_IMPORT_SCALE_SCENE
xform.origin *= state.unit_scale; xform.origin *= state.unit_scale;
@ -2096,7 +2095,7 @@ void Collada::_merge_skeletons2(VisualScene *p_vscene) {
NodeSkeleton *skeleton = nullptr; NodeSkeleton *skeleton = nullptr;
for (Map<String, Transform>::Element *F = cd.bone_rest_map.front(); F; F = F->next()) { for (Map<String, Transform3D>::Element *F = cd.bone_rest_map.front(); F; F = F->next()) {
String name; String name;
if (!state.sid_to_node_map.has(F->key())) { if (!state.sid_to_node_map.has(F->key())) {
@ -2240,11 +2239,11 @@ bool Collada::_move_geometry_to_skeletons(VisualScene *p_vscene, Node *p_node, L
//this should be correct //this should be correct
ERR_FAIL_COND_V(!state.skin_controller_data_map.has(ng->source), false); ERR_FAIL_COND_V(!state.skin_controller_data_map.has(ng->source), false);
SkinControllerData &skin = state.skin_controller_data_map[ng->source]; SkinControllerData &skin = state.skin_controller_data_map[ng->source];
Transform skel_inv = sk->get_global_transform().affine_inverse(); Transform3D skel_inv = sk->get_global_transform().affine_inverse();
p_node->default_transform = skel_inv * (skin.bind_shape /* p_node->get_global_transform()*/); // i honestly have no idea what to do with a previous model xform.. most exporters ignore it p_node->default_transform = skel_inv * (skin.bind_shape /* p_node->get_global_transform()*/); // i honestly have no idea what to do with a previous model xform.. most exporters ignore it
//make rests relative to the skeleton (they seem to be always relative to world) //make rests relative to the skeleton (they seem to be always relative to world)
for (Map<String, Transform>::Element *E = skin.bone_rest_map.front(); E; E = E->next()) { for (Map<String, Transform3D>::Element *E = skin.bone_rest_map.front(); E; E = E->next()) {
E->get() = skel_inv * E->get(); //make the bone rest local to the skeleton E->get() = skel_inv * E->get(); //make the bone rest local to the skeleton
state.bone_rest_map[E->key()] = E->get(); // make it remember where the bone is globally, now that it's relative state.bone_rest_map[E->key()] = E->get(); // make it remember where the bone is globally, now that it's relative
} }
@ -2252,7 +2251,7 @@ bool Collada::_move_geometry_to_skeletons(VisualScene *p_vscene, Node *p_node, L
//but most exporters seem to work only if i do this.. //but most exporters seem to work only if i do this..
//p_node->default_transform = p_node->get_global_transform(); //p_node->default_transform = p_node->get_global_transform();
//p_node->default_transform=Transform(); //this seems to be correct, because bind shape makes the object local to the skeleton //p_node->default_transform=Transform3D(); //this seems to be correct, because bind shape makes the object local to the skeleton
p_node->ignore_anim = true; // collada may animate this later, if it does, then this is not supported (redo your original asset and don't animate the base mesh) p_node->ignore_anim = true; // collada may animate this later, if it does, then this is not supported (redo your original asset and don't animate the base mesh)
p_node->parent = sk; p_node->parent = sk;
//sk->children.push_back(0,p_node); //avoid INFINITE loop //sk->children.push_back(0,p_node); //avoid INFINITE loop

View File

@ -182,7 +182,7 @@ public:
String base; String base;
bool use_idrefs = false; bool use_idrefs = false;
Transform bind_shape; Transform3D bind_shape;
struct Source { struct Source {
Vector<String> sarray; //maybe for names Vector<String> sarray; //maybe for names
@ -210,7 +210,7 @@ public:
int count = 0; int count = 0;
} weights; } weights;
Map<String, Transform> bone_rest_map; Map<String, Transform3D> bone_rest_map;
SkinControllerData() {} SkinControllerData() {}
}; };
@ -342,15 +342,15 @@ public:
String empty_draw_type; String empty_draw_type;
bool noname = false; bool noname = false;
Vector<XForm> xform_list; Vector<XForm> xform_list;
Transform default_transform; Transform3D default_transform;
Transform post_transform; Transform3D post_transform;
Vector<Node *> children; Vector<Node *> children;
Node *parent = nullptr; Node *parent = nullptr;
Transform compute_transform(Collada &state) const; Transform3D compute_transform(Collada &state) const;
Transform get_global_transform() const; Transform3D get_global_transform() const;
Transform get_transform() const; Transform3D get_transform() const;
bool ignore_anim = false; bool ignore_anim = false;
@ -497,7 +497,7 @@ public:
Map<String, String> sid_to_node_map; Map<String, String> sid_to_node_map;
//Map<String,NodeJoint*> bone_map; //Map<String,NodeJoint*> bone_map;
Map<String, Transform> bone_rest_map; Map<String, Transform3D> bone_rest_map;
String local_path; String local_path;
String root_visual_scene; String root_visual_scene;
@ -517,9 +517,9 @@ public:
Collada(); Collada();
Transform fix_transform(const Transform &p_transform); Transform3D fix_transform(const Transform3D &p_transform);
Transform get_root_transform() const; Transform3D get_root_transform() const;
int get_uv_channel(String p_name); int get_uv_channel(String p_name);
@ -557,7 +557,7 @@ private: // private stuff
Variant _parse_param(XMLParser &parser); Variant _parse_param(XMLParser &parser);
Vector<float> _read_float_array(XMLParser &parser); Vector<float> _read_float_array(XMLParser &parser);
Vector<String> _read_string_array(XMLParser &parser); Vector<String> _read_string_array(XMLParser &parser);
Transform _read_transform(XMLParser &parser); Transform3D _read_transform(XMLParser &parser);
String _read_empty_draw_type(XMLParser &parser); String _read_empty_draw_type(XMLParser &parser);
void _joint_set_owner(Collada::Node *p_node, NodeSkeleton *p_owner); void _joint_set_owner(Collada::Node *p_node, NodeSkeleton *p_owner);

View File

@ -87,7 +87,7 @@ struct ColladaImport {
Error _create_scene(Collada::Node *p_node, Node3D *p_parent); Error _create_scene(Collada::Node *p_node, Node3D *p_parent);
Error _create_resources(Collada::Node *p_node, bool p_use_compression); Error _create_resources(Collada::Node *p_node, bool p_use_compression);
Error _create_material(const String &p_target); Error _create_material(const String &p_target);
Error _create_mesh_surfaces(bool p_optimize, Ref<EditorSceneImporterMesh> &p_mesh, const Map<String, Collada::NodeGeometry::Material> &p_material_map, const Collada::MeshData &meshdata, const Transform &p_local_xform, const Vector<int> &bone_remap, const Collada::SkinControllerData *p_skin_controller, const Collada::MorphControllerData *p_morph_data, Vector<Ref<EditorSceneImporterMesh>> p_morph_meshes = Vector<Ref<EditorSceneImporterMesh>>(), bool p_use_compression = false, bool p_use_mesh_material = false); Error _create_mesh_surfaces(bool p_optimize, Ref<EditorSceneImporterMesh> &p_mesh, const Map<String, Collada::NodeGeometry::Material> &p_material_map, const Collada::MeshData &meshdata, const Transform3D &p_local_xform, const Vector<int> &bone_remap, const Collada::SkinControllerData *p_skin_controller, const Collada::MorphControllerData *p_morph_data, Vector<Ref<EditorSceneImporterMesh>> p_morph_meshes = Vector<Ref<EditorSceneImporterMesh>>(), bool p_use_compression = false, bool p_use_mesh_material = false);
Error load(const String &p_path, int p_flags, bool p_force_make_tangents = false, bool p_use_compression = false); Error load(const String &p_path, int p_flags, bool p_force_make_tangents = false, bool p_use_compression = false);
void _fix_param_animation_tracks(); void _fix_param_animation_tracks();
void create_animation(int p_clip, bool p_make_tracks_in_all_bones, bool p_import_value_tracks); void create_animation(int p_clip, bool p_make_tracks_in_all_bones, bool p_import_value_tracks);
@ -300,7 +300,7 @@ Error ColladaImport::_create_scene(Collada::Node *p_node, Node3D *p_parent) {
nm.node = node; nm.node = node;
node_map[p_node->id] = nm; node_map[p_node->id] = nm;
node_name_map[node->get_name()] = p_node->id; node_name_map[node->get_name()] = p_node->id;
Transform xf = p_node->default_transform; Transform3D xf = p_node->default_transform;
xf = collada.fix_transform(xf) * p_node->post_transform; xf = collada.fix_transform(xf) * p_node->post_transform;
node->set_transform(xf); node->set_transform(xf);
@ -457,7 +457,7 @@ Error ColladaImport::_create_material(const String &p_target) {
return OK; return OK;
} }
Error ColladaImport::_create_mesh_surfaces(bool p_optimize, Ref<EditorSceneImporterMesh> &p_mesh, const Map<String, Collada::NodeGeometry::Material> &p_material_map, const Collada::MeshData &meshdata, const Transform &p_local_xform, const Vector<int> &bone_remap, const Collada::SkinControllerData *p_skin_controller, const Collada::MorphControllerData *p_morph_data, Vector<Ref<EditorSceneImporterMesh>> p_morph_meshes, bool p_use_compression, bool p_use_mesh_material) { Error ColladaImport::_create_mesh_surfaces(bool p_optimize, Ref<EditorSceneImporterMesh> &p_mesh, const Map<String, Collada::NodeGeometry::Material> &p_material_map, const Collada::MeshData &meshdata, const Transform3D &p_local_xform, const Vector<int> &bone_remap, const Collada::SkinControllerData *p_skin_controller, const Collada::MorphControllerData *p_morph_data, Vector<Ref<EditorSceneImporterMesh>> p_morph_meshes, bool p_use_compression, bool p_use_mesh_material) {
bool local_xform_mirror = p_local_xform.basis.determinant() < 0; bool local_xform_mirror = p_local_xform.basis.determinant() < 0;
if (p_morph_data) { if (p_morph_data) {
@ -811,7 +811,7 @@ Error ColladaImport::_create_mesh_surfaces(bool p_optimize, Ref<EditorSceneImpor
if (has_weights) { if (has_weights) {
//if skeleton, localize //if skeleton, localize
Transform local_xform = p_local_xform; Transform3D local_xform = p_local_xform;
for (int i = 0; i < vertex_array.size(); i++) { for (int i = 0; i < vertex_array.size(); i++) {
vertex_array.write[i].vertex = local_xform.xform(vertex_array[i].vertex); vertex_array.write[i].vertex = local_xform.xform(vertex_array[i].vertex);
vertex_array.write[i].normal = local_xform.basis.xform(vertex_array[i].normal).normalized(); vertex_array.write[i].normal = local_xform.basis.xform(vertex_array[i].normal).normalized();
@ -1037,7 +1037,7 @@ Error ColladaImport::_create_resources(Collada::Node *p_node, bool p_use_compres
Collada::SkinControllerData *skin = nullptr; Collada::SkinControllerData *skin = nullptr;
Collada::MorphControllerData *morph = nullptr; Collada::MorphControllerData *morph = nullptr;
String meshid; String meshid;
Transform apply_xform; Transform3D apply_xform;
Vector<int> bone_remap; Vector<int> bone_remap;
Vector<Ref<EditorSceneImporterMesh>> morphs; Vector<Ref<EditorSceneImporterMesh>> morphs;
@ -1073,9 +1073,9 @@ Error ColladaImport::_create_resources(Collada::Node *p_node, bool p_use_compres
if (apply_mesh_xform_to_vertices) { if (apply_mesh_xform_to_vertices) {
apply_xform = collada.fix_transform(p_node->default_transform); apply_xform = collada.fix_transform(p_node->default_transform);
node->set_transform(Transform()); node->set_transform(Transform3D());
} else { } else {
apply_xform = Transform(); apply_xform = Transform3D();
} }
ERR_FAIL_COND_V(!skin->weights.sources.has("JOINT"), ERR_INVALID_DATA); ERR_FAIL_COND_V(!skin->weights.sources.has("JOINT"), ERR_INVALID_DATA);
@ -1530,7 +1530,7 @@ void ColladaImport::create_animation(int p_clip, bool p_make_tracks_in_all_bones
} }
} }
Transform xform = cn->compute_transform(collada); Transform3D xform = cn->compute_transform(collada);
xform = collada.fix_transform(xform) * cn->post_transform; xform = collada.fix_transform(xform) * cn->post_transform;
if (nm.bone >= 0) { if (nm.bone >= 0) {
@ -1589,7 +1589,7 @@ void ColladaImport::create_animation(int p_clip, bool p_make_tracks_in_all_bones
animation->track_set_path(track, path); animation->track_set_path(track, path);
animation->track_set_imported(track, true); //helps merging later animation->track_set_imported(track, true); //helps merging later
Transform xform = cn->compute_transform(collada); Transform3D xform = cn->compute_transform(collada);
xform = collada.fix_transform(xform) * cn->post_transform; xform = collada.fix_transform(xform) * cn->post_transform;
xform = sk->get_bone_rest(nm.bone).affine_inverse() * xform; xform = sk->get_bone_rest(nm.bone).affine_inverse() * xform;

View File

@ -433,7 +433,7 @@ Node *ResourceImporterScene::_pre_fix_node(Node *p_node, Node *p_root, Map<Ref<E
p_node->replace_by(rigid_body); p_node->replace_by(rigid_body);
rigid_body->set_transform(mi->get_transform()); rigid_body->set_transform(mi->get_transform());
p_node = rigid_body; p_node = rigid_body;
mi->set_transform(Transform()); mi->set_transform(Transform3D());
rigid_body->add_child(mi); rigid_body->add_child(mi);
mi->set_owner(rigid_body->get_owner()); mi->set_owner(rigid_body->get_owner());
@ -632,7 +632,7 @@ Node *ResourceImporterScene::_post_fix_node(Node *p_node, Node *p_root, Map<Ref<
p_node->replace_by(rigid_body); p_node->replace_by(rigid_body);
rigid_body->set_transform(mi->get_transform()); rigid_body->set_transform(mi->get_transform());
p_node = rigid_body; p_node = rigid_body;
mi->set_transform(Transform()); mi->set_transform(Transform3D());
rigid_body->add_child(mi); rigid_body->add_child(mi);
mi->set_owner(rigid_body->get_owner()); mi->set_owner(rigid_body->get_owner());
base = rigid_body; base = rigid_body;
@ -1209,7 +1209,7 @@ void ResourceImporterScene::_generate_meshes(Node *p_node, const Dictionary &p_m
} }
if (bake_lightmaps) { if (bake_lightmaps) {
Transform xf; Transform3D xf;
Node3D *n = src_mesh_node; Node3D *n = src_mesh_node;
while (n) { while (n) {
xf = n->get_transform() * xf; xf = n->get_transform() * xf;

View File

@ -317,7 +317,7 @@ void SceneImportSettings::_fill_scene(Node *p_node, TreeItem *p_parent_item) {
if (mesh_node && mesh_node->get_mesh().is_valid()) { if (mesh_node && mesh_node->get_mesh().is_valid()) {
_fill_mesh(scene_tree, mesh_node->get_mesh(), item); _fill_mesh(scene_tree, mesh_node->get_mesh(), item);
Transform accum_xform; Transform3D accum_xform;
Node3D *base = mesh_node; Node3D *base = mesh_node;
while (base) { while (base) {
accum_xform = base->get_transform() * accum_xform; accum_xform = base->get_transform() * accum_xform;
@ -379,7 +379,7 @@ void SceneImportSettings::_update_camera() {
camera->set_orthogonal(camera_size * zoom, 0.0001, camera_size * 2); camera->set_orthogonal(camera_size * zoom, 0.0001, camera_size * 2);
Transform xf; Transform3D xf;
xf.basis = Basis(Vector3(0, 1, 0), rot_y) * Basis(Vector3(1, 0, 0), rot_x); xf.basis = Basis(Vector3(0, 1, 0), rot_y) * Basis(Vector3(1, 0, 0), rot_x);
xf.origin = center; xf.origin = center;
xf.translate(0, 0, camera_size); xf.translate(0, 0, camera_size);
@ -493,7 +493,7 @@ void SceneImportSettings::_select(Tree *p_from, String p_type, String p_id) {
Ref<Mesh> base_mesh = mi->get_mesh(); Ref<Mesh> base_mesh = mi->get_mesh();
if (base_mesh.is_valid()) { if (base_mesh.is_valid()) {
AABB aabb = base_mesh->get_aabb(); AABB aabb = base_mesh->get_aabb();
Transform aabb_xf; Transform3D aabb_xf;
aabb_xf.basis.scale(aabb.size); aabb_xf.basis.scale(aabb.size);
aabb_xf.origin = aabb.position; aabb_xf.origin = aabb.position;
@ -1099,7 +1099,7 @@ SceneImportSettings::SceneImportSettings() {
camera->make_current(); camera->make_current();
light = memnew(DirectionalLight3D); light = memnew(DirectionalLight3D);
light->set_transform(Transform().looking_at(Vector3(-1, -2, -0.6), Vector3(0, 1, 0))); light->set_transform(Transform3D().looking_at(Vector3(-1, -2, -0.6), Vector3(0, 1, 0)));
base_viewport->add_child(light); base_viewport->add_child(light);
light->set_shadow(true); light->set_shadow(true);

View File

@ -612,7 +612,7 @@ struct EditorSceneImporterMeshLightmapSurface {
String name; String name;
}; };
Error EditorSceneImporterMesh::lightmap_unwrap_cached(const Transform &p_base_transform, float p_texel_size, const Vector<uint8_t> &p_src_cache, Vector<uint8_t> &r_dst_cache) { Error EditorSceneImporterMesh::lightmap_unwrap_cached(const Transform3D &p_base_transform, float p_texel_size, const Vector<uint8_t> &p_src_cache, Vector<uint8_t> &r_dst_cache) {
ERR_FAIL_COND_V(!array_mesh_lightmap_unwrap_callback, ERR_UNCONFIGURED); ERR_FAIL_COND_V(!array_mesh_lightmap_unwrap_callback, ERR_UNCONFIGURED);
ERR_FAIL_COND_V_MSG(blend_shapes.size() != 0, ERR_UNAVAILABLE, "Can't unwrap mesh with blend shapes."); ERR_FAIL_COND_V_MSG(blend_shapes.size() != 0, ERR_UNAVAILABLE, "Can't unwrap mesh with blend shapes.");
@ -628,7 +628,7 @@ Error EditorSceneImporterMesh::lightmap_unwrap_cached(const Transform &p_base_tr
Basis basis = p_base_transform.get_basis(); Basis basis = p_base_transform.get_basis();
Vector3 scale = Vector3(basis.get_axis(0).length(), basis.get_axis(1).length(), basis.get_axis(2).length()); Vector3 scale = Vector3(basis.get_axis(0).length(), basis.get_axis(1).length(), basis.get_axis(2).length());
Transform transform; Transform3D transform;
transform.scale(scale); transform.scale(scale);
Basis normal_basis = transform.basis.inverse().transposed(); Basis normal_basis = transform.basis.inverse().transposed();

View File

@ -106,7 +106,7 @@ public:
Vector<Ref<Shape3D>> convex_decompose() const; Vector<Ref<Shape3D>> convex_decompose() const;
Ref<Shape3D> create_trimesh_shape() const; Ref<Shape3D> create_trimesh_shape() const;
Ref<NavigationMesh> create_navigation_mesh(); Ref<NavigationMesh> create_navigation_mesh();
Error lightmap_unwrap_cached(const Transform &p_base_transform, float p_texel_size, const Vector<uint8_t> &p_src_cache, Vector<uint8_t> &r_dst_cache); Error lightmap_unwrap_cached(const Transform3D &p_base_transform, float p_texel_size, const Vector<uint8_t> &p_src_cache, Vector<uint8_t> &r_dst_cache);
void set_lightmap_size_hint(const Size2i &p_size); void set_lightmap_size_hint(const Size2i &p_size);
Size2i get_lightmap_size_hint() const; Size2i get_lightmap_size_hint() const;

View File

@ -313,7 +313,7 @@ void InspectorDock::_property_keyed(const String &p_keyed, const Variant &p_valu
AnimationPlayerEditor::singleton->get_track_editor()->insert_value_key(p_keyed, p_value, p_advance); AnimationPlayerEditor::singleton->get_track_editor()->insert_value_key(p_keyed, p_value, p_advance);
} }
void InspectorDock::_transform_keyed(Object *sp, const String &p_sub, const Transform &p_key) { void InspectorDock::_transform_keyed(Object *sp, const String &p_sub, const Transform3D &p_key) {
Node3D *s = Object::cast_to<Node3D>(sp); Node3D *s = Object::cast_to<Node3D>(sp);
if (!s) { if (!s) {
return; return;

View File

@ -112,7 +112,7 @@ class InspectorDock : public VBoxContainer {
void _prepare_history(); void _prepare_history();
void _property_keyed(const String &p_keyed, const Variant &p_value, bool p_advance); void _property_keyed(const String &p_keyed, const Variant &p_value, bool p_advance);
void _transform_keyed(Object *sp, const String &p_sub, const Transform &p_key); void _transform_keyed(Object *sp, const String &p_sub, const Transform3D &p_key);
protected: protected:
static void _bind_methods(); static void _bind_methods();

View File

@ -455,7 +455,7 @@ bool EditorNode3DGizmo::intersect_frustum(const Camera3D *p_camera, const Vector
int vc = collision_segments.size(); int vc = collision_segments.size();
const Vector3 *vptr = collision_segments.ptr(); const Vector3 *vptr = collision_segments.ptr();
Transform t = spatial_node->get_global_transform(); Transform3D t = spatial_node->get_global_transform();
bool any_out = false; bool any_out = false;
for (int j = 0; j < fc; j++) { for (int j = 0; j < fc; j++) {
@ -477,12 +477,12 @@ bool EditorNode3DGizmo::intersect_frustum(const Camera3D *p_camera, const Vector
} }
if (collision_mesh.is_valid()) { if (collision_mesh.is_valid()) {
Transform t = spatial_node->get_global_transform(); Transform3D t = spatial_node->get_global_transform();
Vector3 mesh_scale = t.get_basis().get_scale(); Vector3 mesh_scale = t.get_basis().get_scale();
t.orthonormalize(); t.orthonormalize();
Transform it = t.affine_inverse(); Transform3D it = t.affine_inverse();
Vector<Plane> transformed_frustum; Vector<Plane> transformed_frustum;
@ -508,7 +508,7 @@ bool EditorNode3DGizmo::intersect_ray(Camera3D *p_camera, const Point2 &p_point,
} }
if (r_gizmo_handle && !hidden) { if (r_gizmo_handle && !hidden) {
Transform t = spatial_node->get_global_transform(); Transform3D t = spatial_node->get_global_transform();
if (billboard_handle) { if (billboard_handle) {
t.set_look_at(t.origin, t.origin - p_camera->get_transform().basis.get_axis(2), p_camera->get_transform().basis.get_axis(1)); t.set_look_at(t.origin, t.origin - p_camera->get_transform().basis.get_axis(2), p_camera->get_transform().basis.get_axis(1));
} }
@ -560,7 +560,7 @@ bool EditorNode3DGizmo::intersect_ray(Camera3D *p_camera, const Point2 &p_point,
} }
if (selectable_icon_size > 0.0f) { if (selectable_icon_size > 0.0f) {
Transform t = spatial_node->get_global_transform(); Transform3D t = spatial_node->get_global_transform();
Vector3 camera_position = p_camera->get_camera_transform().origin; Vector3 camera_position = p_camera->get_camera_transform().origin;
if (camera_position.distance_squared_to(t.origin) > 0.01) { if (camera_position.distance_squared_to(t.origin) > 0.01) {
t.set_look_at(t.origin, camera_position); t.set_look_at(t.origin, camera_position);
@ -576,7 +576,7 @@ bool EditorNode3DGizmo::intersect_ray(Camera3D *p_camera, const Point2 &p_point,
Point2 center = p_camera->unproject_position(t.origin); Point2 center = p_camera->unproject_position(t.origin);
Transform orig_camera_transform = p_camera->get_camera_transform(); Transform3D orig_camera_transform = p_camera->get_camera_transform();
if (orig_camera_transform.origin.distance_squared_to(t.origin) > 0.01 && if (orig_camera_transform.origin.distance_squared_to(t.origin) > 0.01 &&
ABS(orig_camera_transform.basis.get_axis(Vector3::AXIS_Z).dot(Vector3(0, 1, 0))) < 0.99) { ABS(orig_camera_transform.basis.get_axis(Vector3::AXIS_Z).dot(Vector3(0, 1, 0))) < 0.99) {
@ -609,7 +609,7 @@ bool EditorNode3DGizmo::intersect_ray(Camera3D *p_camera, const Point2 &p_point,
int vc = collision_segments.size(); int vc = collision_segments.size();
const Vector3 *vptr = collision_segments.ptr(); const Vector3 *vptr = collision_segments.ptr();
Transform t = spatial_node->get_global_transform(); Transform3D t = spatial_node->get_global_transform();
if (billboard_handle) { if (billboard_handle) {
t.set_look_at(t.origin, t.origin - p_camera->get_transform().basis.get_axis(2), p_camera->get_transform().basis.get_axis(1)); t.set_look_at(t.origin, t.origin - p_camera->get_transform().basis.get_axis(2), p_camera->get_transform().basis.get_axis(1));
} }
@ -657,13 +657,13 @@ bool EditorNode3DGizmo::intersect_ray(Camera3D *p_camera, const Point2 &p_point,
} }
if (collision_mesh.is_valid()) { if (collision_mesh.is_valid()) {
Transform gt = spatial_node->get_global_transform(); Transform3D gt = spatial_node->get_global_transform();
if (billboard_handle) { if (billboard_handle) {
gt.set_look_at(gt.origin, gt.origin - p_camera->get_transform().basis.get_axis(2), p_camera->get_transform().basis.get_axis(1)); gt.set_look_at(gt.origin, gt.origin - p_camera->get_transform().basis.get_axis(2), p_camera->get_transform().basis.get_axis(1));
} }
Transform ai = gt.affine_inverse(); Transform3D ai = gt.affine_inverse();
Vector3 ray_from = ai.xform(p_camera->project_ray_origin(p_point)); Vector3 ray_from = ai.xform(p_camera->project_ray_origin(p_point));
Vector3 ray_dir = ai.basis.xform(p_camera->project_ray_normal(p_point)).normalized(); Vector3 ray_dir = ai.basis.xform(p_camera->project_ray_normal(p_point)).normalized();
Vector3 rpos, rnorm; Vector3 rpos, rnorm;
@ -826,7 +826,7 @@ Variant Light3DGizmoPlugin::get_handle_value(EditorNode3DGizmo *p_gizmo, int p_i
return Variant(); return Variant();
} }
static float _find_closest_angle_to_half_pi_arc(const Vector3 &p_from, const Vector3 &p_to, float p_arc_radius, const Transform &p_arc_xform) { static float _find_closest_angle_to_half_pi_arc(const Vector3 &p_from, const Vector3 &p_to, float p_arc_radius, const Transform3D &p_arc_xform) {
//bleh, discrete is simpler //bleh, discrete is simpler
static const int arc_test_points = 64; static const int arc_test_points = 64;
float min_d = 1e20; float min_d = 1e20;
@ -855,8 +855,8 @@ static float _find_closest_angle_to_half_pi_arc(const Vector3 &p_from, const Vec
void Light3DGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Camera3D *p_camera, const Point2 &p_point) { void Light3DGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Camera3D *p_camera, const Point2 &p_point) {
Light3D *light = Object::cast_to<Light3D>(p_gizmo->get_spatial_node()); Light3D *light = Object::cast_to<Light3D>(p_gizmo->get_spatial_node());
Transform gt = light->get_global_transform(); Transform3D gt = light->get_global_transform();
Transform gi = gt.affine_inverse(); Transform3D gi = gt.affine_inverse();
Vector3 ray_from = p_camera->project_ray_origin(p_point); Vector3 ray_from = p_camera->project_ray_origin(p_point);
Vector3 ray_dir = p_camera->project_ray_normal(p_point); Vector3 ray_dir = p_camera->project_ray_normal(p_point);
@ -1084,8 +1084,8 @@ Variant AudioStreamPlayer3DGizmoPlugin::get_handle_value(EditorNode3DGizmo *p_gi
void AudioStreamPlayer3DGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Camera3D *p_camera, const Point2 &p_point) { void AudioStreamPlayer3DGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Camera3D *p_camera, const Point2 &p_point) {
AudioStreamPlayer3D *player = Object::cast_to<AudioStreamPlayer3D>(p_gizmo->get_spatial_node()); AudioStreamPlayer3D *player = Object::cast_to<AudioStreamPlayer3D>(p_gizmo->get_spatial_node());
Transform gt = player->get_global_transform(); Transform3D gt = player->get_global_transform();
Transform gi = gt.affine_inverse(); Transform3D gi = gt.affine_inverse();
Vector3 ray_from = p_camera->project_ray_origin(p_point); Vector3 ray_from = p_camera->project_ray_origin(p_point);
Vector3 ray_dir = p_camera->project_ray_normal(p_point); Vector3 ray_dir = p_camera->project_ray_normal(p_point);
@ -1230,8 +1230,8 @@ Variant Camera3DGizmoPlugin::get_handle_value(EditorNode3DGizmo *p_gizmo, int p_
void Camera3DGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Camera3D *p_camera, const Point2 &p_point) { void Camera3DGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Camera3D *p_camera, const Point2 &p_point) {
Camera3D *camera = Object::cast_to<Camera3D>(p_gizmo->get_spatial_node()); Camera3D *camera = Object::cast_to<Camera3D>(p_gizmo->get_spatial_node());
Transform gt = camera->get_global_transform(); Transform3D gt = camera->get_global_transform();
Transform gi = gt.affine_inverse(); Transform3D gi = gt.affine_inverse();
Vector3 ray_from = p_camera->project_ray_origin(p_point); Vector3 ray_from = p_camera->project_ray_origin(p_point);
Vector3 ray_dir = p_camera->project_ray_normal(p_point); Vector3 ray_dir = p_camera->project_ray_normal(p_point);
@ -1239,7 +1239,7 @@ void Camera3DGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Came
Vector3 s[2] = { gi.xform(ray_from), gi.xform(ray_from + ray_dir * 4096) }; Vector3 s[2] = { gi.xform(ray_from), gi.xform(ray_from + ray_dir * 4096) };
if (camera->get_projection() == Camera3D::PROJECTION_PERSPECTIVE) { if (camera->get_projection() == Camera3D::PROJECTION_PERSPECTIVE) {
Transform gt2 = camera->get_global_transform(); Transform3D gt2 = camera->get_global_transform();
float a = _find_closest_angle_to_half_pi_arc(s[0], s[1], 1.0, gt2); float a = _find_closest_angle_to_half_pi_arc(s[0], s[1], 1.0, gt2);
camera->set("fov", CLAMP(a * 2.0, 1, 179)); camera->set("fov", CLAMP(a * 2.0, 1, 179));
} else { } else {
@ -1418,7 +1418,7 @@ void Camera3DGizmoPlugin::redraw(EditorNode3DGizmo *p_gizmo) {
lines.push_back(cam_pos); lines.push_back(cam_pos);
} }
Transform local = camera->get_global_transform().affine_inverse(); Transform3D local = camera->get_global_transform().affine_inverse();
for (int i = 0; i < lines.size(); i++) { for (int i = 0; i < lines.size(); i++) {
lines.write[i] = local.xform(lines[i]); lines.write[i] = local.xform(lines[i]);
} }
@ -1617,7 +1617,7 @@ void Skeleton3DGizmoPlugin::redraw(EditorNode3DGizmo *p_gizmo) {
surface_tool->begin(Mesh::PRIMITIVE_LINES); surface_tool->begin(Mesh::PRIMITIVE_LINES);
surface_tool->set_material(material); surface_tool->set_material(material);
Vector<Transform> grests; Vector<Transform3D> grests;
grests.resize(skel->get_bone_count()); grests.resize(skel->get_bone_count());
Vector<int> bones; Vector<int> bones;
@ -1749,7 +1749,7 @@ void Skeleton3DGizmoPlugin::redraw(EditorNode3DGizmo *p_gizmo) {
bones.write[0] = i; bones.write[0] = i;
} }
/* /*
Transform t = grests[i]; Transform3D t = grests[i];
t.orthonormalize(); t.orthonormalize();
for (int i=0;i<6;i++) { for (int i=0;i<6;i++) {
@ -2196,9 +2196,9 @@ Variant VisibilityNotifier3DGizmoPlugin::get_handle_value(EditorNode3DGizmo *p_g
void VisibilityNotifier3DGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Camera3D *p_camera, const Point2 &p_point) { void VisibilityNotifier3DGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Camera3D *p_camera, const Point2 &p_point) {
VisibilityNotifier3D *notifier = Object::cast_to<VisibilityNotifier3D>(p_gizmo->get_spatial_node()); VisibilityNotifier3D *notifier = Object::cast_to<VisibilityNotifier3D>(p_gizmo->get_spatial_node());
Transform gt = notifier->get_global_transform(); Transform3D gt = notifier->get_global_transform();
Transform gi = gt.affine_inverse(); Transform3D gi = gt.affine_inverse();
bool move = p_idx >= 3; bool move = p_idx >= 3;
p_idx = p_idx % 3; p_idx = p_idx % 3;
@ -2388,8 +2388,8 @@ Variant GPUParticles3DGizmoPlugin::get_handle_value(EditorNode3DGizmo *p_gizmo,
void GPUParticles3DGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Camera3D *p_camera, const Point2 &p_point) { void GPUParticles3DGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Camera3D *p_camera, const Point2 &p_point) {
GPUParticles3D *particles = Object::cast_to<GPUParticles3D>(p_gizmo->get_spatial_node()); GPUParticles3D *particles = Object::cast_to<GPUParticles3D>(p_gizmo->get_spatial_node());
Transform gt = particles->get_global_transform(); Transform3D gt = particles->get_global_transform();
Transform gi = gt.affine_inverse(); Transform3D gi = gt.affine_inverse();
bool move = p_idx >= 3; bool move = p_idx >= 3;
p_idx = p_idx % 3; p_idx = p_idx % 3;
@ -2555,8 +2555,8 @@ Variant GPUParticlesCollision3DGizmoPlugin::get_handle_value(EditorNode3DGizmo *
void GPUParticlesCollision3DGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Camera3D *p_camera, const Point2 &p_point) { void GPUParticlesCollision3DGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Camera3D *p_camera, const Point2 &p_point) {
Node3D *sn = p_gizmo->get_spatial_node(); Node3D *sn = p_gizmo->get_spatial_node();
Transform gt = sn->get_global_transform(); Transform3D gt = sn->get_global_transform();
Transform gi = gt.affine_inverse(); Transform3D gi = gt.affine_inverse();
Vector3 ray_from = p_camera->project_ray_origin(p_point); Vector3 ray_from = p_camera->project_ray_origin(p_point);
Vector3 ray_dir = p_camera->project_ray_normal(p_point); Vector3 ray_dir = p_camera->project_ray_normal(p_point);
@ -2814,9 +2814,9 @@ Variant ReflectionProbeGizmoPlugin::get_handle_value(EditorNode3DGizmo *p_gizmo,
void ReflectionProbeGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Camera3D *p_camera, const Point2 &p_point) { void ReflectionProbeGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Camera3D *p_camera, const Point2 &p_point) {
ReflectionProbe *probe = Object::cast_to<ReflectionProbe>(p_gizmo->get_spatial_node()); ReflectionProbe *probe = Object::cast_to<ReflectionProbe>(p_gizmo->get_spatial_node());
Transform gt = probe->get_global_transform(); Transform3D gt = probe->get_global_transform();
Transform gi = gt.affine_inverse(); Transform3D gi = gt.affine_inverse();
if (p_idx < 3) { if (p_idx < 3) {
Vector3 extents = probe->get_extents(); Vector3 extents = probe->get_extents();
@ -2993,9 +2993,9 @@ Variant DecalGizmoPlugin::get_handle_value(EditorNode3DGizmo *p_gizmo, int p_idx
void DecalGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Camera3D *p_camera, const Point2 &p_point) { void DecalGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Camera3D *p_camera, const Point2 &p_point) {
Decal *decal = Object::cast_to<Decal>(p_gizmo->get_spatial_node()); Decal *decal = Object::cast_to<Decal>(p_gizmo->get_spatial_node());
Transform gt = decal->get_global_transform(); Transform3D gt = decal->get_global_transform();
Transform gi = gt.affine_inverse(); Transform3D gi = gt.affine_inverse();
Vector3 extents = decal->get_extents(); Vector3 extents = decal->get_extents();
@ -3135,8 +3135,8 @@ Variant GIProbeGizmoPlugin::get_handle_value(EditorNode3DGizmo *p_gizmo, int p_i
void GIProbeGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Camera3D *p_camera, const Point2 &p_point) { void GIProbeGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Camera3D *p_camera, const Point2 &p_point) {
GIProbe *probe = Object::cast_to<GIProbe>(p_gizmo->get_spatial_node()); GIProbe *probe = Object::cast_to<GIProbe>(p_gizmo->get_spatial_node());
Transform gt = probe->get_global_transform(); Transform3D gt = probe->get_global_transform();
Transform gi = gt.affine_inverse(); Transform3D gi = gt.affine_inverse();
Vector3 extents = probe->get_extents(); Vector3 extents = probe->get_extents();
@ -3583,7 +3583,7 @@ void CollisionObject3DGizmoPlugin::redraw(EditorNode3DGizmo *p_gizmo) {
co->get_shape_owners(&owners); co->get_shape_owners(&owners);
for (List<uint32_t>::Element *E = owners.front(); E; E = E->next()) { for (List<uint32_t>::Element *E = owners.front(); E; E = E->next()) {
uint32_t owner_id = E->get(); uint32_t owner_id = E->get();
Transform xform = co->shape_owner_get_transform(owner_id); Transform3D xform = co->shape_owner_get_transform(owner_id);
Object *owner = co->shape_owner_get_owner(owner_id); Object *owner = co->shape_owner_get_owner(owner_id);
// Exclude CollisionShape3D and CollisionPolygon3D as they have their gizmo. // Exclude CollisionShape3D and CollisionPolygon3D as they have their gizmo.
if (!Object::cast_to<CollisionShape3D>(owner) && !Object::cast_to<CollisionPolygon3D>(owner)) { if (!Object::cast_to<CollisionShape3D>(owner) && !Object::cast_to<CollisionPolygon3D>(owner)) {
@ -3701,8 +3701,8 @@ void CollisionShape3DGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_i
return; return;
} }
Transform gt = cs->get_global_transform(); Transform3D gt = cs->get_global_transform();
Transform gi = gt.affine_inverse(); Transform3D gi = gt.affine_inverse();
Vector3 ray_from = p_camera->project_ray_origin(p_point); Vector3 ray_from = p_camera->project_ray_origin(p_point);
Vector3 ray_dir = p_camera->project_ray_normal(p_point); Vector3 ray_dir = p_camera->project_ray_normal(p_point);
@ -4369,7 +4369,7 @@ void NavigationRegion3DGizmoPlugin::redraw(EditorNode3DGizmo *p_gizmo) {
#define BODY_A_RADIUS 0.25 #define BODY_A_RADIUS 0.25
#define BODY_B_RADIUS 0.27 #define BODY_B_RADIUS 0.27
Basis JointGizmosDrawer::look_body(const Transform &p_joint_transform, const Transform &p_body_transform) { Basis JointGizmosDrawer::look_body(const Transform3D &p_joint_transform, const Transform3D &p_body_transform) {
const Vector3 &p_eye(p_joint_transform.origin); const Vector3 &p_eye(p_joint_transform.origin);
const Vector3 &p_target(p_body_transform.origin); const Vector3 &p_target(p_body_transform.origin);
@ -4394,7 +4394,7 @@ Basis JointGizmosDrawer::look_body(const Transform &p_joint_transform, const Tra
return base; return base;
} }
Basis JointGizmosDrawer::look_body_toward(Vector3::Axis p_axis, const Transform &joint_transform, const Transform &body_transform) { Basis JointGizmosDrawer::look_body_toward(Vector3::Axis p_axis, const Transform3D &joint_transform, const Transform3D &body_transform) {
switch (p_axis) { switch (p_axis) {
case Vector3::AXIS_X: case Vector3::AXIS_X:
return look_body_toward_x(joint_transform, body_transform); return look_body_toward_x(joint_transform, body_transform);
@ -4407,7 +4407,7 @@ Basis JointGizmosDrawer::look_body_toward(Vector3::Axis p_axis, const Transform
} }
} }
Basis JointGizmosDrawer::look_body_toward_x(const Transform &p_joint_transform, const Transform &p_body_transform) { Basis JointGizmosDrawer::look_body_toward_x(const Transform3D &p_joint_transform, const Transform3D &p_body_transform) {
const Vector3 &p_eye(p_joint_transform.origin); const Vector3 &p_eye(p_joint_transform.origin);
const Vector3 &p_target(p_body_transform.origin); const Vector3 &p_target(p_body_transform.origin);
@ -4438,7 +4438,7 @@ Basis JointGizmosDrawer::look_body_toward_x(const Transform &p_joint_transform,
return base; return base;
} }
Basis JointGizmosDrawer::look_body_toward_y(const Transform &p_joint_transform, const Transform &p_body_transform) { Basis JointGizmosDrawer::look_body_toward_y(const Transform3D &p_joint_transform, const Transform3D &p_body_transform) {
const Vector3 &p_eye(p_joint_transform.origin); const Vector3 &p_eye(p_joint_transform.origin);
const Vector3 &p_target(p_body_transform.origin); const Vector3 &p_target(p_body_transform.origin);
@ -4469,7 +4469,7 @@ Basis JointGizmosDrawer::look_body_toward_y(const Transform &p_joint_transform,
return base; return base;
} }
Basis JointGizmosDrawer::look_body_toward_z(const Transform &p_joint_transform, const Transform &p_body_transform) { Basis JointGizmosDrawer::look_body_toward_z(const Transform3D &p_joint_transform, const Transform3D &p_body_transform) {
const Vector3 &p_eye(p_joint_transform.origin); const Vector3 &p_eye(p_joint_transform.origin);
const Vector3 &p_target(p_body_transform.origin); const Vector3 &p_target(p_body_transform.origin);
@ -4500,7 +4500,7 @@ Basis JointGizmosDrawer::look_body_toward_z(const Transform &p_joint_transform,
return base; return base;
} }
void JointGizmosDrawer::draw_circle(Vector3::Axis p_axis, real_t p_radius, const Transform &p_offset, const Basis &p_base, real_t p_limit_lower, real_t p_limit_upper, Vector<Vector3> &r_points, bool p_inverse) { void JointGizmosDrawer::draw_circle(Vector3::Axis p_axis, real_t p_radius, const Transform3D &p_offset, const Basis &p_base, real_t p_limit_lower, real_t p_limit_upper, Vector<Vector3> &r_points, bool p_inverse) {
if (p_limit_lower == p_limit_upper) { if (p_limit_lower == p_limit_upper) {
r_points.push_back(p_offset.translated(Vector3()).origin); r_points.push_back(p_offset.translated(Vector3()).origin);
r_points.push_back(p_offset.translated(p_base.xform(Vector3(0.5, 0, 0))).origin); r_points.push_back(p_offset.translated(p_base.xform(Vector3(0.5, 0, 0))).origin);
@ -4562,7 +4562,7 @@ void JointGizmosDrawer::draw_circle(Vector3::Axis p_axis, real_t p_radius, const
} }
} }
void JointGizmosDrawer::draw_cone(const Transform &p_offset, const Basis &p_base, real_t p_swing, real_t p_twist, Vector<Vector3> &r_points) { void JointGizmosDrawer::draw_cone(const Transform3D &p_offset, const Basis &p_base, real_t p_swing, real_t p_twist, Vector<Vector3> &r_points) {
float r = 1.0; float r = 1.0;
float w = r * Math::sin(p_swing); float w = r * Math::sin(p_swing);
float d = r * Math::cos(p_swing); float d = r * Math::cos(p_swing);
@ -4666,7 +4666,7 @@ void Joint3DGizmoPlugin::redraw(EditorNode3DGizmo *p_gizmo) {
Vector<Vector3> body_b_points; Vector<Vector3> body_b_points;
if (Object::cast_to<PinJoint3D>(joint)) { if (Object::cast_to<PinJoint3D>(joint)) {
CreatePinJointGizmo(Transform(), points); CreatePinJointGizmo(Transform3D(), points);
p_gizmo->add_collision_segments(points); p_gizmo->add_collision_segments(points);
p_gizmo->add_lines(points, common_material); p_gizmo->add_lines(points, common_material);
} }
@ -4674,10 +4674,10 @@ void Joint3DGizmoPlugin::redraw(EditorNode3DGizmo *p_gizmo) {
HingeJoint3D *hinge = Object::cast_to<HingeJoint3D>(joint); HingeJoint3D *hinge = Object::cast_to<HingeJoint3D>(joint);
if (hinge) { if (hinge) {
CreateHingeJointGizmo( CreateHingeJointGizmo(
Transform(), Transform3D(),
hinge->get_global_transform(), hinge->get_global_transform(),
node_body_a ? node_body_a->get_global_transform() : Transform(), node_body_a ? node_body_a->get_global_transform() : Transform3D(),
node_body_b ? node_body_b->get_global_transform() : Transform(), node_body_b ? node_body_b->get_global_transform() : Transform3D(),
hinge->get_param(HingeJoint3D::PARAM_LIMIT_LOWER), hinge->get_param(HingeJoint3D::PARAM_LIMIT_LOWER),
hinge->get_param(HingeJoint3D::PARAM_LIMIT_UPPER), hinge->get_param(HingeJoint3D::PARAM_LIMIT_UPPER),
hinge->get_flag(HingeJoint3D::FLAG_USE_LIMIT), hinge->get_flag(HingeJoint3D::FLAG_USE_LIMIT),
@ -4697,10 +4697,10 @@ void Joint3DGizmoPlugin::redraw(EditorNode3DGizmo *p_gizmo) {
SliderJoint3D *slider = Object::cast_to<SliderJoint3D>(joint); SliderJoint3D *slider = Object::cast_to<SliderJoint3D>(joint);
if (slider) { if (slider) {
CreateSliderJointGizmo( CreateSliderJointGizmo(
Transform(), Transform3D(),
slider->get_global_transform(), slider->get_global_transform(),
node_body_a ? node_body_a->get_global_transform() : Transform(), node_body_a ? node_body_a->get_global_transform() : Transform3D(),
node_body_b ? node_body_b->get_global_transform() : Transform(), node_body_b ? node_body_b->get_global_transform() : Transform3D(),
slider->get_param(SliderJoint3D::PARAM_ANGULAR_LIMIT_LOWER), slider->get_param(SliderJoint3D::PARAM_ANGULAR_LIMIT_LOWER),
slider->get_param(SliderJoint3D::PARAM_ANGULAR_LIMIT_UPPER), slider->get_param(SliderJoint3D::PARAM_ANGULAR_LIMIT_UPPER),
slider->get_param(SliderJoint3D::PARAM_LINEAR_LIMIT_LOWER), slider->get_param(SliderJoint3D::PARAM_LINEAR_LIMIT_LOWER),
@ -4721,10 +4721,10 @@ void Joint3DGizmoPlugin::redraw(EditorNode3DGizmo *p_gizmo) {
ConeTwistJoint3D *cone = Object::cast_to<ConeTwistJoint3D>(joint); ConeTwistJoint3D *cone = Object::cast_to<ConeTwistJoint3D>(joint);
if (cone) { if (cone) {
CreateConeTwistJointGizmo( CreateConeTwistJointGizmo(
Transform(), Transform3D(),
cone->get_global_transform(), cone->get_global_transform(),
node_body_a ? node_body_a->get_global_transform() : Transform(), node_body_a ? node_body_a->get_global_transform() : Transform3D(),
node_body_b ? node_body_b->get_global_transform() : Transform(), node_body_b ? node_body_b->get_global_transform() : Transform3D(),
cone->get_param(ConeTwistJoint3D::PARAM_SWING_SPAN), cone->get_param(ConeTwistJoint3D::PARAM_SWING_SPAN),
cone->get_param(ConeTwistJoint3D::PARAM_TWIST_SPAN), cone->get_param(ConeTwistJoint3D::PARAM_TWIST_SPAN),
node_body_a ? &body_a_points : nullptr, node_body_a ? &body_a_points : nullptr,
@ -4740,10 +4740,10 @@ void Joint3DGizmoPlugin::redraw(EditorNode3DGizmo *p_gizmo) {
Generic6DOFJoint3D *gen = Object::cast_to<Generic6DOFJoint3D>(joint); Generic6DOFJoint3D *gen = Object::cast_to<Generic6DOFJoint3D>(joint);
if (gen) { if (gen) {
CreateGeneric6DOFJointGizmo( CreateGeneric6DOFJointGizmo(
Transform(), Transform3D(),
gen->get_global_transform(), gen->get_global_transform(),
node_body_a ? node_body_a->get_global_transform() : Transform(), node_body_a ? node_body_a->get_global_transform() : Transform3D(),
node_body_b ? node_body_b->get_global_transform() : Transform(), node_body_b ? node_body_b->get_global_transform() : Transform3D(),
gen->get_param_x(Generic6DOFJoint3D::PARAM_ANGULAR_LOWER_LIMIT), gen->get_param_x(Generic6DOFJoint3D::PARAM_ANGULAR_LOWER_LIMIT),
gen->get_param_x(Generic6DOFJoint3D::PARAM_ANGULAR_UPPER_LIMIT), gen->get_param_x(Generic6DOFJoint3D::PARAM_ANGULAR_UPPER_LIMIT),
@ -4780,7 +4780,7 @@ void Joint3DGizmoPlugin::redraw(EditorNode3DGizmo *p_gizmo) {
} }
} }
void Joint3DGizmoPlugin::CreatePinJointGizmo(const Transform &p_offset, Vector<Vector3> &r_cursor_points) { void Joint3DGizmoPlugin::CreatePinJointGizmo(const Transform3D &p_offset, Vector<Vector3> &r_cursor_points) {
float cs = 0.25; float cs = 0.25;
r_cursor_points.push_back(p_offset.translated(Vector3(+cs, 0, 0)).origin); r_cursor_points.push_back(p_offset.translated(Vector3(+cs, 0, 0)).origin);
@ -4791,7 +4791,7 @@ void Joint3DGizmoPlugin::CreatePinJointGizmo(const Transform &p_offset, Vector<V
r_cursor_points.push_back(p_offset.translated(Vector3(0, 0, -cs)).origin); r_cursor_points.push_back(p_offset.translated(Vector3(0, 0, -cs)).origin);
} }
void Joint3DGizmoPlugin::CreateHingeJointGizmo(const Transform &p_offset, const Transform &p_trs_joint, const Transform &p_trs_body_a, const Transform &p_trs_body_b, real_t p_limit_lower, real_t p_limit_upper, bool p_use_limit, Vector<Vector3> &r_common_points, Vector<Vector3> *r_body_a_points, Vector<Vector3> *r_body_b_points) { void Joint3DGizmoPlugin::CreateHingeJointGizmo(const Transform3D &p_offset, const Transform3D &p_trs_joint, const Transform3D &p_trs_body_a, const Transform3D &p_trs_body_b, real_t p_limit_lower, real_t p_limit_upper, bool p_use_limit, Vector<Vector3> &r_common_points, Vector<Vector3> *r_body_a_points, Vector<Vector3> *r_body_b_points) {
r_common_points.push_back(p_offset.translated(Vector3(0, 0, 0.5)).origin); r_common_points.push_back(p_offset.translated(Vector3(0, 0, 0.5)).origin);
r_common_points.push_back(p_offset.translated(Vector3(0, 0, -0.5)).origin); r_common_points.push_back(p_offset.translated(Vector3(0, 0, -0.5)).origin);
@ -4821,7 +4821,7 @@ void Joint3DGizmoPlugin::CreateHingeJointGizmo(const Transform &p_offset, const
} }
} }
void Joint3DGizmoPlugin::CreateSliderJointGizmo(const Transform &p_offset, const Transform &p_trs_joint, const Transform &p_trs_body_a, const Transform &p_trs_body_b, real_t p_angular_limit_lower, real_t p_angular_limit_upper, real_t p_linear_limit_lower, real_t p_linear_limit_upper, Vector<Vector3> &r_points, Vector<Vector3> *r_body_a_points, Vector<Vector3> *r_body_b_points) { void Joint3DGizmoPlugin::CreateSliderJointGizmo(const Transform3D &p_offset, const Transform3D &p_trs_joint, const Transform3D &p_trs_body_a, const Transform3D &p_trs_body_b, real_t p_angular_limit_lower, real_t p_angular_limit_upper, real_t p_linear_limit_lower, real_t p_linear_limit_upper, Vector<Vector3> &r_points, Vector<Vector3> *r_body_a_points, Vector<Vector3> *r_body_b_points) {
p_linear_limit_lower = -p_linear_limit_lower; p_linear_limit_lower = -p_linear_limit_lower;
p_linear_limit_upper = -p_linear_limit_upper; p_linear_limit_upper = -p_linear_limit_upper;
@ -4880,7 +4880,7 @@ void Joint3DGizmoPlugin::CreateSliderJointGizmo(const Transform &p_offset, const
} }
} }
void Joint3DGizmoPlugin::CreateConeTwistJointGizmo(const Transform &p_offset, const Transform &p_trs_joint, const Transform &p_trs_body_a, const Transform &p_trs_body_b, real_t p_swing, real_t p_twist, Vector<Vector3> *r_body_a_points, Vector<Vector3> *r_body_b_points) { void Joint3DGizmoPlugin::CreateConeTwistJointGizmo(const Transform3D &p_offset, const Transform3D &p_trs_joint, const Transform3D &p_trs_body_a, const Transform3D &p_trs_body_b, real_t p_swing, real_t p_twist, Vector<Vector3> *r_body_a_points, Vector<Vector3> *r_body_b_points) {
if (r_body_a_points) { if (r_body_a_points) {
JointGizmosDrawer::draw_cone( JointGizmosDrawer::draw_cone(
p_offset, p_offset,
@ -4901,10 +4901,10 @@ void Joint3DGizmoPlugin::CreateConeTwistJointGizmo(const Transform &p_offset, co
} }
void Joint3DGizmoPlugin::CreateGeneric6DOFJointGizmo( void Joint3DGizmoPlugin::CreateGeneric6DOFJointGizmo(
const Transform &p_offset, const Transform3D &p_offset,
const Transform &p_trs_joint, const Transform3D &p_trs_joint,
const Transform &p_trs_body_a, const Transform3D &p_trs_body_a,
const Transform &p_trs_body_b, const Transform3D &p_trs_body_b,
real_t p_angular_limit_lower_x, real_t p_angular_limit_lower_x,
real_t p_angular_limit_upper_x, real_t p_angular_limit_upper_x,
real_t p_linear_limit_lower_x, real_t p_linear_limit_lower_x,

View File

@ -428,17 +428,17 @@ public:
class JointGizmosDrawer { class JointGizmosDrawer {
public: public:
static Basis look_body(const Transform &p_joint_transform, const Transform &p_body_transform); static Basis look_body(const Transform3D &p_joint_transform, const Transform3D &p_body_transform);
static Basis look_body_toward(Vector3::Axis p_axis, const Transform &joint_transform, const Transform &body_transform); static Basis look_body_toward(Vector3::Axis p_axis, const Transform3D &joint_transform, const Transform3D &body_transform);
static Basis look_body_toward_x(const Transform &p_joint_transform, const Transform &p_body_transform); static Basis look_body_toward_x(const Transform3D &p_joint_transform, const Transform3D &p_body_transform);
static Basis look_body_toward_y(const Transform &p_joint_transform, const Transform &p_body_transform); static Basis look_body_toward_y(const Transform3D &p_joint_transform, const Transform3D &p_body_transform);
/// Special function just used for physics joints, it returns a basis constrained toward Joint Z axis /// Special function just used for physics joints, it returns a basis constrained toward Joint Z axis
/// with axis X and Y that are looking toward the body and oriented toward up /// with axis X and Y that are looking toward the body and oriented toward up
static Basis look_body_toward_z(const Transform &p_joint_transform, const Transform &p_body_transform); static Basis look_body_toward_z(const Transform3D &p_joint_transform, const Transform3D &p_body_transform);
// Draw circle around p_axis // Draw circle around p_axis
static void draw_circle(Vector3::Axis p_axis, real_t p_radius, const Transform &p_offset, const Basis &p_base, real_t p_limit_lower, real_t p_limit_upper, Vector<Vector3> &r_points, bool p_inverse = false); static void draw_circle(Vector3::Axis p_axis, real_t p_radius, const Transform3D &p_offset, const Basis &p_base, real_t p_limit_lower, real_t p_limit_upper, Vector<Vector3> &r_points, bool p_inverse = false);
static void draw_cone(const Transform &p_offset, const Basis &p_base, real_t p_swing, real_t p_twist, Vector<Vector3> &r_points); static void draw_cone(const Transform3D &p_offset, const Basis &p_base, real_t p_swing, real_t p_twist, Vector<Vector3> &r_points);
}; };
class Joint3DGizmoPlugin : public EditorNode3DGizmoPlugin { class Joint3DGizmoPlugin : public EditorNode3DGizmoPlugin {
@ -455,15 +455,15 @@ public:
int get_priority() const override; int get_priority() const override;
void redraw(EditorNode3DGizmo *p_gizmo) override; void redraw(EditorNode3DGizmo *p_gizmo) override;
static void CreatePinJointGizmo(const Transform &p_offset, Vector<Vector3> &r_cursor_points); static void CreatePinJointGizmo(const Transform3D &p_offset, Vector<Vector3> &r_cursor_points);
static void CreateHingeJointGizmo(const Transform &p_offset, const Transform &p_trs_joint, const Transform &p_trs_body_a, const Transform &p_trs_body_b, real_t p_limit_lower, real_t p_limit_upper, bool p_use_limit, Vector<Vector3> &r_common_points, Vector<Vector3> *r_body_a_points, Vector<Vector3> *r_body_b_points); static void CreateHingeJointGizmo(const Transform3D &p_offset, const Transform3D &p_trs_joint, const Transform3D &p_trs_body_a, const Transform3D &p_trs_body_b, real_t p_limit_lower, real_t p_limit_upper, bool p_use_limit, Vector<Vector3> &r_common_points, Vector<Vector3> *r_body_a_points, Vector<Vector3> *r_body_b_points);
static void CreateSliderJointGizmo(const Transform &p_offset, const Transform &p_trs_joint, const Transform &p_trs_body_a, const Transform &p_trs_body_b, real_t p_angular_limit_lower, real_t p_angular_limit_upper, real_t p_linear_limit_lower, real_t p_linear_limit_upper, Vector<Vector3> &r_points, Vector<Vector3> *r_body_a_points, Vector<Vector3> *r_body_b_points); static void CreateSliderJointGizmo(const Transform3D &p_offset, const Transform3D &p_trs_joint, const Transform3D &p_trs_body_a, const Transform3D &p_trs_body_b, real_t p_angular_limit_lower, real_t p_angular_limit_upper, real_t p_linear_limit_lower, real_t p_linear_limit_upper, Vector<Vector3> &r_points, Vector<Vector3> *r_body_a_points, Vector<Vector3> *r_body_b_points);
static void CreateConeTwistJointGizmo(const Transform &p_offset, const Transform &p_trs_joint, const Transform &p_trs_body_a, const Transform &p_trs_body_b, real_t p_swing, real_t p_twist, Vector<Vector3> *r_body_a_points, Vector<Vector3> *r_body_b_points); static void CreateConeTwistJointGizmo(const Transform3D &p_offset, const Transform3D &p_trs_joint, const Transform3D &p_trs_body_a, const Transform3D &p_trs_body_b, real_t p_swing, real_t p_twist, Vector<Vector3> *r_body_a_points, Vector<Vector3> *r_body_b_points);
static void CreateGeneric6DOFJointGizmo( static void CreateGeneric6DOFJointGizmo(
const Transform &p_offset, const Transform3D &p_offset,
const Transform &p_trs_joint, const Transform3D &p_trs_joint,
const Transform &p_trs_body_a, const Transform3D &p_trs_body_a,
const Transform &p_trs_body_b, const Transform3D &p_trs_body_b,
real_t p_angular_limit_lower_x, real_t p_angular_limit_lower_x,
real_t p_angular_limit_upper_x, real_t p_angular_limit_upper_x,
real_t p_linear_limit_lower_x, real_t p_linear_limit_lower_x,

View File

@ -108,8 +108,8 @@ bool CollisionPolygon3DEditor::forward_spatial_gui_input(Camera3D *p_camera, con
return false; return false;
} }
Transform gt = node->get_global_transform(); Transform3D gt = node->get_global_transform();
Transform gi = gt.affine_inverse(); Transform3D gi = gt.affine_inverse();
float depth = _get_depth() * 0.5; float depth = _get_depth() * 0.5;
Vector3 n = gt.basis.get_axis(2).normalized(); Vector3 n = gt.basis.get_axis(2).normalized();
Plane p(gt.origin + n * depth, n); Plane p(gt.origin + n * depth, n);
@ -516,7 +516,7 @@ CollisionPolygon3DEditor::CollisionPolygon3DEditor(EditorNode *p_editor) {
mode = MODE_EDIT; mode = MODE_EDIT;
wip_active = false; wip_active = false;
imgeom = memnew(ImmediateGeometry3D); imgeom = memnew(ImmediateGeometry3D);
imgeom->set_transform(Transform(Basis(), Vector3(0, 0, 0.00001))); imgeom->set_transform(Transform3D(Basis(), Vector3(0, 0, 0.00001)));
line_material = Ref<StandardMaterial3D>(memnew(StandardMaterial3D)); line_material = Ref<StandardMaterial3D>(memnew(StandardMaterial3D));
line_material->set_shading_mode(StandardMaterial3D::SHADING_MODE_UNSHADED); line_material->set_shading_mode(StandardMaterial3D::SHADING_MODE_UNSHADED);
@ -539,7 +539,7 @@ CollisionPolygon3DEditor::CollisionPolygon3DEditor(EditorNode *p_editor) {
imgeom->add_child(pointsm); imgeom->add_child(pointsm);
m.instance(); m.instance();
pointsm->set_mesh(m); pointsm->set_mesh(m);
pointsm->set_transform(Transform(Basis(), Vector3(0, 0, 0.00001))); pointsm->set_transform(Transform3D(Basis(), Vector3(0, 0, 0.00001)));
snap_ignore = false; snap_ignore = false;
} }

View File

@ -359,12 +359,12 @@ EditorMaterialPreviewPlugin::EditorMaterialPreviewPlugin() {
camera = RS::get_singleton()->camera_create(); camera = RS::get_singleton()->camera_create();
RS::get_singleton()->viewport_attach_camera(viewport, camera); RS::get_singleton()->viewport_attach_camera(viewport, camera);
RS::get_singleton()->camera_set_transform(camera, Transform(Basis(), Vector3(0, 0, 3))); RS::get_singleton()->camera_set_transform(camera, Transform3D(Basis(), Vector3(0, 0, 3)));
RS::get_singleton()->camera_set_perspective(camera, 45, 0.1, 10); RS::get_singleton()->camera_set_perspective(camera, 45, 0.1, 10);
light = RS::get_singleton()->directional_light_create(); light = RS::get_singleton()->directional_light_create();
light_instance = RS::get_singleton()->instance_create2(light, scenario); light_instance = RS::get_singleton()->instance_create2(light, scenario);
RS::get_singleton()->instance_set_transform(light_instance, Transform().looking_at(Vector3(-1, -1, -1), Vector3(0, 1, 0))); RS::get_singleton()->instance_set_transform(light_instance, Transform3D().looking_at(Vector3(-1, -1, -1), Vector3(0, 1, 0)));
light2 = RS::get_singleton()->directional_light_create(); light2 = RS::get_singleton()->directional_light_create();
RS::get_singleton()->light_set_color(light2, Color(0.7, 0.7, 0.7)); RS::get_singleton()->light_set_color(light2, Color(0.7, 0.7, 0.7));
@ -372,7 +372,7 @@ EditorMaterialPreviewPlugin::EditorMaterialPreviewPlugin() {
light_instance2 = RS::get_singleton()->instance_create2(light2, scenario); light_instance2 = RS::get_singleton()->instance_create2(light2, scenario);
RS::get_singleton()->instance_set_transform(light_instance2, Transform().looking_at(Vector3(0, 1, 0), Vector3(0, 0, 1))); RS::get_singleton()->instance_set_transform(light_instance2, Transform3D().looking_at(Vector3(0, 1, 0), Vector3(0, 0, 1)));
sphere = RS::get_singleton()->mesh_create(); sphere = RS::get_singleton()->mesh_create();
sphere_instance = RS::get_singleton()->instance_create2(sphere, scenario); sphere_instance = RS::get_singleton()->instance_create2(sphere, scenario);
@ -720,7 +720,7 @@ Ref<Texture2D> EditorMeshPreviewPlugin::generate(const RES &p_from, const Size2
AABB aabb = mesh->get_aabb(); AABB aabb = mesh->get_aabb();
Vector3 ofs = aabb.position + aabb.size * 0.5; Vector3 ofs = aabb.position + aabb.size * 0.5;
aabb.position -= ofs; aabb.position -= ofs;
Transform xform; Transform3D xform;
xform.basis = Basis().rotated(Vector3(0, 1, 0), -Math_PI * 0.125); xform.basis = Basis().rotated(Vector3(0, 1, 0), -Math_PI * 0.125);
xform.basis = Basis().rotated(Vector3(1, 0, 0), Math_PI * 0.125) * xform.basis; xform.basis = Basis().rotated(Vector3(1, 0, 0), Math_PI * 0.125) * xform.basis;
AABB rot_aabb = xform.xform(aabb); AABB rot_aabb = xform.xform(aabb);
@ -780,20 +780,20 @@ EditorMeshPreviewPlugin::EditorMeshPreviewPlugin() {
camera = RS::get_singleton()->camera_create(); camera = RS::get_singleton()->camera_create();
RS::get_singleton()->viewport_attach_camera(viewport, camera); RS::get_singleton()->viewport_attach_camera(viewport, camera);
RS::get_singleton()->camera_set_transform(camera, Transform(Basis(), Vector3(0, 0, 3))); RS::get_singleton()->camera_set_transform(camera, Transform3D(Basis(), Vector3(0, 0, 3)));
//RS::get_singleton()->camera_set_perspective(camera,45,0.1,10); //RS::get_singleton()->camera_set_perspective(camera,45,0.1,10);
RS::get_singleton()->camera_set_orthogonal(camera, 1.0, 0.01, 1000.0); RS::get_singleton()->camera_set_orthogonal(camera, 1.0, 0.01, 1000.0);
light = RS::get_singleton()->directional_light_create(); light = RS::get_singleton()->directional_light_create();
light_instance = RS::get_singleton()->instance_create2(light, scenario); light_instance = RS::get_singleton()->instance_create2(light, scenario);
RS::get_singleton()->instance_set_transform(light_instance, Transform().looking_at(Vector3(-1, -1, -1), Vector3(0, 1, 0))); RS::get_singleton()->instance_set_transform(light_instance, Transform3D().looking_at(Vector3(-1, -1, -1), Vector3(0, 1, 0)));
light2 = RS::get_singleton()->directional_light_create(); light2 = RS::get_singleton()->directional_light_create();
RS::get_singleton()->light_set_color(light2, Color(0.7, 0.7, 0.7)); RS::get_singleton()->light_set_color(light2, Color(0.7, 0.7, 0.7));
//RS::get_singleton()->light_set_color(light2, RS::LIGHT_COLOR_SPECULAR, Color(0.0, 0.0, 0.0)); //RS::get_singleton()->light_set_color(light2, RS::LIGHT_COLOR_SPECULAR, Color(0.0, 0.0, 0.0));
light_instance2 = RS::get_singleton()->instance_create2(light2, scenario); light_instance2 = RS::get_singleton()->instance_create2(light2, scenario);
RS::get_singleton()->instance_set_transform(light_instance2, Transform().looking_at(Vector3(0, 1, 0), Vector3(0, 0, 1))); RS::get_singleton()->instance_set_transform(light_instance2, Transform3D().looking_at(Vector3(0, 1, 0), Vector3(0, 0, 1)));
//sphere = RS::get_singleton()->mesh_create(); //sphere = RS::get_singleton()->mesh_create();
mesh_instance = RS::get_singleton()->instance_create(); mesh_instance = RS::get_singleton()->instance_create();

View File

@ -177,7 +177,7 @@ void GPUParticles3DEditorBase::_node_selected(const NodePath &p_path) {
return; return;
} }
Transform geom_xform = base_node->get_global_transform().affine_inverse() * vi->get_global_transform(); Transform3D geom_xform = base_node->get_global_transform().affine_inverse() * vi->get_global_transform();
int gc = geometry.size(); int gc = geometry.size();
Face3 *w = geometry.ptrw(); Face3 *w = geometry.ptrw();

View File

@ -119,17 +119,17 @@ MaterialEditor::MaterialEditor() {
viewport->set_msaa(Viewport::MSAA_4X); viewport->set_msaa(Viewport::MSAA_4X);
camera = memnew(Camera3D); camera = memnew(Camera3D);
camera->set_transform(Transform(Basis(), Vector3(0, 0, 3))); camera->set_transform(Transform3D(Basis(), Vector3(0, 0, 3)));
camera->set_perspective(45, 0.1, 10); camera->set_perspective(45, 0.1, 10);
camera->make_current(); camera->make_current();
viewport->add_child(camera); viewport->add_child(camera);
light1 = memnew(DirectionalLight3D); light1 = memnew(DirectionalLight3D);
light1->set_transform(Transform().looking_at(Vector3(-1, -1, -1), Vector3(0, 1, 0))); light1->set_transform(Transform3D().looking_at(Vector3(-1, -1, -1), Vector3(0, 1, 0)));
viewport->add_child(light1); viewport->add_child(light1);
light2 = memnew(DirectionalLight3D); light2 = memnew(DirectionalLight3D);
light2->set_transform(Transform().looking_at(Vector3(0, 1, 0), Vector3(0, 0, 1))); light2->set_transform(Transform3D().looking_at(Vector3(0, 1, 0), Vector3(0, 0, 1)));
light2->set_color(Color(0.7, 0.7, 0.7)); light2->set_color(Color(0.7, 0.7, 0.7));
viewport->add_child(light2); viewport->add_child(light2);
@ -139,7 +139,7 @@ MaterialEditor::MaterialEditor() {
box_instance = memnew(MeshInstance3D); box_instance = memnew(MeshInstance3D);
viewport->add_child(box_instance); viewport->add_child(box_instance);
Transform box_xform; Transform3D box_xform;
box_xform.basis.rotate(Vector3(1, 0, 0), Math::deg2rad(25.0)); box_xform.basis.rotate(Vector3(1, 0, 0), Math::deg2rad(25.0));
box_xform.basis = box_xform.basis * Basis().rotated(Vector3(0, 1, 0), Math::deg2rad(-25.0)); box_xform.basis = box_xform.basis * Basis().rotated(Vector3(0, 1, 0), Math::deg2rad(-25.0));
box_xform.basis.scale(Vector3(0.8, 0.8, 0.8)); box_xform.basis.scale(Vector3(0.8, 0.8, 0.8));

View File

@ -65,7 +65,7 @@ void MeshEditor::_notification(int p_what) {
} }
void MeshEditor::_update_rotation() { void MeshEditor::_update_rotation() {
Transform t; Transform3D t;
t.basis.rotate(Vector3(0, 1, 0), -rot_y); t.basis.rotate(Vector3(0, 1, 0), -rot_y);
t.basis.rotate(Vector3(1, 0, 0), -rot_x); t.basis.rotate(Vector3(1, 0, 0), -rot_x);
rotation->set_transform(t); rotation->set_transform(t);
@ -85,7 +85,7 @@ void MeshEditor::edit(Ref<Mesh> p_mesh) {
if (m != 0) { if (m != 0) {
m = 1.0 / m; m = 1.0 / m;
m *= 0.5; m *= 0.5;
Transform xform; Transform3D xform;
xform.basis.scale(Vector3(m, m, m)); xform.basis.scale(Vector3(m, m, m));
xform.origin = -xform.basis.xform(ofs); //-ofs*m; xform.origin = -xform.basis.xform(ofs); //-ofs*m;
//xform.origin.z -= aabb.get_longest_axis_size() * 2; //xform.origin.z -= aabb.get_longest_axis_size() * 2;
@ -117,16 +117,16 @@ MeshEditor::MeshEditor() {
viewport->set_msaa(Viewport::MSAA_2X); viewport->set_msaa(Viewport::MSAA_2X);
set_stretch(true); set_stretch(true);
camera = memnew(Camera3D); camera = memnew(Camera3D);
camera->set_transform(Transform(Basis(), Vector3(0, 0, 1.1))); camera->set_transform(Transform3D(Basis(), Vector3(0, 0, 1.1)));
camera->set_perspective(45, 0.1, 10); camera->set_perspective(45, 0.1, 10);
viewport->add_child(camera); viewport->add_child(camera);
light1 = memnew(DirectionalLight3D); light1 = memnew(DirectionalLight3D);
light1->set_transform(Transform().looking_at(Vector3(-1, -1, -1), Vector3(0, 1, 0))); light1->set_transform(Transform3D().looking_at(Vector3(-1, -1, -1), Vector3(0, 1, 0)));
viewport->add_child(light1); viewport->add_child(light1);
light2 = memnew(DirectionalLight3D); light2 = memnew(DirectionalLight3D);
light2->set_transform(Transform().looking_at(Vector3(0, 1, 0), Vector3(0, 0, 1))); light2->set_transform(Transform3D().looking_at(Vector3(0, 1, 0), Vector3(0, 0, 1)));
light2->set_color(Color(0.7, 0.7, 0.7)); light2->set_color(Color(0.7, 0.7, 0.7));
viewport->add_child(light2); viewport->add_child(light2);

View File

@ -127,7 +127,7 @@ void MeshLibraryEditor::_import_scene(Node *p_scene, Ref<MeshLibrary> p_library,
continue; continue;
} }
//Transform shape_transform = sb->shape_owner_get_transform(E->get()); //Transform3D shape_transform = sb->shape_owner_get_transform(E->get());
//shape_transform.set_origin(shape_transform.get_origin() - phys_offset); //shape_transform.set_origin(shape_transform.get_origin() - phys_offset);
@ -147,7 +147,7 @@ void MeshLibraryEditor::_import_scene(Node *p_scene, Ref<MeshLibrary> p_library,
p_library->set_item_shapes(id, collisions); p_library->set_item_shapes(id, collisions);
Ref<NavigationMesh> navmesh; Ref<NavigationMesh> navmesh;
Transform navmesh_transform; Transform3D navmesh_transform;
for (int j = 0; j < mi->get_child_count(); j++) { for (int j = 0; j < mi->get_child_count(); j++) {
Node *child2 = mi->get_child(j); Node *child2 = mi->get_child(j);
if (!Object::cast_to<NavigationRegion3D>(child2)) { if (!Object::cast_to<NavigationRegion3D>(child2)) {
@ -170,7 +170,7 @@ void MeshLibraryEditor::_import_scene(Node *p_scene, Ref<MeshLibrary> p_library,
if (true) { if (true) {
Vector<Ref<Mesh>> meshes; Vector<Ref<Mesh>> meshes;
Vector<Transform> transforms; Vector<Transform3D> transforms;
Vector<int> ids = p_library->get_item_list(); Vector<int> ids = p_library->get_item_list();
for (int i = 0; i < ids.size(); i++) { for (int i = 0; i < ids.size(); i++) {
if (mesh_instances.find(ids[i])) { if (mesh_instances.find(ids[i])) {

View File

@ -111,7 +111,7 @@ void MultiMeshEditor::_populate() {
return; return;
} }
Transform geom_xform = node->get_global_transform().affine_inverse() * ss_instance->get_global_transform(); Transform3D geom_xform = node->get_global_transform().affine_inverse() * ss_instance->get_global_transform();
Vector<Face3> geometry = ss_instance->get_faces(VisualInstance3D::FACES_SOLID); Vector<Face3> geometry = ss_instance->get_faces(VisualInstance3D::FACES_SOLID);
@ -167,7 +167,7 @@ void MultiMeshEditor::_populate() {
float _scale = populate_scale->get_value(); float _scale = populate_scale->get_value();
int axis = populate_axis->get_selected(); int axis = populate_axis->get_selected();
Transform axis_xform; Transform3D axis_xform;
if (axis == Vector3::AXIS_Z) { if (axis == Vector3::AXIS_Z) {
axis_xform.rotate(Vector3(1, 0, 0), -Math_PI * 0.5); axis_xform.rotate(Vector3(1, 0, 0), -Math_PI * 0.5);
} }
@ -191,7 +191,7 @@ void MultiMeshEditor::_populate() {
Vector3 normal = face.get_plane().normal; Vector3 normal = face.get_plane().normal;
Vector3 op_axis = (face.vertex[0] - face.vertex[1]).normalized(); Vector3 op_axis = (face.vertex[0] - face.vertex[1]).normalized();
Transform xform; Transform3D xform;
xform.set_look_at(pos, pos + op_axis, normal); xform.set_look_at(pos, pos + op_axis, normal);
xform = xform * axis_xform; xform = xform * axis_xform;

View File

@ -361,8 +361,8 @@ void Node3DEditorViewport::_update_camera(float p_interp_delta) {
} }
} }
Transform Node3DEditorViewport::to_camera_transform(const Cursor &p_cursor) const { Transform3D Node3DEditorViewport::to_camera_transform(const Cursor &p_cursor) const {
Transform camera_transform; Transform3D camera_transform;
camera_transform.translate(p_cursor.pos); camera_transform.translate(p_cursor.pos);
camera_transform.basis.rotate(Vector3(1, 0, 0), -p_cursor.x_rot); camera_transform.basis.rotate(Vector3(1, 0, 0), -p_cursor.x_rot);
camera_transform.basis.rotate(Vector3(0, 1, 0), -p_cursor.y_rot); camera_transform.basis.rotate(Vector3(0, 1, 0), -p_cursor.y_rot);
@ -410,7 +410,7 @@ float Node3DEditorViewport::get_fov() const {
return CLAMP(spatial_editor->get_fov(), MIN_FOV, MAX_FOV); return CLAMP(spatial_editor->get_fov(), MIN_FOV, MAX_FOV);
} }
Transform Node3DEditorViewport::_get_camera_transform() const { Transform3D Node3DEditorViewport::_get_camera_transform() const {
return camera->get_global_transform(); return camera->get_global_transform();
} }
@ -631,7 +631,7 @@ Vector3 Node3DEditorViewport::_get_screen_to_space(const Vector3 &p_vector3) {
} }
Vector2 screen_he = cm.get_viewport_half_extents(); Vector2 screen_he = cm.get_viewport_half_extents();
Transform camera_transform; Transform3D camera_transform;
camera_transform.translate(cursor.pos); camera_transform.translate(cursor.pos);
camera_transform.basis.rotate(Vector3(1, 0, 0), -cursor.x_rot); camera_transform.basis.rotate(Vector3(1, 0, 0), -cursor.x_rot);
camera_transform.basis.rotate(Vector3(0, 1, 0), -cursor.y_rot); camera_transform.basis.rotate(Vector3(0, 1, 0), -cursor.y_rot);
@ -829,7 +829,7 @@ bool Node3DEditorViewport::_gizmo_select(const Vector2 &p_screenpos, bool p_high
Vector3 ray_pos = _get_ray_pos(Vector2(p_screenpos.x, p_screenpos.y)); Vector3 ray_pos = _get_ray_pos(Vector2(p_screenpos.x, p_screenpos.y));
Vector3 ray = _get_ray(Vector2(p_screenpos.x, p_screenpos.y)); Vector3 ray = _get_ray(Vector2(p_screenpos.x, p_screenpos.y));
Transform gt = spatial_editor->get_gizmo_transform(); Transform3D gt = spatial_editor->get_gizmo_transform();
float gs = gizmo_scale; float gs = gizmo_scale;
if (spatial_editor->get_tool_mode() == Node3DEditor::TOOL_MODE_SELECT || spatial_editor->get_tool_mode() == Node3DEditor::TOOL_MODE_MOVE) { if (spatial_editor->get_tool_mode() == Node3DEditor::TOOL_MODE_SELECT || spatial_editor->get_tool_mode() == Node3DEditor::TOOL_MODE_MOVE) {
@ -1579,10 +1579,10 @@ void Node3DEditorViewport::_sinput(const Ref<InputEvent> &p_event) {
continue; continue;
} }
Transform original = se->original; Transform3D original = se->original;
Transform original_local = se->original_local; Transform3D original_local = se->original_local;
Transform base = Transform(Basis(), _edit.center); Transform3D base = Transform3D(Basis(), _edit.center);
Transform t; Transform3D t;
Vector3 local_scale; Vector3 local_scale;
if (local_coords) { if (local_coords) {
@ -1608,7 +1608,7 @@ void Node3DEditorViewport::_sinput(const Ref<InputEvent> &p_event) {
motion.snap(Vector3(snap, snap, snap)); motion.snap(Vector3(snap, snap, snap));
} }
Transform r; Transform3D r;
r.basis.scale(motion + Vector3(1, 1, 1)); r.basis.scale(motion + Vector3(1, 1, 1));
t = base * (r * (base.inverse() * original)); t = base * (r * (base.inverse() * original));
@ -1701,8 +1701,8 @@ void Node3DEditorViewport::_sinput(const Ref<InputEvent> &p_event) {
continue; continue;
} }
Transform original = se->original; Transform3D original = se->original;
Transform t; Transform3D t;
if (local_coords) { if (local_coords) {
if (_edit.snap || spatial_editor->is_snap_enabled()) { if (_edit.snap || spatial_editor->is_snap_enabled()) {
@ -1797,10 +1797,10 @@ void Node3DEditorViewport::_sinput(const Ref<InputEvent> &p_event) {
continue; continue;
} }
Transform t; Transform3D t;
if (local_coords) { if (local_coords) {
Transform original_local = se->original_local; Transform3D original_local = se->original_local;
Basis rot = Basis(axis, angle); Basis rot = Basis(axis, angle);
t.basis = original_local.get_basis().orthonormalized() * rot; t.basis = original_local.get_basis().orthonormalized() * rot;
@ -1811,9 +1811,9 @@ void Node3DEditorViewport::_sinput(const Ref<InputEvent> &p_event) {
sp->set_scale(original_local.basis.get_scale()); // re-apply original scale sp->set_scale(original_local.basis.get_scale()); // re-apply original scale
} else { } else {
Transform original = se->original; Transform3D original = se->original;
Transform r; Transform3D r;
Transform base = Transform(Basis(), _edit.center); Transform3D base = Transform3D(Basis(), _edit.center);
r.basis.rotate(plane.normal, angle); r.basis.rotate(plane.normal, angle);
t = base * r * base.inverse() * original; t = base * r * base.inverse() * original;
@ -2057,7 +2057,7 @@ void Node3DEditorViewport::_nav_pan(Ref<InputEventWithModifiers> p_event, const
pan_speed *= pan_speed_modifier; pan_speed *= pan_speed_modifier;
} }
Transform camera_transform; Transform3D camera_transform;
camera_transform.translate(cursor.pos); camera_transform.translate(cursor.pos);
camera_transform.basis.rotate(Vector3(1, 0, 0), -cursor.x_rot); camera_transform.basis.rotate(Vector3(1, 0, 0), -cursor.x_rot);
@ -2145,7 +2145,7 @@ void Node3DEditorViewport::_nav_look(Ref<InputEventWithModifiers> p_event, const
const bool invert_y_axis = EditorSettings::get_singleton()->get("editors/3d/navigation/invert_y_axis"); const bool invert_y_axis = EditorSettings::get_singleton()->get("editors/3d/navigation/invert_y_axis");
// Note: do NOT assume the camera has the "current" transform, because it is interpolated and may have "lag". // Note: do NOT assume the camera has the "current" transform, because it is interpolated and may have "lag".
const Transform prev_camera_transform = to_camera_transform(cursor); const Transform3D prev_camera_transform = to_camera_transform(cursor);
if (invert_y_axis) { if (invert_y_axis) {
cursor.x_rot -= p_relative.y * radians_per_pixel; cursor.x_rot -= p_relative.y * radians_per_pixel;
@ -2158,7 +2158,7 @@ void Node3DEditorViewport::_nav_look(Ref<InputEventWithModifiers> p_event, const
cursor.y_rot += p_relative.x * radians_per_pixel; cursor.y_rot += p_relative.x * radians_per_pixel;
// Look is like the opposite of Orbit: the focus point rotates around the camera // Look is like the opposite of Orbit: the focus point rotates around the camera
Transform camera_transform = to_camera_transform(cursor); Transform3D camera_transform = to_camera_transform(cursor);
Vector3 pos = camera_transform.xform(Vector3(0, 0, 0)); Vector3 pos = camera_transform.xform(Vector3(0, 0, 0));
Vector3 prev_pos = prev_camera_transform.xform(Vector3(0, 0, 0)); Vector3 prev_pos = prev_camera_transform.xform(Vector3(0, 0, 0));
Vector3 diff = prev_pos - pos; Vector3 diff = prev_pos - pos;
@ -2444,7 +2444,7 @@ void Node3DEditorViewport::_notification(int p_what) {
continue; continue;
} }
Transform t = sp->get_global_gizmo_transform(); Transform3D t = sp->get_global_gizmo_transform();
VisualInstance3D *vi = Object::cast_to<VisualInstance3D>(sp); VisualInstance3D *vi = Object::cast_to<VisualInstance3D>(sp);
AABB new_aabb = vi ? vi->get_aabb() : _calculate_spatial_bounds(sp); AABB new_aabb = vi ? vi->get_aabb() : _calculate_spatial_bounds(sp);
@ -2878,7 +2878,7 @@ void Node3DEditorViewport::_menu_option(int p_option) {
break; break;
} }
Transform camera_transform = camera->get_global_transform(); Transform3D camera_transform = camera->get_global_transform();
List<Node *> &selection = editor_selection->get_selected_node_list(); List<Node *> &selection = editor_selection->get_selected_node_list();
@ -2895,7 +2895,7 @@ void Node3DEditorViewport::_menu_option(int p_option) {
continue; continue;
} }
Transform 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.set_euler(camera_transform.basis.get_euler());
@ -2915,7 +2915,7 @@ void Node3DEditorViewport::_menu_option(int p_option) {
break; break;
} }
Transform camera_transform = camera->get_global_transform(); Transform3D camera_transform = camera->get_global_transform();
List<Node *> &selection = editor_selection->get_selected_node_list(); List<Node *> &selection = editor_selection->get_selected_node_list();
@ -3315,9 +3315,9 @@ void Node3DEditorViewport::update_transform_gizmo_view() {
return; return;
} }
Transform xform = spatial_editor->get_gizmo_transform(); Transform3D xform = spatial_editor->get_gizmo_transform();
Transform camera_xform = camera->get_transform(); Transform3D camera_xform = camera->get_transform();
if (xform.origin.distance_squared_to(camera_xform.origin) < 0.01) { if (xform.origin.distance_squared_to(camera_xform.origin) < 0.01) {
for (int i = 0; i < 3; i++) { for (int i = 0; i < 3; i++) {
@ -3800,7 +3800,7 @@ bool Node3DEditorViewport::_create_instance(Node *parent, String &path, const Po
Node3D *node3d = Object::cast_to<Node3D>(instanced_scene); Node3D *node3d = Object::cast_to<Node3D>(instanced_scene);
if (node3d) { if (node3d) {
Transform global_transform; Transform3D global_transform;
Node3D *parent_node3d = Object::cast_to<Node3D>(parent); Node3D *parent_node3d = Object::cast_to<Node3D>(parent);
if (parent_node3d) { if (parent_node3d) {
global_transform = parent_node3d->get_global_gizmo_transform(); global_transform = parent_node3d->get_global_gizmo_transform();
@ -3900,7 +3900,7 @@ bool Node3DEditorViewport::can_drop_data_fw(const Point2 &p_point, const Variant
} }
if (can_instance) { if (can_instance) {
Transform global_transform = Transform(Basis(), _get_instance_position(p_point)); Transform3D global_transform = Transform3D(Basis(), _get_instance_position(p_point));
preview_node->set_global_transform(global_transform); preview_node->set_global_transform(global_transform);
} }
@ -4574,7 +4574,7 @@ void Node3DEditor::update_transform_gizmo() {
continue; continue;
} }
Transform xf = se->sp->get_global_gizmo_transform(); Transform3D xf = se->sp->get_global_gizmo_transform();
if (first) { if (first) {
center.position = xf.origin; center.position = xf.origin;
@ -4955,7 +4955,7 @@ void Node3DEditor::_snap_update() {
} }
void Node3DEditor::_xform_dialog_action() { void Node3DEditor::_xform_dialog_action() {
Transform t; Transform3D t;
//translation //translation
Vector3 scale; Vector3 scale;
Vector3 rotate; Vector3 rotate;
@ -4988,7 +4988,7 @@ void Node3DEditor::_xform_dialog_action() {
bool post = xform_type->get_selected() > 0; bool post = xform_type->get_selected() > 0;
Transform tr = sp->get_global_gizmo_transform(); Transform3D tr = sp->get_global_gizmo_transform();
if (post) { if (post) {
tr = tr * t; tr = tr * t;
} else { } else {
@ -6180,7 +6180,7 @@ void Node3DEditor::snap_selected_nodes_to_floor() {
if (ss->intersect_ray(from, to, result, excluded)) { if (ss->intersect_ray(from, to, result, excluded)) {
Vector3 position_offset = d["position_offset"]; Vector3 position_offset = d["position_offset"];
Transform new_transform = sp->get_global_transform(); Transform3D new_transform = sp->get_global_transform();
new_transform.origin.y = result.position.y; new_transform.origin.y = result.position.y;
new_transform.origin = new_transform.origin - position_offset; new_transform.origin = new_transform.origin - position_offset;
@ -6556,7 +6556,7 @@ void Node3DEditor::_preview_settings_changed() {
} }
{ // preview sun { // preview sun
Transform t; Transform3D t;
t.basis = sun_rotation; t.basis = sun_rotation;
preview_sun->set_transform(t); preview_sun->set_transform(t);
sun_direction->update(); sun_direction->update();

View File

@ -322,7 +322,7 @@ private:
Vector3 _get_ray_pos(const Vector2 &p_pos) const; Vector3 _get_ray_pos(const Vector2 &p_pos) const;
Vector3 _get_ray(const Vector2 &p_pos) const; Vector3 _get_ray(const Vector2 &p_pos) const;
Point2 _point_to_screen(const Vector3 &p_point); Point2 _point_to_screen(const Vector3 &p_point);
Transform _get_camera_transform() const; Transform3D _get_camera_transform() const;
int get_selected_count() const; int get_selected_count() const;
Vector3 _get_camera_position() const; Vector3 _get_camera_position() const;
@ -380,7 +380,7 @@ private:
struct EditData { struct EditData {
TransformMode mode; TransformMode mode;
TransformPlane plane; TransformPlane plane;
Transform original; Transform3D original;
Vector3 click_ray; Vector3 click_ray;
Vector3 click_ray_pos; Vector3 click_ray_pos;
Vector3 center; Vector3 center;
@ -432,7 +432,7 @@ private:
// //
void _update_camera(float p_interp_delta); void _update_camera(float p_interp_delta);
Transform to_camera_transform(const Cursor &p_cursor) const; Transform3D to_camera_transform(const Cursor &p_cursor) const;
void _draw(); void _draw();
void _surface_mouse_enter(); void _surface_mouse_enter();
@ -505,9 +505,9 @@ class Node3DEditorSelectedItem : public Object {
public: public:
AABB aabb; AABB aabb;
Transform original; // original location when moving Transform3D original; // original location when moving
Transform original_local; Transform3D original_local;
Transform last_xform; // last transform Transform3D last_xform; // last transform
bool last_xform_dirty; bool last_xform_dirty;
Node3D *sp; Node3D *sp;
RID sbox_instance; RID sbox_instance;
@ -641,7 +641,7 @@ private:
struct Gizmo { struct Gizmo {
bool visible = false; bool visible = false;
float scale = 0; float scale = 0;
Transform transform; Transform3D transform;
} gizmo; } gizmo;
enum MenuOption { enum MenuOption {
@ -824,7 +824,7 @@ public:
float get_zfar() const { return settings_zfar->get_value(); } float get_zfar() const { return settings_zfar->get_value(); }
float get_fov() const { return settings_fov->get_value(); } float get_fov() const { return settings_fov->get_value(); }
Transform get_gizmo_transform() const { return gizmo.transform; } Transform3D get_gizmo_transform() const { return gizmo.transform; }
bool is_gizmo_visible() const { return gizmo.visible; } bool is_gizmo_visible() const { return gizmo.visible; }
ToolMode get_tool_mode() const { return tool_mode; } ToolMode get_tool_mode() const { return tool_mode; }

View File

@ -94,8 +94,8 @@ void Path3DGizmo::set_handle(int p_idx, Camera3D *p_camera, const Point2 &p_poin
return; return;
} }
Transform gt = path->get_global_transform(); Transform3D gt = path->get_global_transform();
Transform gi = gt.affine_inverse(); Transform3D gi = gt.affine_inverse();
Vector3 ray_from = p_camera->project_ray_origin(p_point); Vector3 ray_from = p_camera->project_ray_origin(p_point);
Vector3 ray_dir = p_camera->project_ray_normal(p_point); Vector3 ray_dir = p_camera->project_ray_normal(p_point);
@ -302,8 +302,8 @@ bool Path3DEditorPlugin::forward_spatial_gui_input(Camera3D *p_camera, const Ref
if (c.is_null()) { if (c.is_null()) {
return false; return false;
} }
Transform gt = path->get_global_transform(); Transform3D gt = path->get_global_transform();
Transform it = gt.affine_inverse(); Transform3D it = gt.affine_inverse();
static const int click_dist = 10; //should make global static const int click_dist = 10; //should make global

View File

@ -171,7 +171,7 @@ void BoneTransformEditor::_value_changed(const double p_value) {
return; return;
} }
Transform tform = compute_transform_from_vector3s(); Transform3D tform = compute_transform_from_vector3s();
_change_transform(tform); _change_transform(tform);
} }
@ -179,30 +179,30 @@ void BoneTransformEditor::_value_changed_vector3(const String p_property_name, c
if (updating) { if (updating) {
return; return;
} }
Transform tform = compute_transform_from_vector3s(); Transform3D tform = compute_transform_from_vector3s();
_change_transform(tform); _change_transform(tform);
} }
Transform BoneTransformEditor::compute_transform_from_vector3s() const { Transform3D BoneTransformEditor::compute_transform_from_vector3s() const {
// Convert rotation from degrees to radians. // Convert rotation from degrees to radians.
Vector3 prop_rotation = rotation_property->get_vector(); Vector3 prop_rotation = rotation_property->get_vector();
prop_rotation.x = Math::deg2rad(prop_rotation.x); prop_rotation.x = Math::deg2rad(prop_rotation.x);
prop_rotation.y = Math::deg2rad(prop_rotation.y); prop_rotation.y = Math::deg2rad(prop_rotation.y);
prop_rotation.z = Math::deg2rad(prop_rotation.z); prop_rotation.z = Math::deg2rad(prop_rotation.z);
return Transform( return Transform3D(
Basis(prop_rotation, scale_property->get_vector()), Basis(prop_rotation, scale_property->get_vector()),
translation_property->get_vector()); translation_property->get_vector());
} }
void BoneTransformEditor::_value_changed_transform(const String p_property_name, const Transform p_transform, const StringName p_edited_property_name, const bool p_boolean) { void BoneTransformEditor::_value_changed_transform(const String p_property_name, const Transform3D p_transform, const StringName p_edited_property_name, const bool p_boolean) {
if (updating) { if (updating) {
return; return;
} }
_change_transform(p_transform); _change_transform(p_transform);
} }
void BoneTransformEditor::_change_transform(Transform p_new_transform) { void BoneTransformEditor::_change_transform(Transform3D p_new_transform) {
if (property.get_slicec('/', 0) == "bones" && property.get_slicec('/', 2) == "custom_pose") { if (property.get_slicec('/', 0) == "bones" && property.get_slicec('/', 2) == "custom_pose") {
undo_redo->create_action(TTR("Set Custom Bone Pose Transform"), UndoRedo::MERGE_ENDS); undo_redo->create_action(TTR("Set Custom Bone Pose Transform"), UndoRedo::MERGE_ENDS);
undo_redo->add_undo_method(skeleton, "set_bone_custom_pose", property.get_slicec('/', 1).to_int(), skeleton->get_bone_custom_pose(property.get_slicec('/', 1).to_int())); undo_redo->add_undo_method(skeleton, "set_bone_custom_pose", property.get_slicec('/', 1).to_int(), skeleton->get_bone_custom_pose(property.get_slicec('/', 1).to_int()));
@ -235,7 +235,7 @@ void BoneTransformEditor::_update_properties() {
updating = true; updating = true;
Transform tform = skeleton->get(property); Transform3D tform = skeleton->get(property);
_update_transform_properties(tform); _update_transform_properties(tform);
} }
@ -250,11 +250,11 @@ void BoneTransformEditor::_update_custom_pose_properties() {
updating = true; updating = true;
Transform tform = skeleton->get_bone_custom_pose(property.to_int()); Transform3D tform = skeleton->get_bone_custom_pose(property.to_int());
_update_transform_properties(tform); _update_transform_properties(tform);
} }
void BoneTransformEditor::_update_transform_properties(Transform tform) { void BoneTransformEditor::_update_transform_properties(Transform3D tform) {
Basis rotation_basis = tform.get_basis(); Basis rotation_basis = tform.get_basis();
Vector3 rotation_radians = rotation_basis.get_rotation_euler(); Vector3 rotation_radians = rotation_basis.get_rotation_euler();
Vector3 rotation_degrees = Vector3(Math::rad2deg(rotation_radians.x), Math::rad2deg(rotation_radians.y), Math::rad2deg(rotation_radians.z)); Vector3 rotation_degrees = Vector3(Math::rad2deg(rotation_radians.x), Math::rad2deg(rotation_radians.y), Math::rad2deg(rotation_radians.z));
@ -306,7 +306,7 @@ void BoneTransformEditor::_key_button_pressed() {
} }
// Need to normalize the basis before you key it // Need to normalize the basis before you key it
Transform tform = compute_transform_from_vector3s(); Transform3D tform = compute_transform_from_vector3s();
tform.orthonormalize(); tform.orthonormalize();
AnimationPlayerEditor::singleton->get_track_editor()->insert_transform_key(skeleton, name, tform); AnimationPlayerEditor::singleton->get_track_editor()->insert_transform_key(skeleton, name, tform);
} }
@ -380,7 +380,7 @@ void Skeleton3DEditor::create_physical_skeleton() {
} }
PhysicalBone3D *Skeleton3DEditor::create_physical_bone(int bone_id, int bone_child_id, const Vector<BoneInfo> &bones_infos) { PhysicalBone3D *Skeleton3DEditor::create_physical_bone(int bone_id, int bone_child_id, const Vector<BoneInfo> &bones_infos) {
const Transform child_rest = skeleton->get_bone_rest(bone_child_id); const Transform3D child_rest = skeleton->get_bone_rest(bone_child_id);
const real_t half_height(child_rest.origin.length() * 0.5); const real_t half_height(child_rest.origin.length() * 0.5);
const real_t radius(half_height * 0.2); const real_t radius(half_height * 0.2);
@ -392,15 +392,15 @@ PhysicalBone3D *Skeleton3DEditor::create_physical_bone(int bone_id, int bone_chi
CollisionShape3D *bone_shape = memnew(CollisionShape3D); CollisionShape3D *bone_shape = memnew(CollisionShape3D);
bone_shape->set_shape(bone_shape_capsule); bone_shape->set_shape(bone_shape_capsule);
Transform capsule_transform; Transform3D capsule_transform;
capsule_transform.basis = Basis(Vector3(1, 0, 0), Vector3(0, 0, 1), Vector3(0, -1, 0)); capsule_transform.basis = Basis(Vector3(1, 0, 0), Vector3(0, 0, 1), Vector3(0, -1, 0));
bone_shape->set_transform(capsule_transform); bone_shape->set_transform(capsule_transform);
Transform body_transform; Transform3D body_transform;
body_transform.set_look_at(Vector3(0, 0, 0), child_rest.origin); body_transform.set_look_at(Vector3(0, 0, 0), child_rest.origin);
body_transform.origin = body_transform.basis.xform(Vector3(0, 0, -half_height)); body_transform.origin = body_transform.basis.xform(Vector3(0, 0, -half_height));
Transform joint_transform; Transform3D joint_transform;
joint_transform.origin = Vector3(0, 0, half_height); joint_transform.origin = Vector3(0, 0, half_height);
PhysicalBone3D *physical_bone = memnew(PhysicalBone3D); PhysicalBone3D *physical_bone = memnew(PhysicalBone3D);

View File

@ -78,11 +78,11 @@ class BoneTransformEditor : public VBoxContainer {
// Called when the one of the EditorPropertyVector3 are updated. // Called when the one of the EditorPropertyVector3 are updated.
void _value_changed_vector3(const String p_property_name, const Vector3 p_vector, const StringName p_edited_property_name, const bool p_boolean); void _value_changed_vector3(const String p_property_name, const Vector3 p_vector, const StringName p_edited_property_name, const bool p_boolean);
// Called when the transform_property is updated. // Called when the transform_property is updated.
void _value_changed_transform(const String p_property_name, const Transform p_transform, const StringName p_edited_property_name, const bool p_boolean); void _value_changed_transform(const String p_property_name, const Transform3D p_transform, const StringName p_edited_property_name, const bool p_boolean);
// Changes the transform to the given transform and updates the UI accordingly. // Changes the transform to the given transform and updates the UI accordingly.
void _change_transform(Transform p_new_transform); void _change_transform(Transform3D p_new_transform);
// Creates a Transform using the EditorPropertyVector3 properties. // Creates a Transform using the EditorPropertyVector3 properties.
Transform compute_transform_from_vector3s() const; Transform3D compute_transform_from_vector3s() const;
void update_enabled_checkbox(); void update_enabled_checkbox();
@ -98,7 +98,7 @@ public:
void _update_properties(); void _update_properties();
void _update_custom_pose_properties(); void _update_custom_pose_properties();
void _update_transform_properties(Transform p_transform); void _update_transform_properties(Transform3D p_transform);
// Can/cannot modify the spinner values for the Transform // Can/cannot modify the spinner values for the Transform
void set_read_only(const bool p_read_only); void set_read_only(const bool p_read_only);
@ -127,7 +127,7 @@ class Skeleton3DEditor : public VBoxContainer {
struct BoneInfo { struct BoneInfo {
PhysicalBone3D *physical_bone = nullptr; PhysicalBone3D *physical_bone = nullptr;
Transform relative_rest; // Relative to skeleton node Transform3D relative_rest; // Relative to skeleton node
}; };
EditorNode *editor; EditorNode *editor;

View File

@ -791,7 +791,7 @@ bool CustomPropertyEditor::edit(Object *p_owner, const String &p_name, Variant::
} }
} break; } break;
case Variant::TRANSFORM: { case Variant::TRANSFORM3D: {
field_names.push_back("xx"); field_names.push_back("xx");
field_names.push_back("xy"); field_names.push_back("xy");
field_names.push_back("xz"); field_names.push_back("xz");
@ -806,7 +806,7 @@ bool CustomPropertyEditor::edit(Object *p_owner, const String &p_name, Variant::
field_names.push_back("zo"); field_names.push_back("zo");
config_value_editors(12, 4, 16, field_names); config_value_editors(12, 4, 16, field_names);
Transform tr = v; Transform3D tr = v;
for (int i = 0; i < 9; i++) { for (int i = 0; i < 9; i++) {
value_editor[(i / 3) * 4 + i % 3]->set_text(String::num(tr.basis.elements[i / 3][i % 3])); value_editor[(i / 3) * 4 + i % 3]->set_text(String::num(tr.basis.elements[i / 3][i % 3]));
} }
@ -1557,7 +1557,7 @@ void CustomPropertyEditor::_modified(String p_string) {
_emit_changed_whole_or_field(); _emit_changed_whole_or_field();
} break; } break;
case Variant::TRANSFORM: { case Variant::TRANSFORM3D: {
Basis basis; Basis basis;
for (int i = 0; i < 9; i++) { for (int i = 0; i < 9; i++) {
basis.elements[i / 3][i % 3] = _parse_real_expression(value_editor[(i / 3) * 4 + i % 3]->get_text()); basis.elements[i / 3][i % 3] = _parse_real_expression(value_editor[(i / 3) * 4 + i % 3]->get_text());
@ -1569,7 +1569,7 @@ void CustomPropertyEditor::_modified(String p_string) {
origin.y = _parse_real_expression(value_editor[7]->get_text()); origin.y = _parse_real_expression(value_editor[7]->get_text());
origin.z = _parse_real_expression(value_editor[11]->get_text()); origin.z = _parse_real_expression(value_editor[11]->get_text());
v = Transform(basis, origin); v = Transform3D(basis, origin);
_emit_changed_whole_or_field(); _emit_changed_whole_or_field();
} break; } break;
@ -1639,7 +1639,7 @@ void CustomPropertyEditor::_focus_enter() {
case Variant::AABB: case Variant::AABB:
case Variant::TRANSFORM2D: case Variant::TRANSFORM2D:
case Variant::BASIS: case Variant::BASIS:
case Variant::TRANSFORM: { case Variant::TRANSFORM3D: {
for (int i = 0; i < MAX_VALUE_EDITORS; ++i) { for (int i = 0; i < MAX_VALUE_EDITORS; ++i) {
if (value_editor[i]->has_focus()) { if (value_editor[i]->has_focus()) {
focused_value_editor = i; focused_value_editor = i;
@ -1665,7 +1665,7 @@ void CustomPropertyEditor::_focus_exit() {
case Variant::AABB: case Variant::AABB:
case Variant::TRANSFORM2D: case Variant::TRANSFORM2D:
case Variant::BASIS: case Variant::BASIS:
case Variant::TRANSFORM: { case Variant::TRANSFORM3D: {
for (int i = 0; i < MAX_VALUE_EDITORS; ++i) { for (int i = 0; i < MAX_VALUE_EDITORS; ++i) {
value_editor[i]->select(0, 0); value_editor[i]->select(0, 0);
} }

View File

@ -199,7 +199,7 @@ protected:
pinfo.type = Variant::TRANSFORM2D; pinfo.type = Variant::TRANSFORM2D;
} break; } break;
case RS::GLOBAL_VAR_TYPE_TRANSFORM: { case RS::GLOBAL_VAR_TYPE_TRANSFORM: {
pinfo.type = Variant::TRANSFORM; pinfo.type = Variant::TRANSFORM3D;
} break; } break;
case RS::GLOBAL_VAR_TYPE_MAT4: { case RS::GLOBAL_VAR_TYPE_MAT4: {
pinfo.type = Variant::PACKED_INT32_ARRAY; pinfo.type = Variant::PACKED_INT32_ARRAY;
@ -326,7 +326,7 @@ static Variant create_var(RS::GlobalVariableType p_type) {
return Transform2D(); return Transform2D();
} }
case RS::GLOBAL_VAR_TYPE_TRANSFORM: { case RS::GLOBAL_VAR_TYPE_TRANSFORM: {
return Transform(); return Transform3D();
} }
case RS::GLOBAL_VAR_TYPE_MAT4: { case RS::GLOBAL_VAR_TYPE_MAT4: {
Vector<real_t> xform; Vector<real_t> xform;

View File

@ -268,7 +268,7 @@ PhysicsServer3D::AreaSpaceOverrideMode BulletPhysicsServer3D::area_get_space_ove
return area->get_spOv_mode(); return area->get_spOv_mode();
} }
void BulletPhysicsServer3D::area_add_shape(RID p_area, RID p_shape, const Transform &p_transform, bool p_disabled) { void BulletPhysicsServer3D::area_add_shape(RID p_area, RID p_shape, const Transform3D &p_transform, bool p_disabled) {
AreaBullet *area = area_owner.getornull(p_area); AreaBullet *area = area_owner.getornull(p_area);
ERR_FAIL_COND(!area); ERR_FAIL_COND(!area);
@ -288,7 +288,7 @@ void BulletPhysicsServer3D::area_set_shape(RID p_area, int p_shape_idx, RID p_sh
area->set_shape(p_shape_idx, shape); area->set_shape(p_shape_idx, shape);
} }
void BulletPhysicsServer3D::area_set_shape_transform(RID p_area, int p_shape_idx, const Transform &p_transform) { void BulletPhysicsServer3D::area_set_shape_transform(RID p_area, int p_shape_idx, const Transform3D &p_transform) {
AreaBullet *area = area_owner.getornull(p_area); AreaBullet *area = area_owner.getornull(p_area);
ERR_FAIL_COND(!area); ERR_FAIL_COND(!area);
@ -309,9 +309,9 @@ RID BulletPhysicsServer3D::area_get_shape(RID p_area, int p_shape_idx) const {
return area->get_shape(p_shape_idx)->get_self(); return area->get_shape(p_shape_idx)->get_self();
} }
Transform BulletPhysicsServer3D::area_get_shape_transform(RID p_area, int p_shape_idx) const { Transform3D BulletPhysicsServer3D::area_get_shape_transform(RID p_area, int p_shape_idx) const {
AreaBullet *area = area_owner.getornull(p_area); AreaBullet *area = area_owner.getornull(p_area);
ERR_FAIL_COND_V(!area, Transform()); ERR_FAIL_COND_V(!area, Transform3D());
return area->get_shape_transform(p_shape_idx); return area->get_shape_transform(p_shape_idx);
} }
@ -382,15 +382,15 @@ Variant BulletPhysicsServer3D::area_get_param(RID p_area, AreaParameter p_param)
} }
} }
void BulletPhysicsServer3D::area_set_transform(RID p_area, const Transform &p_transform) { void BulletPhysicsServer3D::area_set_transform(RID p_area, const Transform3D &p_transform) {
AreaBullet *area = area_owner.getornull(p_area); AreaBullet *area = area_owner.getornull(p_area);
ERR_FAIL_COND(!area); ERR_FAIL_COND(!area);
area->set_transform(p_transform); area->set_transform(p_transform);
} }
Transform BulletPhysicsServer3D::area_get_transform(RID p_area) const { Transform3D BulletPhysicsServer3D::area_get_transform(RID p_area) const {
AreaBullet *area = area_owner.getornull(p_area); AreaBullet *area = area_owner.getornull(p_area);
ERR_FAIL_COND_V(!area, Transform()); ERR_FAIL_COND_V(!area, Transform3D());
return area->get_transform(); return area->get_transform();
} }
@ -484,7 +484,7 @@ PhysicsServer3D::BodyMode BulletPhysicsServer3D::body_get_mode(RID p_body) const
return body->get_mode(); return body->get_mode();
} }
void BulletPhysicsServer3D::body_add_shape(RID p_body, RID p_shape, const Transform &p_transform, bool p_disabled) { void BulletPhysicsServer3D::body_add_shape(RID p_body, RID p_shape, const Transform3D &p_transform, bool p_disabled) {
RigidBodyBullet *body = rigid_body_owner.getornull(p_body); RigidBodyBullet *body = rigid_body_owner.getornull(p_body);
ERR_FAIL_COND(!body); ERR_FAIL_COND(!body);
@ -504,7 +504,7 @@ void BulletPhysicsServer3D::body_set_shape(RID p_body, int p_shape_idx, RID p_sh
body->set_shape(p_shape_idx, shape); body->set_shape(p_shape_idx, shape);
} }
void BulletPhysicsServer3D::body_set_shape_transform(RID p_body, int p_shape_idx, const Transform &p_transform) { void BulletPhysicsServer3D::body_set_shape_transform(RID p_body, int p_shape_idx, const Transform3D &p_transform) {
RigidBodyBullet *body = rigid_body_owner.getornull(p_body); RigidBodyBullet *body = rigid_body_owner.getornull(p_body);
ERR_FAIL_COND(!body); ERR_FAIL_COND(!body);
@ -527,9 +527,9 @@ RID BulletPhysicsServer3D::body_get_shape(RID p_body, int p_shape_idx) const {
return shape->get_self(); return shape->get_self();
} }
Transform BulletPhysicsServer3D::body_get_shape_transform(RID p_body, int p_shape_idx) const { Transform3D BulletPhysicsServer3D::body_get_shape_transform(RID p_body, int p_shape_idx) const {
RigidBodyBullet *body = rigid_body_owner.getornull(p_body); RigidBodyBullet *body = rigid_body_owner.getornull(p_body);
ERR_FAIL_COND_V(!body, Transform()); ERR_FAIL_COND_V(!body, Transform3D());
return body->get_shape_transform(p_shape_idx); return body->get_shape_transform(p_shape_idx);
} }
@ -842,7 +842,7 @@ PhysicsDirectBodyState3D *BulletPhysicsServer3D::body_get_direct_state(RID p_bod
return BulletPhysicsDirectBodyState3D::get_singleton(body); return BulletPhysicsDirectBodyState3D::get_singleton(body);
} }
bool BulletPhysicsServer3D::body_test_motion(RID p_body, const Transform &p_from, const Vector3 &p_motion, bool p_infinite_inertia, MotionResult *r_result, bool p_exclude_raycast_shapes) { bool BulletPhysicsServer3D::body_test_motion(RID p_body, const Transform3D &p_from, const Vector3 &p_motion, bool p_infinite_inertia, MotionResult *r_result, bool p_exclude_raycast_shapes) {
RigidBodyBullet *body = rigid_body_owner.getornull(p_body); RigidBodyBullet *body = rigid_body_owner.getornull(p_body);
ERR_FAIL_COND_V(!body, false); ERR_FAIL_COND_V(!body, false);
ERR_FAIL_COND_V(!body->get_space(), false); ERR_FAIL_COND_V(!body->get_space(), false);
@ -850,7 +850,7 @@ bool BulletPhysicsServer3D::body_test_motion(RID p_body, const Transform &p_from
return body->get_space()->test_body_motion(body, p_from, p_motion, p_infinite_inertia, r_result, p_exclude_raycast_shapes); return body->get_space()->test_body_motion(body, p_from, p_motion, p_infinite_inertia, r_result, p_exclude_raycast_shapes);
} }
int BulletPhysicsServer3D::body_test_ray_separation(RID p_body, const Transform &p_transform, bool p_infinite_inertia, Vector3 &r_recover_motion, SeparationResult *r_results, int p_result_max, real_t p_margin) { int BulletPhysicsServer3D::body_test_ray_separation(RID p_body, const Transform3D &p_transform, bool p_infinite_inertia, Vector3 &r_recover_motion, SeparationResult *r_results, int p_result_max, real_t p_margin) {
RigidBodyBullet *body = rigid_body_owner.getornull(p_body); RigidBodyBullet *body = rigid_body_owner.getornull(p_body);
ERR_FAIL_COND_V(!body, 0); ERR_FAIL_COND_V(!body, 0);
ERR_FAIL_COND_V(!body->get_space(), 0); ERR_FAIL_COND_V(!body->get_space(), 0);
@ -990,7 +990,7 @@ Variant BulletPhysicsServer3D::soft_body_get_state(RID p_body, BodyState p_state
return Variant(); return Variant();
} }
void BulletPhysicsServer3D::soft_body_set_transform(RID p_body, const Transform &p_transform) { void BulletPhysicsServer3D::soft_body_set_transform(RID p_body, const Transform3D &p_transform) {
SoftBodyBullet *body = soft_body_owner.getornull(p_body); SoftBodyBullet *body = soft_body_owner.getornull(p_body);
ERR_FAIL_COND(!body); ERR_FAIL_COND(!body);
@ -1205,7 +1205,7 @@ Vector3 BulletPhysicsServer3D::pin_joint_get_local_b(RID p_joint) const {
return pin_joint->getPivotInB(); return pin_joint->getPivotInB();
} }
RID BulletPhysicsServer3D::joint_create_hinge(RID p_body_A, const Transform &p_hinge_A, RID p_body_B, const Transform &p_hinge_B) { RID BulletPhysicsServer3D::joint_create_hinge(RID p_body_A, const Transform3D &p_hinge_A, RID p_body_B, const Transform3D &p_hinge_B) {
RigidBodyBullet *body_A = rigid_body_owner.getornull(p_body_A); RigidBodyBullet *body_A = rigid_body_owner.getornull(p_body_A);
ERR_FAIL_COND_V(!body_A, RID()); ERR_FAIL_COND_V(!body_A, RID());
JointAssertSpace(body_A, "A", RID()); JointAssertSpace(body_A, "A", RID());
@ -1277,7 +1277,7 @@ bool BulletPhysicsServer3D::hinge_joint_get_flag(RID p_joint, HingeJointFlag p_f
return hinge_joint->get_flag(p_flag); return hinge_joint->get_flag(p_flag);
} }
RID BulletPhysicsServer3D::joint_create_slider(RID p_body_A, const Transform &p_local_frame_A, RID p_body_B, const Transform &p_local_frame_B) { RID BulletPhysicsServer3D::joint_create_slider(RID p_body_A, const Transform3D &p_local_frame_A, RID p_body_B, const Transform3D &p_local_frame_B) {
RigidBodyBullet *body_A = rigid_body_owner.getornull(p_body_A); RigidBodyBullet *body_A = rigid_body_owner.getornull(p_body_A);
ERR_FAIL_COND_V(!body_A, RID()); ERR_FAIL_COND_V(!body_A, RID());
JointAssertSpace(body_A, "A", RID()); JointAssertSpace(body_A, "A", RID());
@ -1313,7 +1313,7 @@ real_t BulletPhysicsServer3D::slider_joint_get_param(RID p_joint, SliderJointPar
return slider_joint->get_param(p_param); return slider_joint->get_param(p_param);
} }
RID BulletPhysicsServer3D::joint_create_cone_twist(RID p_body_A, const Transform &p_local_frame_A, RID p_body_B, const Transform &p_local_frame_B) { RID BulletPhysicsServer3D::joint_create_cone_twist(RID p_body_A, const Transform3D &p_local_frame_A, RID p_body_B, const Transform3D &p_local_frame_B) {
RigidBodyBullet *body_A = rigid_body_owner.getornull(p_body_A); RigidBodyBullet *body_A = rigid_body_owner.getornull(p_body_A);
ERR_FAIL_COND_V(!body_A, RID()); ERR_FAIL_COND_V(!body_A, RID());
JointAssertSpace(body_A, "A", RID()); JointAssertSpace(body_A, "A", RID());
@ -1347,7 +1347,7 @@ real_t BulletPhysicsServer3D::cone_twist_joint_get_param(RID p_joint, ConeTwistJ
return coneTwist_joint->get_param(p_param); return coneTwist_joint->get_param(p_param);
} }
RID BulletPhysicsServer3D::joint_create_generic_6dof(RID p_body_A, const Transform &p_local_frame_A, RID p_body_B, const Transform &p_local_frame_B) { RID BulletPhysicsServer3D::joint_create_generic_6dof(RID p_body_A, const Transform3D &p_local_frame_A, RID p_body_B, const Transform3D &p_local_frame_B) {
RigidBodyBullet *body_A = rigid_body_owner.getornull(p_body_A); RigidBodyBullet *body_A = rigid_body_owner.getornull(p_body_A);
ERR_FAIL_COND_V(!body_A, RID()); ERR_FAIL_COND_V(!body_A, RID());
JointAssertSpace(body_A, "A", RID()); JointAssertSpace(body_A, "A", RID());

View File

@ -134,12 +134,12 @@ public:
virtual void area_set_space_override_mode(RID p_area, AreaSpaceOverrideMode p_mode) override; virtual void area_set_space_override_mode(RID p_area, AreaSpaceOverrideMode p_mode) override;
virtual AreaSpaceOverrideMode area_get_space_override_mode(RID p_area) const override; virtual AreaSpaceOverrideMode area_get_space_override_mode(RID p_area) const override;
virtual void area_add_shape(RID p_area, RID p_shape, const Transform &p_transform = Transform(), bool p_disabled = false) override; virtual void area_add_shape(RID p_area, RID p_shape, const Transform3D &p_transform = Transform3D(), bool p_disabled = false) override;
virtual void area_set_shape(RID p_area, int p_shape_idx, RID p_shape) override; virtual void area_set_shape(RID p_area, int p_shape_idx, RID p_shape) override;
virtual void area_set_shape_transform(RID p_area, int p_shape_idx, const Transform &p_transform) override; virtual void area_set_shape_transform(RID p_area, int p_shape_idx, const Transform3D &p_transform) override;
virtual int area_get_shape_count(RID p_area) const override; virtual int area_get_shape_count(RID p_area) const override;
virtual RID area_get_shape(RID p_area, int p_shape_idx) const override; virtual RID area_get_shape(RID p_area, int p_shape_idx) const override;
virtual Transform area_get_shape_transform(RID p_area, int p_shape_idx) const override; virtual Transform3D area_get_shape_transform(RID p_area, int p_shape_idx) const override;
virtual void area_remove_shape(RID p_area, int p_shape_idx) override; virtual void area_remove_shape(RID p_area, int p_shape_idx) override;
virtual void area_clear_shapes(RID p_area) override; virtual void area_clear_shapes(RID p_area) override;
virtual void area_set_shape_disabled(RID p_area, int p_shape_idx, bool p_disabled) override; virtual void area_set_shape_disabled(RID p_area, int p_shape_idx, bool p_disabled) override;
@ -153,8 +153,8 @@ public:
virtual void area_set_param(RID p_area, AreaParameter p_param, const Variant &p_value) override; virtual void area_set_param(RID p_area, AreaParameter p_param, const Variant &p_value) override;
virtual Variant area_get_param(RID p_area, AreaParameter p_param) const override; virtual Variant area_get_param(RID p_area, AreaParameter p_param) const override;
virtual void area_set_transform(RID p_area, const Transform &p_transform) override; virtual void area_set_transform(RID p_area, const Transform3D &p_transform) override;
virtual Transform area_get_transform(RID p_area) const override; virtual Transform3D area_get_transform(RID p_area) const override;
virtual void area_set_collision_mask(RID p_area, uint32_t p_mask) override; virtual void area_set_collision_mask(RID p_area, uint32_t p_mask) override;
virtual void area_set_collision_layer(RID p_area, uint32_t p_layer) override; virtual void area_set_collision_layer(RID p_area, uint32_t p_layer) override;
@ -174,14 +174,14 @@ public:
virtual void body_set_mode(RID p_body, BodyMode p_mode) override; virtual void body_set_mode(RID p_body, BodyMode p_mode) override;
virtual BodyMode body_get_mode(RID p_body) const override; virtual BodyMode body_get_mode(RID p_body) const override;
virtual void body_add_shape(RID p_body, RID p_shape, const Transform &p_transform = Transform(), bool p_disabled = false) override; virtual void body_add_shape(RID p_body, RID p_shape, const Transform3D &p_transform = Transform3D(), bool p_disabled = false) override;
// Not supported, Please remove and add new shape // Not supported, Please remove and add new shape
virtual void body_set_shape(RID p_body, int p_shape_idx, RID p_shape) override; virtual void body_set_shape(RID p_body, int p_shape_idx, RID p_shape) override;
virtual void body_set_shape_transform(RID p_body, int p_shape_idx, const Transform &p_transform) override; virtual void body_set_shape_transform(RID p_body, int p_shape_idx, const Transform3D &p_transform) override;
virtual int body_get_shape_count(RID p_body) const override; virtual int body_get_shape_count(RID p_body) const override;
virtual RID body_get_shape(RID p_body, int p_shape_idx) const override; virtual RID body_get_shape(RID p_body, int p_shape_idx) const override;
virtual Transform body_get_shape_transform(RID p_body, int p_shape_idx) const override; virtual Transform3D body_get_shape_transform(RID p_body, int p_shape_idx) const override;
virtual void body_set_shape_disabled(RID p_body, int p_shape_idx, bool p_disabled) override; virtual void body_set_shape_disabled(RID p_body, int p_shape_idx, bool p_disabled) override;
@ -253,8 +253,8 @@ public:
// this function only works on physics process, errors and returns null otherwise // this function only works on physics process, errors and returns null otherwise
virtual PhysicsDirectBodyState3D *body_get_direct_state(RID p_body) override; virtual PhysicsDirectBodyState3D *body_get_direct_state(RID p_body) override;
virtual bool body_test_motion(RID p_body, const Transform &p_from, const Vector3 &p_motion, bool p_infinite_inertia, MotionResult *r_result = nullptr, bool p_exclude_raycast_shapes = true) override; virtual bool body_test_motion(RID p_body, const Transform3D &p_from, const Vector3 &p_motion, bool p_infinite_inertia, MotionResult *r_result = nullptr, bool p_exclude_raycast_shapes = true) override;
virtual int body_test_ray_separation(RID p_body, const Transform &p_transform, bool p_infinite_inertia, Vector3 &r_recover_motion, SeparationResult *r_results, int p_result_max, real_t p_margin = 0.001) override; virtual int body_test_ray_separation(RID p_body, const Transform3D &p_transform, bool p_infinite_inertia, Vector3 &r_recover_motion, SeparationResult *r_results, int p_result_max, real_t p_margin = 0.001) override;
/* SOFT BODY API */ /* SOFT BODY API */
@ -283,7 +283,7 @@ public:
virtual Variant soft_body_get_state(RID p_body, BodyState p_state) const override; virtual Variant soft_body_get_state(RID p_body, BodyState p_state) const override;
/// Special function. This function has bad performance /// Special function. This function has bad performance
virtual void soft_body_set_transform(RID p_body, const Transform &p_transform) override; virtual void soft_body_set_transform(RID p_body, const Transform3D &p_transform) override;
virtual void soft_body_set_ray_pickable(RID p_body, bool p_enable) override; virtual void soft_body_set_ray_pickable(RID p_body, bool p_enable) override;
@ -333,7 +333,7 @@ public:
virtual void pin_joint_set_local_b(RID p_joint, const Vector3 &p_B) override; virtual void pin_joint_set_local_b(RID p_joint, const Vector3 &p_B) override;
virtual Vector3 pin_joint_get_local_b(RID p_joint) const override; virtual Vector3 pin_joint_get_local_b(RID p_joint) const override;
virtual RID joint_create_hinge(RID p_body_A, const Transform &p_hinge_A, RID p_body_B, const Transform &p_hinge_B) override; virtual RID joint_create_hinge(RID p_body_A, const Transform3D &p_hinge_A, RID p_body_B, const Transform3D &p_hinge_B) override;
virtual RID joint_create_hinge_simple(RID p_body_A, const Vector3 &p_pivot_A, const Vector3 &p_axis_A, RID p_body_B, const Vector3 &p_pivot_B, const Vector3 &p_axis_B) override; virtual RID joint_create_hinge_simple(RID p_body_A, const Vector3 &p_pivot_A, const Vector3 &p_axis_A, RID p_body_B, const Vector3 &p_pivot_B, const Vector3 &p_axis_B) override;
virtual void hinge_joint_set_param(RID p_joint, HingeJointParam p_param, real_t p_value) override; virtual void hinge_joint_set_param(RID p_joint, HingeJointParam p_param, real_t p_value) override;
@ -343,19 +343,19 @@ public:
virtual bool hinge_joint_get_flag(RID p_joint, HingeJointFlag p_flag) const override; virtual bool hinge_joint_get_flag(RID p_joint, HingeJointFlag p_flag) const override;
/// Reference frame is A /// Reference frame is A
virtual RID joint_create_slider(RID p_body_A, const Transform &p_local_frame_A, RID p_body_B, const Transform &p_local_frame_B) override; virtual RID joint_create_slider(RID p_body_A, const Transform3D &p_local_frame_A, RID p_body_B, const Transform3D &p_local_frame_B) override;
virtual void slider_joint_set_param(RID p_joint, SliderJointParam p_param, real_t p_value) override; virtual void slider_joint_set_param(RID p_joint, SliderJointParam p_param, real_t p_value) override;
virtual real_t slider_joint_get_param(RID p_joint, SliderJointParam p_param) const override; virtual real_t slider_joint_get_param(RID p_joint, SliderJointParam p_param) const override;
/// Reference frame is A /// Reference frame is A
virtual RID joint_create_cone_twist(RID p_body_A, const Transform &p_local_frame_A, RID p_body_B, const Transform &p_local_frame_B) override; virtual RID joint_create_cone_twist(RID p_body_A, const Transform3D &p_local_frame_A, RID p_body_B, const Transform3D &p_local_frame_B) override;
virtual void cone_twist_joint_set_param(RID p_joint, ConeTwistJointParam p_param, real_t p_value) override; virtual void cone_twist_joint_set_param(RID p_joint, ConeTwistJointParam p_param, real_t p_value) override;
virtual real_t cone_twist_joint_get_param(RID p_joint, ConeTwistJointParam p_param) const override; virtual real_t cone_twist_joint_get_param(RID p_joint, ConeTwistJointParam p_param) const override;
/// Reference frame is A /// Reference frame is A
virtual RID joint_create_generic_6dof(RID p_body_A, const Transform &p_local_frame_A, RID p_body_B, const Transform &p_local_frame_B) override; virtual RID joint_create_generic_6dof(RID p_body_A, const Transform3D &p_local_frame_A, RID p_body_B, const Transform3D &p_local_frame_B) override;
virtual void generic_6dof_joint_set_param(RID p_joint, Vector3::Axis p_axis, G6DOFJointAxisParam p_param, real_t p_value) override; virtual void generic_6dof_joint_set_param(RID p_joint, Vector3::Axis p_axis, G6DOFJointAxisParam p_param, real_t p_value) override;
virtual real_t generic_6dof_joint_get_param(RID p_joint, Vector3::Axis p_axis, G6DOFJointAxisParam p_param) override; virtual real_t generic_6dof_joint_get_param(RID p_joint, Vector3::Axis p_axis, G6DOFJointAxisParam p_param) override;

View File

@ -59,7 +59,7 @@ void INVERT_B_TO_G(btMatrix3x3 const &inVal, Basis &outVal) {
INVERT_B_TO_G(inVal[2], outVal[2]); INVERT_B_TO_G(inVal[2], outVal[2]);
} }
void B_TO_G(btTransform const &inVal, Transform &outVal) { void B_TO_G(btTransform const &inVal, Transform3D &outVal) {
B_TO_G(inVal.getBasis(), outVal.basis); B_TO_G(inVal.getBasis(), outVal.basis);
B_TO_G(inVal.getOrigin(), outVal.origin); B_TO_G(inVal.getOrigin(), outVal.origin);
} }
@ -89,7 +89,7 @@ void INVERT_G_TO_B(Basis const &inVal, btMatrix3x3 &outVal) {
INVERT_G_TO_B(inVal[2], outVal[2]); INVERT_G_TO_B(inVal[2], outVal[2]);
} }
void G_TO_B(Transform const &inVal, btTransform &outVal) { void G_TO_B(Transform3D const &inVal, btTransform &outVal) {
G_TO_B(inVal.basis, outVal.getBasis()); G_TO_B(inVal.basis, outVal.getBasis());
G_TO_B(inVal.origin, outVal.getOrigin()); G_TO_B(inVal.origin, outVal.getOrigin());
} }

View File

@ -32,7 +32,7 @@
#define BULLET_TYPES_CONVERTER_H #define BULLET_TYPES_CONVERTER_H
#include "core/math/basis.h" #include "core/math/basis.h"
#include "core/math/transform.h" #include "core/math/transform_3d.h"
#include "core/math/vector3.h" #include "core/math/vector3.h"
#include "core/typedefs.h" #include "core/typedefs.h"
@ -49,14 +49,14 @@ extern void B_TO_G(btVector3 const &inVal, Vector3 &outVal);
extern void INVERT_B_TO_G(btVector3 const &inVal, Vector3 &outVal); extern void INVERT_B_TO_G(btVector3 const &inVal, Vector3 &outVal);
extern void B_TO_G(btMatrix3x3 const &inVal, Basis &outVal); extern void B_TO_G(btMatrix3x3 const &inVal, Basis &outVal);
extern void INVERT_B_TO_G(btMatrix3x3 const &inVal, Basis &outVal); extern void INVERT_B_TO_G(btMatrix3x3 const &inVal, Basis &outVal);
extern void B_TO_G(btTransform const &inVal, Transform &outVal); extern void B_TO_G(btTransform const &inVal, Transform3D &outVal);
// Godot TO Bullet // Godot TO Bullet
extern void G_TO_B(Vector3 const &inVal, btVector3 &outVal); extern void G_TO_B(Vector3 const &inVal, btVector3 &outVal);
extern void INVERT_G_TO_B(Vector3 const &inVal, btVector3 &outVal); extern void INVERT_G_TO_B(Vector3 const &inVal, btVector3 &outVal);
extern void G_TO_B(Basis const &inVal, btMatrix3x3 &outVal); extern void G_TO_B(Basis const &inVal, btMatrix3x3 &outVal);
extern void INVERT_G_TO_B(Basis const &inVal, btMatrix3x3 &outVal); extern void INVERT_G_TO_B(Basis const &inVal, btMatrix3x3 &outVal);
extern void G_TO_B(Transform const &inVal, btTransform &outVal); extern void G_TO_B(Transform3D const &inVal, btTransform &outVal);
extern void UNSCALE_BT_BASIS(btTransform &scaledBasis); extern void UNSCALE_BT_BASIS(btTransform &scaledBasis);
#endif #endif

Some files were not shown because too many files have changed in this diff Show More