2023-05-23 19:01:39 +02:00
|
|
|
/*************************************************************************/
|
|
|
|
/* Vector3.cpp */
|
|
|
|
/*************************************************************************/
|
|
|
|
/* This file is part of: */
|
2023-10-23 14:07:57 +02:00
|
|
|
/* PANDEMONIUM ENGINE */
|
|
|
|
/* https://pandemoniumengine.org */
|
2023-05-23 19:01:39 +02:00
|
|
|
/*************************************************************************/
|
|
|
|
/* Copyright (c) 2007-2022 Juan Linietsky, Ariel Manzur. */
|
2023-10-23 14:07:57 +02:00
|
|
|
/* Copyright (c) 2014-2022 Pandemonium Engine contributors (cf. AUTHORS.md). */
|
2023-05-23 19:01:39 +02:00
|
|
|
/* */
|
|
|
|
/* Permission is hereby granted, free of charge, to any person obtaining */
|
|
|
|
/* a copy of this software and associated documentation files (the */
|
|
|
|
/* "Software"), to deal in the Software without restriction, including */
|
|
|
|
/* without limitation the rights to use, copy, modify, merge, publish, */
|
|
|
|
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
|
|
|
/* permit persons to whom the Software is furnished to do so, subject to */
|
|
|
|
/* the following conditions: */
|
|
|
|
/* */
|
|
|
|
/* The above copyright notice and this permission notice shall be */
|
|
|
|
/* included in all copies or substantial portions of the Software. */
|
|
|
|
/* */
|
|
|
|
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
|
|
|
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
|
|
|
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
|
|
|
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
|
|
|
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
|
|
|
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
|
|
|
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
|
|
|
/*************************************************************************/
|
|
|
|
|
2023-10-23 14:41:55 +02:00
|
|
|
#include "vector3.h"
|
2023-05-23 19:01:39 +02:00
|
|
|
|
2023-10-23 14:41:55 +02:00
|
|
|
#include "ustring.h"
|
2023-05-23 19:01:39 +02:00
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
2023-10-23 14:41:55 +02:00
|
|
|
#include "basis.h"
|
2023-05-23 19:01:39 +02:00
|
|
|
|
2023-10-23 17:11:10 +02:00
|
|
|
|
2023-05-23 19:01:39 +02:00
|
|
|
|
|
|
|
const Vector3 Vector3::ZERO = Vector3();
|
|
|
|
const Vector3 Vector3::ONE = Vector3(1, 1, 1);
|
|
|
|
const Vector3 Vector3::INF = Vector3(INFINITY, INFINITY, INFINITY);
|
|
|
|
|
|
|
|
const Vector3 Vector3::LEFT = Vector3(-1, 0, 0);
|
|
|
|
const Vector3 Vector3::RIGHT = Vector3(1, 0, 0);
|
|
|
|
const Vector3 Vector3::UP = Vector3(0, 1, 0);
|
|
|
|
const Vector3 Vector3::DOWN = Vector3(0, -1, 0);
|
|
|
|
const Vector3 Vector3::FORWARD = Vector3(0, 0, -1);
|
|
|
|
const Vector3 Vector3::BACK = Vector3(0, 0, 1);
|
|
|
|
|
|
|
|
bool Vector3::operator<(const Vector3 &p_v) const {
|
|
|
|
if (x == p_v.x) {
|
|
|
|
if (y == p_v.y)
|
|
|
|
return z < p_v.z;
|
|
|
|
else
|
|
|
|
return y < p_v.y;
|
|
|
|
} else {
|
|
|
|
return x < p_v.x;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Vector3::operator<=(const Vector3 &p_v) const {
|
|
|
|
if (x == p_v.x) {
|
|
|
|
if (y == p_v.y)
|
|
|
|
return z <= p_v.z;
|
|
|
|
else
|
|
|
|
return y < p_v.y;
|
|
|
|
} else {
|
|
|
|
return x < p_v.x;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Vector3 Vector3::cubic_interpolate(const Vector3 &b, const Vector3 &pre_a, const Vector3 &post_b, const real_t t) const {
|
|
|
|
Vector3 p0 = pre_a;
|
|
|
|
Vector3 p1 = *this;
|
|
|
|
Vector3 p2 = b;
|
|
|
|
Vector3 p3 = post_b;
|
|
|
|
|
|
|
|
real_t t2 = t * t;
|
|
|
|
real_t t3 = t2 * t;
|
|
|
|
|
|
|
|
Vector3 out;
|
|
|
|
out = ((p1 * 2.0) +
|
|
|
|
(-p0 + p2) * t +
|
|
|
|
(p0 * 2.0 - p1 * 5.0 + p2 * 4 - p3) * t2 +
|
|
|
|
(-p0 + p1 * 3.0 - p2 * 3.0 + p3) * t3) *
|
|
|
|
0.5;
|
|
|
|
return out;
|
|
|
|
}
|
|
|
|
|
|
|
|
Basis Vector3::outer(const Vector3 &b) const {
|
|
|
|
Vector3 row0(x * b.x, x * b.y, x * b.z);
|
|
|
|
Vector3 row1(y * b.x, y * b.y, y * b.z);
|
|
|
|
Vector3 row2(z * b.x, z * b.y, z * b.z);
|
|
|
|
return Basis(row0, row1, row2);
|
|
|
|
}
|
|
|
|
|
|
|
|
int Vector3::max_axis() const {
|
|
|
|
return x < y ? (y < z ? 2 : 1) : (x < z ? 2 : 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
int Vector3::min_axis() const {
|
|
|
|
return x < y ? (x < z ? 0 : 2) : (y < z ? 1 : 2);
|
|
|
|
}
|
|
|
|
|
|
|
|
void Vector3::rotate(const Vector3 &p_axis, real_t p_phi) {
|
|
|
|
*this = Basis(p_axis, p_phi).xform(*this);
|
|
|
|
}
|
|
|
|
|
|
|
|
void Vector3::snap(real_t p_val) {
|
2023-10-23 19:18:50 +02:00
|
|
|
x = Math::stepify(x, p_val);
|
|
|
|
y = Math::stepify(y, p_val);
|
|
|
|
z = Math::stepify(z, p_val);
|
2023-05-23 19:01:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
Vector3::operator String() const {
|
|
|
|
return String::num(x) + ", " + String::num(y) + ", " + String::num(z);
|
|
|
|
}
|
|
|
|
|
2023-10-23 17:11:10 +02:00
|
|
|
|