mirror of
https://github.com/whoahq/whoa.git
synced 2026-03-18 05:31:07 +03:00
Some checks failed
Push / ${{ matrix.build.system_name }} / ${{ matrix.build.build_type }} / ${{ matrix.build.compiler_name }} (map[build_type:Release cc:cl compiler_name:MSVC cxx:cl os:windows-latest system_name:Windows test_path:WhoaTest]) (push) Has been cancelled
Push / ${{ matrix.build.system_name }} / ${{ matrix.build.build_type }} / ${{ matrix.build.compiler_name }} (map[build_type:Release cc:clang compiler_name:Clang cxx:clang++ os:macos-latest system_name:macOS test_path:WhoaTest]) (push) Has been cancelled
Push / ${{ matrix.build.system_name }} / ${{ matrix.build.build_type }} / ${{ matrix.build.compiler_name }} (map[build_type:Release cc:gcc compiler_name:GCC cxx:g++ os:ubuntu-latest system_name:Linux test_path:WhoaTest]) (push) Has been cancelled
113 lines
2.5 KiB
C++
113 lines
2.5 KiB
C++
#include "ui/simple/CSimpleCamera.hpp"
|
|
#include "model/Model2.hpp"
|
|
#include <tempest/Math.hpp>
|
|
|
|
namespace {
|
|
|
|
void FaceDirection(const C3Vector& direction, C3Vector& xPrime, C3Vector& yPrime, C3Vector& zPrime) {
|
|
STORM_ASSERT(CMath::fnotequal(direction.SquaredMag(), 0.0f));
|
|
|
|
// Forward
|
|
xPrime = direction;
|
|
|
|
// Right
|
|
if (CMath::fequal(xPrime.SquaredMag(), 0.0f)) {
|
|
yPrime.x = 1.0f;
|
|
yPrime.y = 0.0f;
|
|
yPrime.z = 0.0f;
|
|
} else {
|
|
yPrime.x = -xPrime.y;
|
|
yPrime.y = xPrime.x;
|
|
yPrime.z = 0.0f;
|
|
|
|
CMath::normalize(yPrime.x, yPrime.y);
|
|
}
|
|
|
|
// Up (Forward cross Right)
|
|
zPrime = C3Vector::Cross(xPrime, yPrime);
|
|
}
|
|
|
|
void BuildBillboardMatrix(const C3Vector& direction, C33Matrix& rotation) {
|
|
C3Vector xPrime = {};
|
|
C3Vector yPrime = {};
|
|
C3Vector zPrime = {};
|
|
|
|
FaceDirection(direction, xPrime, yPrime, zPrime);
|
|
|
|
// Forward
|
|
rotation.a0 = xPrime.x;
|
|
rotation.a1 = xPrime.y;
|
|
rotation.a2 = xPrime.z;
|
|
|
|
// Right
|
|
rotation.b0 = yPrime.x;
|
|
rotation.b1 = yPrime.y;
|
|
rotation.b2 = yPrime.z;
|
|
|
|
// Up
|
|
rotation.c0 = zPrime.x;
|
|
rotation.c1 = zPrime.y;
|
|
rotation.c2 = zPrime.z;
|
|
}
|
|
|
|
}
|
|
|
|
CSimpleCamera::CSimpleCamera(float nearZ, float farZ, float fov) {
|
|
this->m_scene = nullptr;
|
|
|
|
this->m_nearZ = nearZ;
|
|
this->m_farZ = farZ;
|
|
this->m_fov = fov;
|
|
this->m_aspect = 1.0f;
|
|
|
|
this->SetFacing(0.0f, 0.0f, 0.0f);
|
|
}
|
|
|
|
float CSimpleCamera::FOV() {
|
|
return this->m_fov;
|
|
}
|
|
|
|
C3Vector CSimpleCamera::Forward() const {
|
|
return { this->m_facing.a0, this->m_facing.a1, this->m_facing.a2 };
|
|
}
|
|
|
|
CM2Scene* CSimpleCamera::GetScene() {
|
|
if (!this->m_scene) {
|
|
this->m_scene = M2CreateScene();
|
|
}
|
|
|
|
return this->m_scene;
|
|
}
|
|
|
|
C3Vector CSimpleCamera::Right() const {
|
|
return { this->m_facing.b0, this->m_facing.b1, this->m_facing.b2 };
|
|
}
|
|
|
|
void CSimpleCamera::SetFacing(const C3Vector& forward) {
|
|
BuildBillboardMatrix(forward, this->m_facing);
|
|
}
|
|
|
|
void CSimpleCamera::SetFacing(const C3Vector& forward, const C3Vector& up) {
|
|
// TODO
|
|
}
|
|
|
|
void CSimpleCamera::SetFacing(float yaw, float pitch, float roll) {
|
|
this->m_facing.FromEulerAnglesZYX(yaw, pitch, roll);
|
|
}
|
|
|
|
void CSimpleCamera::SetFarZ(float farZ) {
|
|
this->m_farZ = farZ;
|
|
}
|
|
|
|
void CSimpleCamera::SetFieldOfView(float fov) {
|
|
this->m_fov = fov;
|
|
}
|
|
|
|
void CSimpleCamera::SetNearZ(float nearZ) {
|
|
this->m_nearZ = nearZ;
|
|
}
|
|
|
|
C3Vector CSimpleCamera::Up() const {
|
|
return { this->m_facing.c0, this->m_facing.c1, this->m_facing.c2 };
|
|
}
|