Add some useful lerp lib functions made use of in the polytrails branch and in mods
authorMario <mario.mario@y7mail.com>
Sat, 30 May 2020 09:51:00 +0000 (19:51 +1000)
committerMario <mario.mario@y7mail.com>
Sat, 30 May 2020 09:51:00 +0000 (19:51 +1000)
qcsrc/lib/math.qh

index d8f1990..ac23325 100644 (file)
@@ -72,6 +72,39 @@ vector vsnap(vector point, float fsize)
 }
 
 ERASEABLE
+float lerpratio(float f0, float f1, float ratio)
+{
+       return f0 * (1 - ratio) + f1 * ratio;
+}
+
+ERASEABLE
+float lerp(float t0, float f0, float t1, float f1, float t)
+{
+       return lerpratio(f0, f1, (t - t0) / (t1 - t0));
+}
+
+ERASEABLE
+float lerp3ratio(float f0, float f1, float f2, float ratio)
+{
+       float mid = 0.5;
+       return ratio < mid ? lerpratio(f0, f1, ratio / mid) : ratio > mid ? lerpratio(f1, f2, (ratio - mid) / mid) : f1;
+}
+
+
+ERASEABLE
+vector lerpvratio(vector f0, vector f1, float ratio)
+{
+       return f0 * (1 - ratio) + f1 * ratio;
+}
+
+ERASEABLE
+vector lerpv3ratio(vector f0, vector f1, vector f2, float ratio)
+{
+       float mid = 0.5;
+       return ratio < mid ? lerpvratio(f0, f1, ratio / mid) : ratio > mid ? lerpvratio(f1, f2, (ratio - mid) / mid) : f1;
+}
+
+ERASEABLE
 vector lerpv(float t0, vector v0, float t1, vector v1, float t)
 {
        return v0 + (v1 - v0) * ((t - t0) / (t1 - t0));