2024-05-03 18:31:14 +00:00
|
|
|
import { Gain } from "../../core/context/Gain.js";
|
|
|
|
import {
|
|
|
|
OutputNode,
|
|
|
|
ToneAudioNode,
|
|
|
|
ToneAudioNodeOptions,
|
|
|
|
} from "../../core/context/ToneAudioNode.js";
|
|
|
|
import { optionsFromArguments } from "../../core/util/Defaults.js";
|
|
|
|
import { Merge } from "./Merge.js";
|
2019-09-11 02:38:48 +00:00
|
|
|
|
|
|
|
export type MonoOptions = ToneAudioNodeOptions;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Mono coerces the incoming mono or stereo signal into a mono signal
|
|
|
|
* where both left and right channels have the same value. This can be useful
|
|
|
|
* for [stereo imaging](https://en.wikipedia.org/wiki/Stereo_imaging).
|
2019-09-16 14:15:23 +00:00
|
|
|
* @category Component
|
2019-09-11 02:38:48 +00:00
|
|
|
*/
|
|
|
|
export class Mono extends ToneAudioNode<MonoOptions> {
|
|
|
|
readonly name: string = "Mono";
|
|
|
|
|
|
|
|
/**
|
2019-09-14 20:39:18 +00:00
|
|
|
* merge the signal
|
2019-09-11 02:38:48 +00:00
|
|
|
*/
|
|
|
|
private _merge: Merge;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The summed output of the multiple inputs
|
|
|
|
*/
|
|
|
|
readonly output: OutputNode;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The stereo signal to sum to mono
|
|
|
|
*/
|
|
|
|
readonly input: Gain;
|
|
|
|
|
|
|
|
constructor(options?: Partial<MonoOptions>);
|
|
|
|
constructor() {
|
|
|
|
super(optionsFromArguments(Mono.getDefaults(), arguments));
|
|
|
|
|
2019-09-16 03:32:40 +00:00
|
|
|
this.input = new Gain({ context: this.context });
|
2019-09-11 02:38:48 +00:00
|
|
|
|
|
|
|
this._merge = this.output = new Merge({
|
|
|
|
channels: 2,
|
|
|
|
context: this.context,
|
|
|
|
});
|
|
|
|
|
|
|
|
this.input.connect(this._merge, 0, 0);
|
|
|
|
this.input.connect(this._merge, 0, 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
dispose(): this {
|
|
|
|
super.dispose();
|
|
|
|
this._merge.dispose();
|
|
|
|
this.input.dispose();
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
}
|