summaryrefslogtreecommitdiff
path: root/source/math.h
diff options
context:
space:
mode:
authortalha <sarcxd@gmail.com>2024-10-19 17:32:47 +0500
committertalha <sarcxd@gmail.com>2024-10-19 17:32:47 +0500
commit35d3384f9b6ba6786a2e12a729865836d96cee71 (patch)
tree99ff9dd18becd9524dd3ef984a1bb4e10042a177 /source/math.h
parent7c0ca92da0d2d0fd7e7f4da957ef7d1ea9f15e41 (diff)
Motion+Collision now work:
- Collisions are checked for each side, to let us know how to proceed - Equations of motion seem to work fine, except that they don't play well with time_delta, and are framerate dependant.
Diffstat (limited to 'source/math.h')
-rwxr-xr-xsource/math.h46
1 files changed, 42 insertions, 4 deletions
diff --git a/source/math.h b/source/math.h
index cf04d54..04ef63c 100755
--- a/source/math.h
+++ b/source/math.h
@@ -2,10 +2,11 @@
#define MATH_H
#define PI 3.14159265358979323846264338327950288f
-#define Square(x) ((x)*(x))
-#define To_Radian(x) ((x) * PI / 180.0f)
-#define To_Degree(x) ((x) * 180.0f / PI)
+#define SQUARE(x) ((x)*(x))
+#define TO_RAD(x) ((x) * PI / 180.0f)
+#define TO_DEG(x) ((x) * 180.0f / PI)
#define ABS(x) ((x) < 0 ? (-(x)) : (x))
+#define MIN(x,y) ((x) < (y) ? (y) : (x))
// @todo:
// - convert these to column major calculations for the opengl path
@@ -49,8 +50,26 @@ union Vec2 {
return res;
}
+
+ Vec2 operator-(const r32& scaler) const {
+ Vec2 res;
+ res.x = this->x - scaler;
+ res.y = this->y - scaler;
+
+ return res;
+ }
+
+ Vec2 operator-(const Vec2& v) const {
+ Vec2 res;
+ res.x = this->x - v.x;
+ res.y = this->y - v.y;
+
+ return res;
+ }
};
+#define V3TOV2(v) (Vec2{((v).x), ((v).y)})
+
union Vec3 {
struct {
r32 x;
@@ -78,6 +97,12 @@ union Mat4 {
// ==== Vec2 ====
+r32 dot2v(Vec2 a, Vec2 b)
+{
+ r32 res = (a.x*b.x)+(a.y*b.y);
+ return res;
+}
+
Vec2 mul2vf(Vec2 vec, r32 scaler)
{
Vec2 res;
@@ -97,6 +122,19 @@ Vec2 div2vf(Vec2 vec, r32 scaler)
return res;
}
+r32 magnitude2v(Vec2 v)
+{
+ r32 res = sqrtf(SQUARE(v.x) + SQUARE(v.y));
+ return res;
+}
+
+Vec2 normalize2v(Vec2 v)
+{
+ r32 magnitude = magnitude2v(v);
+ Vec2 res = div2vf(v, magnitude);
+ return res;
+}
+
// ========================================================== Vec3 ==========================================================
Vec3 init3v(r32 x, r32 y, r32 z)
@@ -173,7 +211,7 @@ r32 dot_multiply3v(Vec3 a, Vec3 b)
r32 magnitude3v(Vec3 vec)
{
- r32 res = sqrtf(Square(vec.x) + Square(vec.y) + Square(vec.z));
+ r32 res = sqrtf(SQUARE(vec.x) + SQUARE(vec.y) + SQUARE(vec.z));
return res;
}