mirror of
https://github.com/Tonejs/Tone.js
synced 2025-01-03 23:48:43 +00:00
78 lines
1.9 KiB
TypeScript
78 lines
1.9 KiB
TypeScript
|
import { optionsFromArguments, readOnly } from "../core/Util";
|
||
|
import "../type/Units";
|
||
|
import { ToneAudioNode, ToneAudioNodeOptions } from "./AudioNode";
|
||
|
import { Param } from "./Param";
|
||
|
|
||
|
interface GainOptions extends ToneAudioNodeOptions {
|
||
|
gain: number;
|
||
|
units: Unit;
|
||
|
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.
|
||
|
*/
|
||
|
export class Gain<Type extends Unit = "gain"> extends ToneAudioNode<GainOptions> {
|
||
|
|
||
|
readonly name = "Gain";
|
||
|
|
||
|
/**
|
||
|
* 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,
|
||
|
units : "gain" as Unit,
|
||
|
});
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Clean up.
|
||
|
*/
|
||
|
dispose(): this {
|
||
|
super.dispose();
|
||
|
this._gainNode.disconnect();
|
||
|
this.gain.dispose();
|
||
|
return this;
|
||
|
}
|
||
|
}
|