diff options
author | Joshua Rowe <17525998+omnisci3nce@users.noreply.github.com> | 2024-03-14 22:08:43 +1100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-03-14 22:08:43 +1100 |
commit | 70308798adbaa376da97c9c0739d437fe76b8b36 (patch) | |
tree | 09836fab6ddc9012a5f4437f2139ab0a704b3a78 /src/maths/maths.h | |
parent | a627f75cc956a463e3910a8f5f615932bad3a418 (diff) | |
parent | b240374c23365e33727d78ca74e901bcb383e077 (diff) |
Merge pull request #5 from omnisci3nce/cel-41-port-over-a-basic-3d-scene-example
CEL 41 port over a basic 3d scene example
Diffstat (limited to 'src/maths/maths.h')
-rw-r--r-- | src/maths/maths.h | 40 |
1 files changed, 38 insertions, 2 deletions
diff --git a/src/maths/maths.h b/src/maths/maths.h index 7352aeb..d832739 100644 --- a/src/maths/maths.h +++ b/src/maths/maths.h @@ -11,10 +11,16 @@ #include <math.h> #include "maths_types.h" +// --- Helpers +#define deg_to_rad(x) (x * 3.14 / 180.0) +#define min(a, b) (a < b ? a : b) +#define max(a, b) (a > b ? a : b) + // --- Vector Implementations // Dimension 3 static inline vec3 vec3_create(f32 x, f32 y, f32 z) { return (vec3){ x, y, z }; } +#define vec3(x, y, z) (vec3_create(x, y, z)) static inline vec3 vec3_add(vec3 a, vec3 b) { return (vec3){ a.x + b.x, a.y + b.y, a.z + b.z }; } static inline vec3 vec3_sub(vec3 a, vec3 b) { return (vec3){ a.x - b.x, a.y - b.y, a.z - b.z }; } static inline vec3 vec3_mult(vec3 a, f32 s) { return (vec3){ a.x * s, a.y * s, a.z * s }; } @@ -48,6 +54,18 @@ static inline vec2 vec2_create(f32 x, f32 y) { return (vec2){ x, y }; } // TODO: Dimension 4 #define VEC4_ZERO ((vec4){ .x = 0.0, .y = 0.0, .z = 0.0, .w = 0.0 }) +// --- Quaternion Implementations + +static inline f32 quat_dot(quat a, quat b) { return a.x * b.x + a.y * b.y + a.z * b.z + a.w * b.w; } + +static inline quat quat_normalise(quat a) { + f32 length = sqrtf(quat_dot(a, a) // same as len squared + ); + return (quat){ a.x / length, a.y / length, a.z / length, a.w / length }; +} + +static inline quat quat_ident() { return (quat){ .x = 0.0, .y = 0.0, .z = 0.0, .w = 1.0 }; } + // --- Matrix Implementations static inline mat4 mat4_ident() { @@ -70,6 +88,26 @@ static inline mat4 mat4_scale(f32 scale) { return out_matrix; } +// TODO: double check this +static inline mat4 mat4_rotation(quat rotation) { + mat4 out_matrix = mat4_ident(); + quat n = quat_normalise(rotation); + + out_matrix.data[0] = 1.0f - 2.0f * n.y * n.y - 2.0f * n.z * n.z; + out_matrix.data[1] = 2.0f * n.x * n.y - 2.0f * n.z * n.w; + out_matrix.data[2] = 2.0f * n.x * n.z + 2.0f * n.y * n.w; + + out_matrix.data[4] = 2.0f * n.x * n.y + 2.0f * n.z * n.w; + out_matrix.data[5] = 1.0f - 2.0f * n.x * n.x - 2.0f * n.z * n.z; + out_matrix.data[6] = 2.0f * n.y * n.z - 2.0f * n.x * n.w; + + out_matrix.data[8] = 2.0f * n.x * n.z - 2.0f * n.y * n.w; + out_matrix.data[9] = 2.0f * n.y * n.z + 2.0f * n.x * n.w; + out_matrix.data[10] = 1.0f - 2.0f * n.x * n.x - 2.0f * n.y * n.y; + + return out_matrix; +} + static inline mat4 mat4_mult(mat4 lhs, mat4 rhs) { mat4 out_matrix = mat4_ident(); @@ -156,8 +194,6 @@ static inline mat4 mat4_look_at(vec3 position, vec3 target, vec3 up) { // ... -// --- Quaternion Implementations - // --- Transform Implementations #define TRANSFORM_DEFAULT \ |