2024-05-03 14:10:40 +00:00
|
|
|
import { Param } from "../context/Param.js";
|
|
|
|
import { UnitMap, UnitName } from "../type/Units.js";
|
|
|
|
import { optionsFromArguments } from "../util/Defaults.js";
|
|
|
|
import { readOnly } from "../util/Interface.js";
|
|
|
|
import { ToneAudioNode, ToneAudioNodeOptions } from "./ToneAudioNode.js";
|
2019-04-12 14:37:47 +00:00
|
|
|
|
2019-10-28 15:37:53 +00:00
|
|
|
interface GainOptions<TypeName extends UnitName> extends ToneAudioNodeOptions {
|
|
|
|
gain: UnitMap[TypeName];
|
|
|
|
units: TypeName;
|
2019-04-12 14:37:47 +00:00
|
|
|
convert: boolean;
|
2019-12-14 22:27:54 +00:00
|
|
|
minValue?: number;
|
|
|
|
maxValue?: number;
|
2019-04-12 14:37:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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.
|
2019-08-26 17:44:43 +00:00
|
|
|
* @category Core
|
2020-04-29 21:15:12 +00:00
|
|
|
* @example
|
2020-07-26 20:55:06 +00:00
|
|
|
* return Tone.Offline(() => {
|
|
|
|
* const gainNode = new Tone.Gain(0).toDestination();
|
|
|
|
* const osc = new Tone.Oscillator(30).connect(gainNode).start();
|
|
|
|
* gainNode.gain.rampTo(1, 0.1);
|
|
|
|
* gainNode.gain.rampTo(0, 0.4, 0.2);
|
|
|
|
* }, 0.7, 1);
|
2019-04-12 14:37:47 +00:00
|
|
|
*/
|
2019-10-28 15:37:53 +00:00
|
|
|
export class Gain<TypeName extends "gain" | "decibels" | "normalRange" = "gain"> extends ToneAudioNode<GainOptions<TypeName>> {
|
2019-04-12 14:37:47 +00:00
|
|
|
|
2019-09-04 23:18:44 +00:00
|
|
|
readonly name: string = "Gain";
|
2019-04-12 14:37:47 +00:00
|
|
|
|
|
|
|
/**
|
2019-09-14 20:39:18 +00:00
|
|
|
* The gain parameter of the gain node.
|
2020-04-29 21:15:12 +00:00
|
|
|
* @example
|
|
|
|
* const gainNode = new Tone.Gain(0).toDestination();
|
2020-05-27 01:09:32 +00:00
|
|
|
* const osc = new Tone.Oscillator().connect(gainNode).start();
|
2020-04-29 21:15:12 +00:00
|
|
|
* gainNode.gain.rampTo(1, 0.1);
|
|
|
|
* gainNode.gain.rampTo(0, 2, "+0.5");
|
2019-04-12 14:37:47 +00:00
|
|
|
*/
|
2019-10-28 15:37:53 +00:00
|
|
|
readonly gain: Param<TypeName>;
|
2019-04-12 14:37:47 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The wrapped GainNode.
|
|
|
|
*/
|
|
|
|
private _gainNode: GainNode = this.context.createGain();
|
|
|
|
|
|
|
|
// input = output
|
|
|
|
readonly input: GainNode = this._gainNode;
|
|
|
|
readonly output: GainNode = this._gainNode;
|
|
|
|
|
2019-08-27 17:02:31 +00:00
|
|
|
/**
|
|
|
|
* @param gain The initial gain of the GainNode
|
|
|
|
* @param units The units of the gain parameter.
|
|
|
|
*/
|
2019-10-28 15:37:53 +00:00
|
|
|
constructor(gain?: UnitMap[TypeName], units?: TypeName);
|
|
|
|
constructor(options?: Partial<GainOptions<TypeName>>);
|
2019-04-12 14:37:47 +00:00
|
|
|
constructor() {
|
|
|
|
super(optionsFromArguments(Gain.getDefaults(), arguments, ["gain", "units"]));
|
|
|
|
const options = optionsFromArguments(Gain.getDefaults(), arguments, ["gain", "units"]);
|
|
|
|
|
|
|
|
this.gain = new Param({
|
2019-09-16 03:32:40 +00:00
|
|
|
context: this.context,
|
|
|
|
convert: options.convert,
|
|
|
|
param: this._gainNode.gain,
|
|
|
|
units: options.units,
|
2019-10-28 15:37:53 +00:00
|
|
|
value: options.gain,
|
2019-12-14 22:27:54 +00:00
|
|
|
minValue: options.minValue,
|
|
|
|
maxValue: options.maxValue,
|
2019-04-12 14:37:47 +00:00
|
|
|
});
|
|
|
|
readOnly(this, "gain");
|
|
|
|
}
|
|
|
|
|
2019-10-28 15:37:53 +00:00
|
|
|
static getDefaults(): GainOptions<any> {
|
2019-04-12 14:37:47 +00:00
|
|
|
return Object.assign(ToneAudioNode.getDefaults(), {
|
2019-09-16 03:32:40 +00:00
|
|
|
convert: true,
|
|
|
|
gain: 1,
|
2019-10-28 15:37:53 +00:00
|
|
|
units: "gain",
|
2019-04-12 14:37:47 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2019-09-14 20:39:18 +00:00
|
|
|
* Clean up.
|
2019-04-12 14:37:47 +00:00
|
|
|
*/
|
|
|
|
dispose(): this {
|
|
|
|
super.dispose();
|
|
|
|
this._gainNode.disconnect();
|
|
|
|
this.gain.dispose();
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
}
|