2024-05-03 18:31:14 +00:00
|
|
|
import {
|
|
|
|
ToneAudioNode,
|
|
|
|
ToneAudioNodeOptions,
|
|
|
|
} from "../../core/context/ToneAudioNode.js";
|
|
|
|
import { optionsFromArguments } from "../../core/util/Defaults.js";
|
2019-08-03 01:46:36 +00:00
|
|
|
|
|
|
|
interface SplitOptions extends ToneAudioNodeOptions {
|
|
|
|
channels: number;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Split splits an incoming signal into the number of given channels.
|
|
|
|
*
|
|
|
|
* @example
|
2020-04-17 02:24:18 +00:00
|
|
|
* const split = new Tone.Split();
|
2019-10-23 03:39:35 +00:00
|
|
|
* // stereoSignal.connect(split);
|
2019-09-16 14:15:23 +00:00
|
|
|
* @category Component
|
2019-08-03 01:46:36 +00:00
|
|
|
*/
|
|
|
|
export class Split extends ToneAudioNode<SplitOptions> {
|
2019-09-04 23:18:44 +00:00
|
|
|
readonly name: string = "Split";
|
2019-08-03 01:46:36 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The splitting node
|
|
|
|
*/
|
|
|
|
private _splitter: ChannelSplitterNode;
|
|
|
|
|
|
|
|
readonly input: ChannelSplitterNode;
|
|
|
|
readonly output: ChannelSplitterNode;
|
|
|
|
|
2019-08-27 17:02:31 +00:00
|
|
|
/**
|
|
|
|
* @param channels The number of channels to merge.
|
|
|
|
*/
|
2019-08-03 01:46:36 +00:00
|
|
|
constructor(channels?: number);
|
|
|
|
constructor(options?: Partial<SplitOptions>);
|
|
|
|
constructor() {
|
2024-05-03 18:31:14 +00:00
|
|
|
const options = optionsFromArguments(Split.getDefaults(), arguments, [
|
|
|
|
"channels",
|
|
|
|
]);
|
2024-05-06 14:55:55 +00:00
|
|
|
super(options);
|
2024-05-03 18:31:14 +00:00
|
|
|
|
|
|
|
this._splitter =
|
|
|
|
this.input =
|
|
|
|
this.output =
|
|
|
|
this.context.createChannelSplitter(options.channels);
|
2019-08-03 01:46:36 +00:00
|
|
|
this._internalChannels = [this._splitter];
|
|
|
|
}
|
|
|
|
|
|
|
|
static getDefaults(): SplitOptions {
|
|
|
|
return Object.assign(ToneAudioNode.getDefaults(), {
|
|
|
|
channels: 2,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
dispose(): this {
|
|
|
|
super.dispose();
|
|
|
|
this._splitter.disconnect();
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
}
|