2018-08-27 02:29:17 +00:00
|
|
|
define(["../core/Tone", "../core/Gain"], function(Tone){
|
2014-04-16 04:23:58 +00:00
|
|
|
|
2014-09-04 04:41:40 +00:00
|
|
|
"use strict";
|
|
|
|
|
2014-06-15 22:32:49 +00:00
|
|
|
/**
|
|
|
|
* buses are another way of routing audio
|
|
|
|
*
|
2018-07-21 13:06:28 +00:00
|
|
|
* augments Tone.prototype to include send and receive
|
2014-06-15 22:32:49 +00:00
|
|
|
*/
|
|
|
|
|
2017-10-21 23:02:46 +00:00
|
|
|
/**
|
|
|
|
* All of the routes
|
|
|
|
*
|
|
|
|
* @type {Object}
|
|
|
|
* @static
|
|
|
|
* @private
|
|
|
|
*/
|
2014-06-15 22:32:49 +00:00
|
|
|
var Buses = {};
|
2014-04-16 04:23:58 +00:00
|
|
|
|
2014-06-15 22:32:49 +00:00
|
|
|
/**
|
2017-10-21 23:02:46 +00:00
|
|
|
* Send this signal to the channel name.
|
2017-05-01 20:03:04 +00:00
|
|
|
* @param {String} channelName A named channel to send the signal to.
|
2017-10-21 23:02:46 +00:00
|
|
|
* @param {Decibels} amount The amount of the source to send to the bus.
|
|
|
|
* @return {GainNode} The gain node which connects this node to the desired channel.
|
2015-06-14 00:52:51 +00:00
|
|
|
* Can be used to adjust the levels of the send.
|
2015-06-14 05:24:12 +00:00
|
|
|
* @example
|
|
|
|
* source.send("reverb", -12);
|
2014-06-15 22:32:49 +00:00
|
|
|
*/
|
2014-04-16 04:23:58 +00:00
|
|
|
Tone.prototype.send = function(channelName, amount){
|
|
|
|
if (!Buses.hasOwnProperty(channelName)){
|
|
|
|
Buses[channelName] = this.context.createGain();
|
|
|
|
}
|
2017-04-30 19:03:49 +00:00
|
|
|
amount = Tone.defaultArg(amount, 0);
|
2016-09-20 03:30:43 +00:00
|
|
|
var sendKnob = new Tone.Gain(amount, Tone.Type.Decibels);
|
2018-02-04 16:41:19 +00:00
|
|
|
this.connect(sendKnob);
|
2017-12-15 17:49:41 +00:00
|
|
|
sendKnob.connect(Buses[channelName]);
|
2017-10-21 23:02:46 +00:00
|
|
|
return sendKnob;
|
2014-06-15 22:32:49 +00:00
|
|
|
};
|
2014-04-16 04:23:58 +00:00
|
|
|
|
2014-06-15 22:32:49 +00:00
|
|
|
/**
|
2018-07-21 13:06:28 +00:00
|
|
|
* Receive the input from the desired channelName to the input
|
2014-06-19 17:38:21 +00:00
|
|
|
*
|
2017-05-01 20:03:04 +00:00
|
|
|
* @param {String} channelName A named channel to send the signal to.
|
|
|
|
* @param {Number=} channelNumber The channel to connect to
|
2015-06-14 03:56:32 +00:00
|
|
|
* @returns {Tone} this
|
2015-06-14 05:24:12 +00:00
|
|
|
* @example
|
|
|
|
* reverbEffect.receive("reverb");
|
2014-06-15 22:32:49 +00:00
|
|
|
*/
|
2017-05-01 20:03:04 +00:00
|
|
|
Tone.prototype.receive = function(channelName, inputNum){
|
2014-04-16 04:23:58 +00:00
|
|
|
if (!Buses.hasOwnProperty(channelName)){
|
2017-10-21 23:02:46 +00:00
|
|
|
Buses[channelName] = this.context.createGain();
|
2014-04-16 04:23:58 +00:00
|
|
|
}
|
2017-05-01 20:03:04 +00:00
|
|
|
Buses[channelName].connect(this, 0, inputNum);
|
2015-01-06 04:33:05 +00:00
|
|
|
return this;
|
2014-06-15 22:32:49 +00:00
|
|
|
};
|
2014-09-25 03:43:10 +00:00
|
|
|
|
2016-09-20 03:30:43 +00:00
|
|
|
//remove all the send/receives when a new audio context is passed in
|
2017-02-19 16:50:53 +00:00
|
|
|
Tone.Context.on("init", function(context){
|
2018-07-30 03:34:13 +00:00
|
|
|
if (context.buses){
|
|
|
|
Buses = context.buses;
|
2017-02-19 16:50:53 +00:00
|
|
|
} else {
|
|
|
|
Buses = {};
|
2018-07-30 03:34:13 +00:00
|
|
|
context.buses = Buses;
|
2017-02-19 16:50:53 +00:00
|
|
|
}
|
2016-09-20 03:30:43 +00:00
|
|
|
});
|
|
|
|
|
2014-09-25 03:43:10 +00:00
|
|
|
return Tone;
|
2017-10-21 23:02:46 +00:00
|
|
|
});
|