Tone.js/Tone/component/dynamics/Limiter.ts

88 lines
2.1 KiB
TypeScript
Raw Normal View History

import {
InputNode,
OutputNode,
ToneAudioNode,
ToneAudioNodeOptions,
} from "../../core/context/ToneAudioNode.js";
import { Decibels } from "../../core/type/Units.js";
import { optionsFromArguments } from "../../core/util/Defaults.js";
import { Compressor } from "./Compressor.js";
import { Param } from "../../core/context/Param.js";
import { readOnly } from "../../core/util/Interface.js";
2019-11-14 16:23:00 +00:00
export interface LimiterOptions extends ToneAudioNodeOptions {
threshold: Decibels;
2021-10-13 22:38:30 +00:00
}
2019-11-14 16:23:00 +00:00
/**
* Limiter will limit the loudness of an incoming signal.
2024-04-29 14:48:37 +00:00
* Under the hood it's composed of a {@link Compressor} with a fast attack
* and release and max compression ratio.
2019-11-14 16:23:00 +00:00
*
* @example
* const limiter = new Tone.Limiter(-20).toDestination();
* const oscillator = new Tone.Oscillator().connect(limiter);
2019-11-14 16:23:00 +00:00
* oscillator.start();
* @category Component
2019-11-14 16:23:00 +00:00
*/
export class Limiter extends ToneAudioNode<LimiterOptions> {
readonly name: string = "Limiter";
readonly input: InputNode;
readonly output: OutputNode;
/**
* The compressor which does the limiting
*/
private _compressor: Compressor;
readonly threshold: Param<"decibels">;
2019-11-14 16:23:00 +00:00
/**
* @param threshold The threshold above which the gain reduction is applied.
*/
constructor(threshold?: Decibels);
constructor(options?: Partial<LimiterOptions>);
constructor() {
const options = optionsFromArguments(Limiter.getDefaults(), arguments, [
"threshold",
]);
super(options);
2019-11-14 16:23:00 +00:00
this._compressor =
this.input =
this.output =
new Compressor({
context: this.context,
ratio: 20,
attack: 0.003,
release: 0.01,
threshold: options.threshold,
});
2019-11-14 16:23:00 +00:00
this.threshold = this._compressor.threshold;
readOnly(this, "threshold");
}
static getDefaults(): LimiterOptions {
return Object.assign(ToneAudioNode.getDefaults(), {
threshold: -12,
2019-11-14 16:23:00 +00:00
});
}
/**
* A read-only decibel value for metering purposes, representing the current amount of gain
* reduction that the compressor is applying to the signal.
2019-11-14 16:23:00 +00:00
*/
get reduction(): Decibels {
return this._compressor.reduction;
}
dispose(): this {
super.dispose();
this._compressor.dispose();
this.threshold.dispose();
return this;
}
}