mirror of
https://github.com/Tonejs/Tone.js
synced 2024-12-31 22:18:44 +00:00
129 lines
3.5 KiB
TypeScript
129 lines
3.5 KiB
TypeScript
|
import { Gain } from "Tone/core/context/Gain";
|
||
|
import { optionsFromArguments } from "Tone/core/util/Defaults";
|
||
|
import { readOnly, writable } from "Tone/core/util/Interface";
|
||
|
import { ToneAudioNode, ToneAudioNodeOptions } from "../../core/context/ToneAudioNode";
|
||
|
import { Signal } from "Tone/signal/Signal";
|
||
|
import { Filter } from "../filter/Filter";
|
||
|
|
||
|
interface MultibandSplitOptions extends ToneAudioNodeOptions {
|
||
|
lowFrequency: Frequency,
|
||
|
highFrequency: Frequency,
|
||
|
Q: Positive
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @class Split the incoming signal into three bands (low, mid, high)
|
||
|
* with two crossover frequency controls.
|
||
|
*
|
||
|
* @extends {Tone.AudioNode}
|
||
|
* @constructor
|
||
|
* @param {Frequency|Object} [lowFrequency] the low/mid crossover frequency
|
||
|
* @param {Frequency} [highFrequency] the mid/high crossover frequency
|
||
|
*/
|
||
|
export class MultibandSplit extends ToneAudioNode {
|
||
|
|
||
|
readonly name = "MultibandSplit";
|
||
|
|
||
|
/**
|
||
|
* the input
|
||
|
*/
|
||
|
readonly input = new Gain({ context: this.context });
|
||
|
|
||
|
/**
|
||
|
* The low band. Alias for <code>output[0]</code>
|
||
|
*/
|
||
|
readonly low = new Filter(0, "lowpass");
|
||
|
|
||
|
/**
|
||
|
* the lower filter of the mid band
|
||
|
*/
|
||
|
private _lowMidFilter = new Filter(0, "highpass");
|
||
|
|
||
|
/**
|
||
|
* The mid band output. Alias for <code>output[1]</code>
|
||
|
*/
|
||
|
readonly mid = new Filter(0, "lowpass");
|
||
|
|
||
|
/**
|
||
|
* The high band output. Alias for <code>output[2]</code>
|
||
|
* @type {Tone.Filter}
|
||
|
*/
|
||
|
readonly high = new Filter(0, "highpass");
|
||
|
|
||
|
readonly output = [this.low, this.mid, this.high];
|
||
|
|
||
|
readonly lowFrequency: Signal<"frequency">;
|
||
|
readonly highFrequency: Signal<"frequency">;
|
||
|
|
||
|
protected _internalChannels = [this.input, ...this.output];
|
||
|
|
||
|
/**
|
||
|
* The Q or Quality of the filter
|
||
|
*/
|
||
|
readonly Q: Signal<"positive">;
|
||
|
|
||
|
constructor(lowFrequency?: Frequency, highFrequency?: Frequency);
|
||
|
constructor(options?: Partial<MultibandSplitOptions>);
|
||
|
constructor() {
|
||
|
super(optionsFromArguments(MultibandSplit.getDefaults(), arguments, ["lowFrequency", "highFrequency"]));
|
||
|
const options = optionsFromArguments(MultibandSplit.getDefaults(), arguments, ["lowFrequency", "highFrequency"]);
|
||
|
|
||
|
this.lowFrequency = new Signal({
|
||
|
context: this.context,
|
||
|
units: "frequency",
|
||
|
value: options.lowFrequency,
|
||
|
});
|
||
|
|
||
|
this.highFrequency = new Signal({
|
||
|
context: this.context,
|
||
|
units: "frequency",
|
||
|
value: options.highFrequency,
|
||
|
});
|
||
|
|
||
|
this.Q = new Signal({
|
||
|
context: this.context,
|
||
|
units: "positive",
|
||
|
value: options.Q,
|
||
|
});
|
||
|
|
||
|
this.input.fan(this.low, this.high);
|
||
|
this.input.chain(this._lowMidFilter, this.mid);
|
||
|
//the frequency control signal
|
||
|
this.lowFrequency.connect(this.low.frequency);
|
||
|
this.lowFrequency.connect(this._lowMidFilter.frequency);
|
||
|
this.highFrequency.connect(this.mid.frequency);
|
||
|
this.highFrequency.connect(this.high.frequency);
|
||
|
//the Q value
|
||
|
this.Q.connect(this.low.Q);
|
||
|
this.Q.connect(this._lowMidFilter.Q);
|
||
|
this.Q.connect(this.mid.Q);
|
||
|
this.Q.connect(this.high.Q);
|
||
|
|
||
|
readOnly(this, ["high", "mid", "low", "highFrequency", "lowFrequency"]);
|
||
|
}
|
||
|
|
||
|
static getDefaults(): MultibandSplitOptions {
|
||
|
return Object.assign(ToneAudioNode.getDefaults(), {
|
||
|
lowFrequency: 400,
|
||
|
highFrequency: 2500,
|
||
|
Q: 1,
|
||
|
});
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Clean up.
|
||
|
*/
|
||
|
dispose (): this {
|
||
|
super.dispose();
|
||
|
writable(this, ["high", "mid", "low", "highFrequency", "lowFrequency"]);
|
||
|
this.low.dispose();
|
||
|
this._lowMidFilter.dispose();
|
||
|
this.mid.dispose();
|
||
|
this.high.dispose();
|
||
|
this.lowFrequency.dispose();
|
||
|
this.highFrequency.dispose();
|
||
|
this.Q.dispose();
|
||
|
return this;
|
||
|
};
|
||
|
|
||
|
}
|