import { ToneAudioNode, ToneAudioNodeOptions } from "../../core/context/ToneAudioNode"; import { Positive } from "../../core/type/Units"; import { optionsFromArguments } from "../../core/util/Defaults"; interface MergeOptions extends ToneAudioNodeOptions { channels: Positive; } /** * Merge brings multiple mono input channels into a single multichannel output channel. * * @example * const merge = new Merge().toDestination(); * // routing a sine tone in the left channel * const osc = new Oscillator().connect(merge, 0, 0).start(); * // and noise in the right channel * const noise = new Noise().connect(merge, 0, 1).start();; * @category Component */ export class Merge extends ToneAudioNode { readonly name: string = "Merge"; /** * The merger node for the two channels. */ private _merger: ChannelMergerNode; /** * The output is the input channels combined into a sigle (multichannel) output */ readonly output: ChannelMergerNode; /** * Multiple input connections combine into a single output. */ readonly input: ChannelMergerNode; /** * @param channels The number of channels to merge. */ constructor(channels?: Positive); constructor(options?: Partial); constructor() { super(optionsFromArguments(Merge.getDefaults(), arguments, ["channels"])); const options = optionsFromArguments(Merge.getDefaults(), arguments, ["channels"]); this._merger = this.output = this.input = this.context.createChannelMerger(options.channels); } static getDefaults(): MergeOptions { return Object.assign(ToneAudioNode.getDefaults(), { channels: 2, }); } dispose(): this { super.dispose(); this._merger.disconnect(); return this; } }