2019-07-18 15:24:32 +00:00
|
|
|
import { Gain } from "../../core/context/Gain";
|
2019-07-30 19:35:27 +00:00
|
|
|
import { NormalRange, Time } from "../../core/type/Units";
|
2019-07-18 15:24:32 +00:00
|
|
|
import { optionsFromArguments } from "../../core/util/Defaults";
|
|
|
|
import { Envelope, EnvelopeOptions } from "./Envelope";
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AmplitudeEnvelope is a Tone.Envelope connected to a gain node.
|
|
|
|
* Unlike Tone.Envelope, which outputs the envelope's value, AmplitudeEnvelope accepts
|
|
|
|
* an audio signal as the input and will apply the envelope to the amplitude
|
|
|
|
* of the signal.
|
|
|
|
* Read more about ADSR Envelopes on [Wikipedia](https://en.wikipedia.org/wiki/Synthesizer#ADSR_envelope).
|
|
|
|
*
|
2019-08-30 16:06:38 +00:00
|
|
|
* @example
|
2020-04-17 02:24:18 +00:00
|
|
|
* const ampEnv = new Tone.AmplitudeEnvelope({
|
2019-10-23 03:04:52 +00:00
|
|
|
* attack: 0.1,
|
|
|
|
* decay: 0.2,
|
|
|
|
* sustain: 1.0,
|
|
|
|
* release: 0.8
|
2019-07-25 15:32:56 +00:00
|
|
|
* }).toDestination();
|
2019-10-23 03:04:52 +00:00
|
|
|
* // create an oscillator and connect it
|
2020-04-17 02:24:18 +00:00
|
|
|
* const osc = new Tone.Oscillator().connect(ampEnv).start();
|
2019-10-23 03:04:52 +00:00
|
|
|
* // trigger the envelopes attack and release "8t" apart
|
2019-07-18 15:24:32 +00:00
|
|
|
* ampEnv.triggerAttackRelease("8t");
|
2019-09-16 14:15:23 +00:00
|
|
|
* @category Component
|
2019-07-18 15:24:32 +00:00
|
|
|
*/
|
|
|
|
export class AmplitudeEnvelope extends Envelope {
|
|
|
|
|
2019-09-04 23:18:44 +00:00
|
|
|
readonly name: string = "AmplitudeEnvelope";
|
2019-07-18 18:06:32 +00:00
|
|
|
|
2019-07-18 15:24:32 +00:00
|
|
|
private _gainNode: Gain = new Gain({
|
|
|
|
context: this.context,
|
|
|
|
gain: 0,
|
|
|
|
});
|
|
|
|
output: Gain = this._gainNode;
|
|
|
|
input: Gain = this._gainNode;
|
|
|
|
|
2019-08-27 17:02:31 +00:00
|
|
|
/**
|
|
|
|
* @param attack The amount of time it takes for the envelope to go from 0 to it's maximum value.
|
|
|
|
* @param decay The period of time after the attack that it takes for the envelope
|
2019-09-14 20:39:18 +00:00
|
|
|
* to fall to the sustain value. Value must be greater than 0.
|
2019-08-27 17:02:31 +00:00
|
|
|
* @param sustain The percent of the maximum value that the envelope rests at until
|
2019-09-14 20:39:18 +00:00
|
|
|
* the release is triggered.
|
2019-08-27 17:02:31 +00:00
|
|
|
* @param release The amount of time after the release is triggered it takes to reach 0.
|
2019-09-14 20:39:18 +00:00
|
|
|
* Value must be greater than 0.
|
2019-08-27 17:02:31 +00:00
|
|
|
*/
|
2019-07-18 15:24:32 +00:00
|
|
|
constructor(attack?: Time, decay?: Time, sustain?: NormalRange, release?: Time);
|
|
|
|
constructor(options?: Partial<EnvelopeOptions>)
|
|
|
|
constructor() {
|
|
|
|
super(optionsFromArguments(AmplitudeEnvelope.getDefaults(), arguments, ["attack", "decay", "sustain", "release"]));
|
|
|
|
this._sig.connect(this._gainNode.gain);
|
|
|
|
this.output = this._gainNode;
|
|
|
|
this.input = this._gainNode;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Clean up
|
|
|
|
*/
|
|
|
|
dispose(): this {
|
|
|
|
super.dispose();
|
|
|
|
this._gainNode.dispose();
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
}
|