Tone.js/Tone/core/context/Gain.ts

100 lines
2.5 KiB
TypeScript
Raw Normal View History

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
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
*/
2024-05-03 15:09:28 +00:00
export class Gain<
TypeName extends "gain" | "decibels" | "normalRange" = "gain",
> extends ToneAudioNode<GainOptions<TypeName>> {
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
*/
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.
*/
constructor(gain?: UnitMap[TypeName], units?: TypeName);
constructor(options?: Partial<GainOptions<TypeName>>);
2019-04-12 14:37:47 +00:00
constructor() {
2024-05-03 15:09:28 +00:00
super(
optionsFromArguments(Gain.getDefaults(), arguments, [
"gain",
"units",
])
);
const options = optionsFromArguments(Gain.getDefaults(), arguments, [
"gain",
"units",
]);
2019-04-12 14:37:47 +00:00
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,
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");
}
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,
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;
}
}