mirror of
https://github.com/Tonejs/Tone.js
synced 2024-11-16 08:38:00 +00:00
Merge branch 'pr/523' into typescript
This commit is contained in:
commit
88ea4f5d49
2 changed files with 159 additions and 0 deletions
58
Tone/signal/Scale.test.ts
Normal file
58
Tone/signal/Scale.test.ts
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
import { expect } from "chai";
|
||||||
|
import { BasicTests } from "test/helper/Basic";
|
||||||
|
import { connectFrom, connectTo } from "test/helper/Connect";
|
||||||
|
import { ConstantOutput } from "test/helper/ConstantOutput";
|
||||||
|
import { Scale } from "./Scale";
|
||||||
|
import { Signal } from "./Signal";
|
||||||
|
|
||||||
|
describe("Scale", () => {
|
||||||
|
|
||||||
|
BasicTests(Scale);
|
||||||
|
|
||||||
|
context("Scaling", () => {
|
||||||
|
|
||||||
|
it("handles input and output connections", () => {
|
||||||
|
const scale = new Scale({ outputMin: 0, outputMax: 100 });
|
||||||
|
connectFrom().connect(scale);
|
||||||
|
scale.connect(connectTo());
|
||||||
|
scale.dispose();
|
||||||
|
});
|
||||||
|
|
||||||
|
it("can set the min and max values", () => {
|
||||||
|
const scale = new Scale({ outputMin: 0, outputMax: 100 });
|
||||||
|
scale.min = -0.01;
|
||||||
|
expect(scale.min).to.be.closeTo(-0.01, 0.001);
|
||||||
|
scale.max = 1000;
|
||||||
|
expect(scale.max).to.be.closeTo(1000, 0.001);
|
||||||
|
scale.dispose();
|
||||||
|
});
|
||||||
|
|
||||||
|
it("scales to the min when the input is 0", () => {
|
||||||
|
return ConstantOutput(() => {
|
||||||
|
const signal = new Signal(0);
|
||||||
|
const scale = new Scale({ outputMin: -10, outputMax: 8 });
|
||||||
|
signal.connect(scale);
|
||||||
|
scale.toDestination();
|
||||||
|
}, -10);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("scales to the max when the input is 1", () => {
|
||||||
|
return ConstantOutput(() => {
|
||||||
|
const signal = new Signal(1);
|
||||||
|
const scale = new Scale({ outputMin: -10, outputMax: 0 });
|
||||||
|
scale.max = 8;
|
||||||
|
signal.connect(scale);
|
||||||
|
scale.toDestination();
|
||||||
|
}, 8);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("scales an input of 0.5 to 15 (10, 20)", () => {
|
||||||
|
return ConstantOutput(() => {
|
||||||
|
const signal = new Signal(0.5);
|
||||||
|
const scale = new Scale({ outputMin: 10, outputMax: 20 });
|
||||||
|
signal.connect(scale);
|
||||||
|
scale.toDestination();
|
||||||
|
}, 15);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
101
Tone/signal/Scale.ts
Normal file
101
Tone/signal/Scale.ts
Normal file
|
@ -0,0 +1,101 @@
|
||||||
|
import { ToneAudioNodeOptions } from "Tone/core/context/ToneAudioNode";
|
||||||
|
import { optionsFromArguments } from "Tone/core/util/Defaults";
|
||||||
|
import { Add } from "./Add";
|
||||||
|
import { Multiply } from "./Multiply";
|
||||||
|
import { Signal } from "./Signal";
|
||||||
|
import { SignalOperator } from "./SignalOperator";
|
||||||
|
|
||||||
|
export interface ScaleOptions extends ToneAudioNodeOptions {
|
||||||
|
outputMin: number;
|
||||||
|
outputMax: number;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @class Performs a linear scaling on an input signal.
|
||||||
|
* Scales a NormalRange input to between
|
||||||
|
* outputMin and outputMax.
|
||||||
|
*
|
||||||
|
* @constructor
|
||||||
|
* @extends {SignalOperator}
|
||||||
|
* @param outputMin The output value when the input is 0.
|
||||||
|
* @param outputMax The output value when the input is 1.
|
||||||
|
* @example
|
||||||
|
* var scale = new Scale(50, 100);
|
||||||
|
* var signal = new Signal(0.5).connect(scale);
|
||||||
|
* //the output of scale equals 75
|
||||||
|
*/
|
||||||
|
export class Scale extends SignalOperator<ScaleOptions> {
|
||||||
|
|
||||||
|
readonly name: string = "Scale";
|
||||||
|
|
||||||
|
input = new Multiply({
|
||||||
|
context: this.context,
|
||||||
|
value: 1,
|
||||||
|
});
|
||||||
|
|
||||||
|
output = new Add({
|
||||||
|
context: this.context,
|
||||||
|
value: 0,
|
||||||
|
});
|
||||||
|
|
||||||
|
private _outputMin!: number;
|
||||||
|
|
||||||
|
private _outputMax!: number;
|
||||||
|
|
||||||
|
constructor(options?: Partial<ScaleOptions>);
|
||||||
|
// tslint:disable-next-line: unified-signatures
|
||||||
|
constructor(value?: number);
|
||||||
|
constructor() {
|
||||||
|
super(Object.assign(optionsFromArguments(Scale.getDefaults(), arguments, ["outputMin", "outputMax"])));
|
||||||
|
|
||||||
|
const options = optionsFromArguments(Scale.getDefaults(), arguments, ["outputMin", "outputMax"]);
|
||||||
|
this._outputMin = options.outputMin;
|
||||||
|
this._outputMax = options.outputMax;
|
||||||
|
|
||||||
|
this.input.connect(this.output);
|
||||||
|
this._setRange();
|
||||||
|
}
|
||||||
|
|
||||||
|
static getDefaults(): ScaleOptions {
|
||||||
|
return Object.assign(Signal.getDefaults(), {
|
||||||
|
outputMax: 1,
|
||||||
|
outputMin: 0,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
get min(): number {
|
||||||
|
return this._outputMin;
|
||||||
|
}
|
||||||
|
|
||||||
|
set min(min) {
|
||||||
|
this._outputMin = min;
|
||||||
|
this._setRange();
|
||||||
|
}
|
||||||
|
|
||||||
|
get max(): number {
|
||||||
|
return this._outputMax;
|
||||||
|
}
|
||||||
|
|
||||||
|
set max(max) {
|
||||||
|
this._outputMax = max;
|
||||||
|
this._setRange();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* set the values
|
||||||
|
*/
|
||||||
|
private _setRange(): void {
|
||||||
|
this.output.value = this._outputMin;
|
||||||
|
this.input.value = this._outputMax - this._outputMin;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clean up.
|
||||||
|
*/
|
||||||
|
dispose(): this {
|
||||||
|
super.dispose();
|
||||||
|
this.input.dispose();
|
||||||
|
this.output.dispose();
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue