Add comments to Interpolator<T>
https://github.com/theatre-js/theatre/pull/118#discussion_r846632746
This commit is contained in:
parent
86cdbdb48c
commit
f3dfb7cedb
1 changed files with 18 additions and 0 deletions
|
@ -556,6 +556,24 @@ export function stringLiteral<
|
||||||
}
|
}
|
||||||
|
|
||||||
export type Sanitizer<T> = (value: unknown) => T | undefined
|
export type Sanitizer<T> = (value: unknown) => T | undefined
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A linear interpolator for a certain value type.
|
||||||
|
*
|
||||||
|
* @param left - the value to interpolate from (beginning)
|
||||||
|
* @param right - the value to interpolate to (end)
|
||||||
|
* @param progression - the amount of progression. Starts at 0 and ends at 1. But could overshoot in either direction
|
||||||
|
*
|
||||||
|
* @example
|
||||||
|
* ```ts
|
||||||
|
* const numberInterpolator: Interpolator<number> = (left, right, progression) => left + progression * (right - left)
|
||||||
|
*
|
||||||
|
* numberInterpolator(-50, 50, 0.5) === 0
|
||||||
|
* numberInterpolator(-50, 50, 0) === -50
|
||||||
|
* numberInterpolator(-50, 50, 1) === 50
|
||||||
|
* numberInterpolator(-50, 50, 2) === 150 // overshoot
|
||||||
|
* ```
|
||||||
|
*/
|
||||||
export type Interpolator<T> = (left: T, right: T, progression: number) => T
|
export type Interpolator<T> = (left: T, right: T, progression: number) => T
|
||||||
|
|
||||||
export interface IBasePropType<
|
export interface IBasePropType<
|
||||||
|
|
Loading…
Reference in a new issue