2019-05-23 18:00:49 +00:00
|
|
|
import { Param } from "../context/Param";
|
2019-04-12 14:37:47 +00:00
|
|
|
import "../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
|
|
|
|
|
|
|
interface GainOptions extends ToneAudioNodeOptions {
|
|
|
|
gain: number;
|
2019-07-15 19:37:25 +00:00
|
|
|
units: UnitName;
|
2019-04-12 14:37:47 +00:00
|
|
|
convert: boolean;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A thin wrapper around the Native Web Audio GainNode.
|
|
|
|
* The GainNode is a basic building block of the Web Audio
|
|
|
|
* API and is useful for routing audio and adjusting gains.
|
|
|
|
* @param gain The initial gain of the GainNode
|
|
|
|
* @param units The units of the gain parameter.
|
|
|
|
*/
|
2019-07-15 19:37:25 +00:00
|
|
|
export class Gain<Type extends Unit = GainFactor> extends ToneAudioNode<GainOptions> {
|
2019-04-12 14:37:47 +00:00
|
|
|
|
2019-07-15 19:37:25 +00:00
|
|
|
name = "Gain";
|
2019-04-12 14:37:47 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The gain parameter of the gain node.
|
|
|
|
*/
|
|
|
|
readonly gain: Param<Type>;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The wrapped GainNode.
|
|
|
|
*/
|
|
|
|
private _gainNode: GainNode = this.context.createGain();
|
|
|
|
|
|
|
|
// input = output
|
|
|
|
readonly input: GainNode = this._gainNode;
|
|
|
|
readonly output: GainNode = this._gainNode;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add all of the gain nodes
|
|
|
|
*/
|
|
|
|
protected _internalChannels: AudioNode[] = [this._gainNode];
|
|
|
|
|
|
|
|
constructor(gain?: GainFactor, units?: Unit);
|
|
|
|
constructor(options?: Partial<GainOptions>);
|
|
|
|
constructor() {
|
|
|
|
super(optionsFromArguments(Gain.getDefaults(), arguments, ["gain", "units"]));
|
|
|
|
const options = optionsFromArguments(Gain.getDefaults(), arguments, ["gain", "units"]);
|
|
|
|
|
|
|
|
this.gain = new Param({
|
|
|
|
context : this.context,
|
|
|
|
convert : options.convert,
|
|
|
|
param : this._gainNode.gain,
|
|
|
|
units : options.units,
|
|
|
|
value : options.gain,
|
|
|
|
});
|
|
|
|
readOnly(this, "gain");
|
|
|
|
}
|
|
|
|
|
|
|
|
static getDefaults(): GainOptions {
|
|
|
|
return Object.assign(ToneAudioNode.getDefaults(), {
|
|
|
|
convert : true,
|
|
|
|
gain : 1,
|
|
|
|
numberOfInputs: 1,
|
|
|
|
numberOfOutputs: 1,
|
2019-07-15 19:37:25 +00:00
|
|
|
units : "gain" as UnitName,
|
2019-04-12 14:37:47 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Clean up.
|
|
|
|
*/
|
|
|
|
dispose(): this {
|
|
|
|
super.dispose();
|
|
|
|
this._gainNode.disconnect();
|
|
|
|
this.gain.dispose();
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
}
|