2019-01-27 18:05:20 +00:00
|
|
|
import Tone from "../core/Tone";
|
|
|
|
import "../core/AudioNode";
|
2014-04-05 22:05:42 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
/**
|
|
|
|
* @class Tone.Merge brings two signals into the left and right
|
|
|
|
* channels of a single stereo channel.
|
|
|
|
*
|
|
|
|
* @constructor
|
|
|
|
* @extends {Tone.AudioNode}
|
|
|
|
* @param {number} [channels=2] The number of channels to merge.
|
|
|
|
* @example
|
|
|
|
* var merge = new Tone.Merge().toMaster();
|
|
|
|
* //routing a sine tone in the left channel
|
|
|
|
* //and noise in the right channel
|
|
|
|
* var osc = new Tone.Oscillator().connect(merge.left);
|
|
|
|
* var noise = new Tone.Noise().connect(merge.right);
|
|
|
|
* //starting our oscillators
|
|
|
|
* noise.start();
|
|
|
|
* osc.start();
|
|
|
|
*/
|
|
|
|
Tone.Merge = function(channels){
|
|
|
|
|
|
|
|
//defaults to 2 channels
|
|
|
|
channels = Tone.defaultArg(channels, 2);
|
|
|
|
|
|
|
|
Tone.AudioNode.call(this);
|
|
|
|
this.createInsOuts(channels, 0);
|
2014-09-04 04:41:40 +00:00
|
|
|
|
2014-06-17 15:40:01 +00:00
|
|
|
/**
|
2019-01-27 18:05:20 +00:00
|
|
|
* the merger node for the two channels
|
|
|
|
* @type {ChannelMergerNode}
|
|
|
|
* @private
|
2014-06-17 15:40:01 +00:00
|
|
|
*/
|
2019-01-27 18:05:20 +00:00
|
|
|
this._merger = this.output = this.context.createChannelMerger(channels);
|
2019-01-27 01:06:07 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
//connections
|
|
|
|
for (var i = 0; i < channels; i++){
|
|
|
|
this.input[i] = new Tone.Gain();
|
|
|
|
this.input[i].connect(this._merger, 0, i);
|
|
|
|
this.input[i].channelCount = 1;
|
|
|
|
this.input[i].channelCountMode = "explicit";
|
|
|
|
}
|
2019-01-27 01:06:07 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
/**
|
|
|
|
* The left input channel.
|
|
|
|
* Alias for <code>input[0]</code>
|
|
|
|
* @type {GainNode}
|
|
|
|
*/
|
|
|
|
this.left = this.input[0];
|
2014-04-05 22:05:42 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
/**
|
|
|
|
* The right input channel.
|
|
|
|
* Alias for <code>input[1]</code>.
|
|
|
|
* @type {GainNode}
|
|
|
|
*/
|
|
|
|
this.right = this.input[1];
|
|
|
|
};
|
2014-08-20 21:09:58 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
Tone.extend(Tone.Merge, Tone.AudioNode);
|
2014-04-05 22:05:42 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
/**
|
|
|
|
* Clean up.
|
|
|
|
* @returns {Tone.Merge} this
|
|
|
|
*/
|
|
|
|
Tone.Merge.prototype.dispose = function(){
|
|
|
|
this.input.forEach(function(input){
|
|
|
|
input.dispose();
|
|
|
|
});
|
|
|
|
Tone.AudioNode.prototype.dispose.call(this);
|
|
|
|
this.left = null;
|
|
|
|
this.right = null;
|
|
|
|
this._merger.disconnect();
|
|
|
|
this._merger = null;
|
|
|
|
return this;
|
|
|
|
};
|
2014-04-05 22:05:42 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
export default Tone.Merge;
|
2014-06-20 04:38:14 +00:00
|
|
|
|