@ls-stack/utils 1.6.0 → 1.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/interpolate.d.ts +1 -1
- package/dist/interpolate.js +13 -6
- package/dist/interpolate.js.map +1 -1
- package/package.json +1 -1
package/dist/interpolate.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
type Interval = [number, number];
|
|
2
2
|
declare function cyclicLerp(input: number, [inStart, inEnd]: Interval, [outStart, outEnd]: Interval): number;
|
|
3
|
-
declare function interpolate(input: number, inputRange: number[], outputRange: number[], clamp?: boolean): number;
|
|
3
|
+
declare function interpolate(input: number, inputRange: number[], outputRange: number[], clamp?: boolean | 'start' | 'end'): number;
|
|
4
4
|
|
|
5
5
|
export { cyclicLerp, interpolate };
|
package/dist/interpolate.js
CHANGED
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import {
|
|
2
|
+
clampMax,
|
|
3
|
+
clampMin,
|
|
2
4
|
clampRange
|
|
3
5
|
} from "./chunk-NKCC3375.js";
|
|
4
6
|
import {
|
|
5
|
-
|
|
7
|
+
invariant
|
|
6
8
|
} from "./chunk-JT3EBBCA.js";
|
|
7
9
|
|
|
8
10
|
// src/interpolate.ts
|
|
@@ -20,13 +22,18 @@ function findRange(input, inputRange) {
|
|
|
20
22
|
return inputRange.length - 2;
|
|
21
23
|
}
|
|
22
24
|
function interpolate(input, inputRange, outputRange, clamp = true) {
|
|
25
|
+
invariant(
|
|
26
|
+
inputRange.length === outputRange.length,
|
|
27
|
+
"Ranges must have the same length"
|
|
28
|
+
);
|
|
23
29
|
const range = findRange(input, inputRange);
|
|
24
|
-
const inStart =
|
|
25
|
-
const inEnd =
|
|
26
|
-
const outStart =
|
|
27
|
-
const outEnd =
|
|
30
|
+
const inStart = inputRange[range];
|
|
31
|
+
const inEnd = inputRange[range + 1];
|
|
32
|
+
const outStart = outputRange[range];
|
|
33
|
+
const outEnd = outputRange[range + 1];
|
|
28
34
|
const interpolatedValue = (input - inStart) / (inEnd - inStart) * (outEnd - outStart) + outStart;
|
|
29
|
-
|
|
35
|
+
const outputIsAscending = outStart < outEnd;
|
|
36
|
+
return clamp === "start" ? outputIsAscending ? clampMin(interpolatedValue, outStart) : clampMax(interpolatedValue, outStart) : clamp === "end" ? outputIsAscending ? clampMax(interpolatedValue, outEnd) : clampMin(interpolatedValue, outEnd) : clamp ? clampRange(interpolatedValue, outStart, outEnd) : interpolatedValue;
|
|
30
37
|
}
|
|
31
38
|
export {
|
|
32
39
|
cyclicLerp,
|
package/dist/interpolate.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/interpolate.ts"],"sourcesContent":["import {
|
|
1
|
+
{"version":3,"sources":["../src/interpolate.ts"],"sourcesContent":["import { invariant } from './assertions';\nimport { clampMax, clampMin, clampRange } from './mathUtils';\n\ntype Interval = [number, number];\n\nfunction mod(n: number, m: number) {\n return ((n % m) + m) % m;\n}\n\nexport function cyclicLerp(\n input: number,\n [inStart, inEnd]: Interval,\n [outStart, outEnd]: Interval,\n) {\n return (\n mod((input - inStart) / (inEnd - inStart), 1) * (outEnd - outStart) +\n outStart\n );\n}\n\nfunction findRange(input: number, inputRange: number[]) {\n for (let i = 1; i < inputRange.length - 1; i++) {\n if (inputRange[i]! >= input) return i - 1;\n }\n\n return inputRange.length - 2;\n}\n\nexport function interpolate(\n input: number,\n inputRange: number[],\n outputRange: number[],\n clamp: boolean | 'start' | 'end' = true,\n) {\n invariant(\n inputRange.length === outputRange.length,\n 'Ranges must have the same length',\n );\n\n const range = findRange(input, inputRange);\n const inStart = inputRange[range]!;\n const inEnd = inputRange[range + 1]!;\n const outStart = outputRange[range]!;\n const outEnd = outputRange[range + 1]!;\n\n const interpolatedValue =\n ((input - inStart) / (inEnd - inStart)) * (outEnd - outStart) + outStart;\n\n const outputIsAscending = outStart < outEnd;\n\n return (\n clamp === 'start' ?\n outputIsAscending ? clampMin(interpolatedValue, outStart)\n : clampMax(interpolatedValue, outStart)\n : clamp === 'end' ?\n outputIsAscending ? clampMax(interpolatedValue, outEnd)\n : clampMin(interpolatedValue, outEnd)\n : clamp ? clampRange(interpolatedValue, outStart, outEnd)\n : interpolatedValue\n );\n}\n"],"mappings":";;;;;;;;;;AAKA,SAAS,IAAI,GAAW,GAAW;AACjC,UAAS,IAAI,IAAK,KAAK;AACzB;AAEO,SAAS,WACd,OACA,CAAC,SAAS,KAAK,GACf,CAAC,UAAU,MAAM,GACjB;AACA,SACE,KAAK,QAAQ,YAAY,QAAQ,UAAU,CAAC,KAAK,SAAS,YAC1D;AAEJ;AAEA,SAAS,UAAU,OAAe,YAAsB;AACtD,WAAS,IAAI,GAAG,IAAI,WAAW,SAAS,GAAG,KAAK;AAC9C,QAAI,WAAW,CAAC,KAAM;AAAO,aAAO,IAAI;AAAA,EAC1C;AAEA,SAAO,WAAW,SAAS;AAC7B;AAEO,SAAS,YACd,OACA,YACA,aACA,QAAmC,MACnC;AACA;AAAA,IACE,WAAW,WAAW,YAAY;AAAA,IAClC;AAAA,EACF;AAEA,QAAM,QAAQ,UAAU,OAAO,UAAU;AACzC,QAAM,UAAU,WAAW,KAAK;AAChC,QAAM,QAAQ,WAAW,QAAQ,CAAC;AAClC,QAAM,WAAW,YAAY,KAAK;AAClC,QAAM,SAAS,YAAY,QAAQ,CAAC;AAEpC,QAAM,qBACF,QAAQ,YAAY,QAAQ,YAAa,SAAS,YAAY;AAElE,QAAM,oBAAoB,WAAW;AAErC,SACE,UAAU,UACR,oBAAoB,SAAS,mBAAmB,QAAQ,IACtD,SAAS,mBAAmB,QAAQ,IACtC,UAAU,QACV,oBAAoB,SAAS,mBAAmB,MAAM,IACpD,SAAS,mBAAmB,MAAM,IACpC,QAAQ,WAAW,mBAAmB,UAAU,MAAM,IACtD;AAEN;","names":[]}
|