@ls-stack/utils 1.7.0 → 1.8.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 +7 -1
- package/dist/interpolate.js +9 -4
- package/dist/interpolate.js.map +1 -1
- package/package.json +1 -1
package/dist/interpolate.d.ts
CHANGED
|
@@ -1,5 +1,11 @@
|
|
|
1
1
|
type Interval = [number, number];
|
|
2
2
|
declare function cyclicLerp(input: number, [inStart, inEnd]: Interval, [outStart, outEnd]: Interval): number;
|
|
3
|
-
|
|
3
|
+
type InterpolateArgs = {
|
|
4
|
+
input: number;
|
|
5
|
+
in: number[];
|
|
6
|
+
out: number[];
|
|
7
|
+
clamp?: boolean | 'start' | 'end';
|
|
8
|
+
};
|
|
9
|
+
declare function interpolate({ input, in: inputRange, out, clamp, }: InterpolateArgs): number;
|
|
4
10
|
|
|
5
11
|
export { cyclicLerp, interpolate };
|
package/dist/interpolate.js
CHANGED
|
@@ -21,16 +21,21 @@ function findRange(input, inputRange) {
|
|
|
21
21
|
}
|
|
22
22
|
return inputRange.length - 2;
|
|
23
23
|
}
|
|
24
|
-
function interpolate(
|
|
24
|
+
function interpolate({
|
|
25
|
+
input,
|
|
26
|
+
in: inputRange,
|
|
27
|
+
out,
|
|
28
|
+
clamp = true
|
|
29
|
+
}) {
|
|
25
30
|
invariant(
|
|
26
|
-
inputRange.length ===
|
|
31
|
+
inputRange.length === out.length,
|
|
27
32
|
"Ranges must have the same length"
|
|
28
33
|
);
|
|
29
34
|
const range = findRange(input, inputRange);
|
|
30
35
|
const inStart = inputRange[range];
|
|
31
36
|
const inEnd = inputRange[range + 1];
|
|
32
|
-
const outStart =
|
|
33
|
-
const outEnd =
|
|
37
|
+
const outStart = out[range];
|
|
38
|
+
const outEnd = out[range + 1];
|
|
34
39
|
const interpolatedValue = (input - inStart) / (inEnd - inStart) * (outEnd - outStart) + outStart;
|
|
35
40
|
const outputIsAscending = outStart < outEnd;
|
|
36
41
|
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;
|
package/dist/interpolate.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
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\
|
|
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\ntype InterpolateArgs = {\n input: number;\n in: number[];\n out: number[];\n clamp?: boolean | 'start' | 'end';\n};\n\nexport function interpolate({\n input,\n in: inputRange,\n out,\n clamp = true,\n}: InterpolateArgs): number {\n invariant(\n inputRange.length === out.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 = out[range]!;\n const outEnd = out[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;AASO,SAAS,YAAY;AAAA,EAC1B;AAAA,EACA,IAAI;AAAA,EACJ;AAAA,EACA,QAAQ;AACV,GAA4B;AAC1B;AAAA,IACE,WAAW,WAAW,IAAI;AAAA,IAC1B;AAAA,EACF;AAEA,QAAM,QAAQ,UAAU,OAAO,UAAU;AACzC,QAAM,UAAU,WAAW,KAAK;AAChC,QAAM,QAAQ,WAAW,QAAQ,CAAC;AAClC,QAAM,WAAW,IAAI,KAAK;AAC1B,QAAM,SAAS,IAAI,QAAQ,CAAC;AAE5B,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":[]}
|