mirror of
https://github.com/Tonejs/Tone.js
synced 2025-01-03 15:38:42 +00:00
70 lines
1.8 KiB
TypeScript
70 lines
1.8 KiB
TypeScript
|
import { Scale, ScaleOptions } from "./Scale";
|
||
|
import { Positive } from "../core/type/Units";
|
||
|
import { optionsFromArguments } from "../core/util/Defaults";
|
||
|
import { Pow } from "./Pow";
|
||
|
|
||
|
export interface ScaleExpOptions extends ScaleOptions {
|
||
|
exponent: Positive;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Performs an exponential scaling on an input signal.
|
||
|
* Scales a NormalRange value [0,1] exponentially
|
||
|
* to the output range of outputMin to outputMax.
|
||
|
* @example
|
||
|
* import { ScaleExp, Signal } from "tone";
|
||
|
* const scaleExp = new ScaleExp(0, 100, 2);
|
||
|
* const signal = new Signal(0.5).connect(scaleExp);
|
||
|
*/
|
||
|
export class ScaleExp extends Scale<ScaleExpOptions> {
|
||
|
|
||
|
readonly name: string = "ScaleExp";
|
||
|
|
||
|
/**
|
||
|
* The exponent scaler
|
||
|
*/
|
||
|
private _exp: Pow;
|
||
|
|
||
|
/**
|
||
|
* @param min The output value when the input is 0.
|
||
|
* @param max The output value when the input is 1.
|
||
|
* @param exponent The exponent which scales the incoming signal.
|
||
|
*/
|
||
|
constructor(min?: number, max?: number, exponent?: number);
|
||
|
constructor(options?: Partial<ScaleExpOptions>);
|
||
|
constructor() {
|
||
|
super(Object.assign(optionsFromArguments(ScaleExp.getDefaults(), arguments, ["min", "max", "exponent"])));
|
||
|
const options = optionsFromArguments(ScaleExp.getDefaults(), arguments, ["min", "max", "exponent"]);
|
||
|
|
||
|
this.input = this._exp = new Pow({
|
||
|
context: this.context,
|
||
|
value: options.exponent,
|
||
|
});
|
||
|
this._exp.connect(this._mult);
|
||
|
}
|
||
|
|
||
|
static getDefaults(): ScaleExpOptions {
|
||
|
return Object.assign(Scale.getDefaults(), {
|
||
|
exponent: 1,
|
||
|
});
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Instead of interpolating linearly between the [[min]] and
|
||
|
* [[max]] values, setting the exponent will interpolate between
|
||
|
* the two values with an exponential curve.
|
||
|
*/
|
||
|
get exponent(): Positive {
|
||
|
return this._exp.value;
|
||
|
}
|
||
|
set exponent(exp) {
|
||
|
this._exp.value = exp;
|
||
|
}
|
||
|
|
||
|
dispose(): this {
|
||
|
super.dispose();
|
||
|
this._exp.dispose();
|
||
|
return this;
|
||
|
}
|
||
|
}
|