瀏覽代碼

Merge pull request #17254 from Chaosus/updatewrap

Update wrap functions
Rémi Verschelde 7 年之前
父節點
當前提交
b4da44981a
共有 2 個文件被更改,包括 12 次插入17 次删除
  1. 0 15
      core/math/math_funcs.cpp
  2. 12 2
      core/math/math_funcs.h

+ 0 - 15
core/math/math_funcs.cpp

@@ -177,18 +177,3 @@ float Math::random(float from, float to) {
 	float ret = (float)r / (float)RANDOM_MAX;
 	return (ret) * (to - from) + from;
 }
-
-int Math::wrapi(int value, int min, int max) {
-	--max;
-	int rng = max - min + 1;
-	value = ((value - min) % rng);
-	if (value < 0)
-		return max + 1 + value;
-	else
-		return min + value;
-}
-
-float Math::wrapf(float value, float min, float max) {
-	float rng = max - min;
-	return min + (value - min) - (rng * floor((value - min) / rng));
-}

+ 12 - 2
core/math/math_funcs.h

@@ -209,8 +209,18 @@ public:
 	static _ALWAYS_INLINE_ double round(double p_val) { return (p_val >= 0) ? Math::floor(p_val + 0.5) : -Math::floor(-p_val + 0.5); }
 	static _ALWAYS_INLINE_ float round(float p_val) { return (p_val >= 0) ? Math::floor(p_val + 0.5) : -Math::floor(-p_val + 0.5); }
 
-	static int wrapi(int value, int min, int max);
-	static float wrapf(float value, float min, float max);
+	static _ALWAYS_INLINE_ int wrapi(int value, int min, int max) {
+		int rng = max - min;
+		return min + ((((value - min) % rng) + rng) % rng);
+	}
+	static _ALWAYS_INLINE_ double wrapf(double value, double min, double max) {
+		double rng = max - min;
+		return min + (value - min) - (rng * Math::floor((value - min) / rng));
+	}
+	static _ALWAYS_INLINE_ float wrapf(float value, float min, float max) {
+		float rng = max - min;
+		return min + (value - min) - (rng * Math::floor((value - min) / rng));
+	}
 
 	// double only, as these functions are mainly used by the editor and not performance-critical,
 	static double ease(double p_x, double p_c);