Tone.js/Tone/component/channel/Volume.ts

113 lines
2.5 KiB
TypeScript
Raw Normal View History

import { Gain } from "../../core/context/Gain.js";
import { Param } from "../../core/context/Param.js";
import {
ToneAudioNode,
ToneAudioNodeOptions,
} from "../../core/context/ToneAudioNode.js";
import { Decibels } from "../../core/type/Units.js";
import { optionsFromArguments } from "../../core/util/Defaults.js";
import { readOnly } from "../../core/util/Interface.js";
2019-06-19 13:53:18 +00:00
interface VolumeOptions extends ToneAudioNodeOptions {
volume: Decibels;
mute: boolean;
}
/**
2019-08-27 17:02:31 +00:00
* Volume is a simple volume node, useful for creating a volume fader.
2019-06-19 13:53:18 +00:00
*
2019-08-27 17:02:31 +00:00
* @example
* const vol = new Tone.Volume(-12).toDestination();
* const osc = new Tone.Oscillator().connect(vol).start();
2019-09-16 14:15:23 +00:00
* @category Component
2019-06-19 13:53:18 +00:00
*/
export class Volume extends ToneAudioNode<VolumeOptions> {
2019-09-04 23:18:44 +00:00
readonly name: string = "Volume";
2019-06-19 13:53:18 +00:00
/**
* the output node
*/
output: Gain<"decibels">;
2019-06-19 13:53:18 +00:00
/**
* Input and output are the same
*/
input: Gain<"decibels">;
2019-06-19 13:53:18 +00:00
/**
* The unmuted volume
*/
private _unmutedVolume: Decibels;
/**
2019-09-14 20:39:18 +00:00
* The volume control in decibels.
2019-10-23 03:39:35 +00:00
* @example
* const vol = new Tone.Volume().toDestination();
* const osc = new Tone.Oscillator().connect(vol).start();
2019-10-23 03:39:35 +00:00
* vol.volume.value = -20;
2019-06-19 13:53:18 +00:00
*/
volume: Param<"decibels">;
2019-06-19 13:53:18 +00:00
2019-08-27 17:02:31 +00:00
/**
* @param volume the initial volume in decibels
*/
constructor(volume?: Decibels);
constructor(options?: Partial<VolumeOptions>);
2019-06-19 13:53:18 +00:00
constructor() {
const options = optionsFromArguments(Volume.getDefaults(), arguments, [
"volume",
]);
super(options);
2019-06-19 13:53:18 +00:00
this.input = this.output = new Gain({
context: this.context,
gain: options.volume,
units: "decibels",
});
this.volume = this.output.gain;
2019-06-19 13:53:18 +00:00
readOnly(this, "volume");
this._unmutedVolume = options.volume;
// set the mute initially
this.mute = options.mute;
}
static getDefaults(): VolumeOptions {
return Object.assign(ToneAudioNode.getDefaults(), {
mute: false,
volume: 0,
});
}
/**
* Mute the output.
* @example
* const vol = new Tone.Volume(-12).toDestination();
* const osc = new Tone.Oscillator().connect(vol).start();
2019-10-23 03:04:52 +00:00
* // mute the output
* vol.mute = true;
2019-06-19 13:53:18 +00:00
*/
get mute(): boolean {
return this.volume.value === -Infinity;
}
set mute(mute: boolean) {
if (!this.mute && mute) {
this._unmutedVolume = this.volume.value;
// maybe it should ramp here?
this.volume.value = -Infinity;
} else if (this.mute && !mute) {
this.volume.value = this._unmutedVolume;
}
}
/**
2019-09-14 20:39:18 +00:00
* clean up
2019-06-19 13:53:18 +00:00
*/
dispose(): this {
super.dispose();
2019-06-19 13:53:18 +00:00
this.input.dispose();
this.volume.dispose();
return this;
}
}