Tone.js/Tone/core/context/Delay.ts

86 lines
2.2 KiB
TypeScript
Raw Normal View History

2019-05-23 18:00:49 +00:00
import { Param } from "../context/Param";
import { Time } from "../type/Units";
2019-05-23 18:00:49 +00:00
import { optionsFromArguments } from "../util/Defaults";
import { readOnly } from "../util/Interface";
import { ToneAudioNode, ToneAudioNodeOptions } from "./ToneAudioNode";
2019-04-12 14:37:47 +00:00
export interface DelayOptions extends ToneAudioNodeOptions {
delayTime: Time;
maxDelay: Time;
2019-04-12 14:37:47 +00:00
}
/**
* Wrapper around Web Audio's native [DelayNode](http://webaudio.github.io/web-audio-api/#the-delaynode-interface).
* @param delayTime The delay applied to the incoming signal.
* @param maxDelay The maximum delay time.
*/
export class Delay extends ToneAudioNode<DelayOptions> {
2019-07-15 19:37:25 +00:00
name = "Delay";
2019-04-12 14:37:47 +00:00
/**
* The maximum delay time. This cannot be changed after
* the value is passed into the constructor.
*/
readonly maxDelay: Time;
/**
* The amount of time the incoming signal is delayed.
*/
2019-07-15 19:37:25 +00:00
readonly delayTime: Param<Time>;
2019-04-12 14:37:47 +00:00
/**
* Private reference to the internal DelayNode
*/
private _delayNode: DelayNode;
readonly input: DelayNode;
readonly output: DelayNode;
/**
* The internal channels for channel routing changes
*/
protected _internalChannels: AudioNode[];
constructor(options?: Partial<DelayOptions>)
constructor(delayTime?: Time, maxDelay?: Time)
constructor() {
super(optionsFromArguments(Delay.getDefaults(), arguments, ["delayTime", "maxDelay"]));
const options = optionsFromArguments(Delay.getDefaults(), arguments, ["delayTime", "maxDelay"]);
const maxDelayInSeconds = this.toSeconds(options.maxDelay);
this.maxDelay = Math.max(maxDelayInSeconds, this.toSeconds(options.delayTime));
2019-04-12 14:37:47 +00:00
this._delayNode = this.input = this.output = this.context.createDelay(maxDelayInSeconds);
2019-04-12 14:37:47 +00:00
this._internalChannels = [this._delayNode];
this.delayTime = new Param({
context: this.context,
param : this._delayNode.delayTime,
units : "time",
value : options.delayTime,
});
readOnly(this, "delayTime");
}
static getDefaults(): DelayOptions {
return Object.assign(ToneAudioNode.getDefaults(), {
delayTime : 0,
maxDelay: 1,
numberOfInputs: 1,
numberOfOutputs: 1,
});
}
/**
* Clean up.
*/
dispose(): this {
super.dispose();
this._delayNode.disconnect();
this.delayTime.dispose();
return this;
}
}