2017-10-21 22:29:50 +00:00
|
|
|
define(["Tone/core/Tone", "Tone/signal/Signal", "Tone/signal/Subtract",
|
2017-08-27 21:50:31 +00:00
|
|
|
"Tone/signal/EqualPowerGain", "Tone/core/Gain", "Tone/core/AudioNode"], function(Tone){
|
2015-02-02 17:48:04 +00:00
|
|
|
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
/**
|
2017-08-27 21:50:31 +00:00
|
|
|
* @class Tone.Crossfade provides equal power fading between two inputs.
|
2015-07-04 19:25:37 +00:00
|
|
|
* More on crossfading technique [here](https://en.wikipedia.org/wiki/Fade_(audio_engineering)#Crossfading).
|
2015-02-02 17:48:04 +00:00
|
|
|
*
|
|
|
|
* @constructor
|
2017-08-27 21:50:31 +00:00
|
|
|
* @extends {Tone.AudioNode}
|
2015-06-20 23:25:49 +00:00
|
|
|
* @param {NormalRange} [initialFade=0.5]
|
2015-02-27 21:53:10 +00:00
|
|
|
* @example
|
|
|
|
* var crossFade = new Tone.CrossFade(0.5);
|
2015-07-02 00:19:58 +00:00
|
|
|
* //connect effect A to crossfade from
|
|
|
|
* //effect output 0 to crossfade input 0
|
2015-02-27 21:53:10 +00:00
|
|
|
* effectA.connect(crossFade, 0, 0);
|
2015-07-02 00:19:58 +00:00
|
|
|
* //connect effect B to crossfade from
|
|
|
|
* //effect output 0 to crossfade input 1
|
2015-02-27 21:53:10 +00:00
|
|
|
* effectB.connect(crossFade, 0, 1);
|
|
|
|
* crossFade.fade.value = 0;
|
|
|
|
* // ^ only effectA is output
|
|
|
|
* crossFade.fade.value = 1;
|
|
|
|
* // ^ only effectB is output
|
|
|
|
* crossFade.fade.value = 0.5;
|
2017-08-27 21:50:31 +00:00
|
|
|
* // ^ the two signals are mixed equally.
|
|
|
|
*/
|
2015-02-02 17:48:04 +00:00
|
|
|
Tone.CrossFade = function(initialFade){
|
|
|
|
|
2017-08-27 21:50:31 +00:00
|
|
|
Tone.AudioNode.call(this);
|
2016-09-20 03:02:42 +00:00
|
|
|
this.createInsOuts(2, 1);
|
2015-02-02 17:48:04 +00:00
|
|
|
|
|
|
|
/**
|
2017-08-27 21:50:31 +00:00
|
|
|
* Alias for <code>input[0]</code>.
|
2016-09-20 03:53:07 +00:00
|
|
|
* @type {Tone.Gain}
|
2015-02-02 17:48:04 +00:00
|
|
|
*/
|
2016-09-20 03:53:07 +00:00
|
|
|
this.a = this.input[0] = new Tone.Gain();
|
2015-02-02 17:48:04 +00:00
|
|
|
|
|
|
|
/**
|
2017-08-27 21:50:31 +00:00
|
|
|
* Alias for <code>input[1]</code>.
|
2016-09-20 03:53:07 +00:00
|
|
|
* @type {Tone.Gain}
|
2015-02-02 17:48:04 +00:00
|
|
|
*/
|
2016-09-20 03:53:07 +00:00
|
|
|
this.b = this.input[1] = new Tone.Gain();
|
2015-02-02 17:48:04 +00:00
|
|
|
|
|
|
|
/**
|
2015-06-20 23:25:49 +00:00
|
|
|
* The mix between the two inputs. A fade value of 0
|
2017-08-27 21:50:31 +00:00
|
|
|
* will output 100% <code>input[0]</code> and
|
|
|
|
* a value of 1 will output 100% <code>input[1]</code>.
|
2015-06-13 23:29:25 +00:00
|
|
|
* @type {NormalRange}
|
|
|
|
* @signal
|
2015-02-02 17:48:04 +00:00
|
|
|
*/
|
2017-04-30 19:03:49 +00:00
|
|
|
this.fade = new Tone.Signal(Tone.defaultArg(initialFade, 0.5), Tone.Type.NormalRange);
|
2015-02-02 17:48:04 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* equal power gain cross fade
|
|
|
|
* @private
|
|
|
|
* @type {Tone.EqualPowerGain}
|
|
|
|
*/
|
2015-02-11 20:28:33 +00:00
|
|
|
this._equalPowerA = new Tone.EqualPowerGain();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* equal power gain cross fade
|
|
|
|
* @private
|
|
|
|
* @type {Tone.EqualPowerGain}
|
|
|
|
*/
|
|
|
|
this._equalPowerB = new Tone.EqualPowerGain();
|
2017-08-27 21:50:31 +00:00
|
|
|
|
2015-02-02 17:48:04 +00:00
|
|
|
/**
|
|
|
|
* invert the incoming signal
|
|
|
|
* @private
|
|
|
|
* @type {Tone}
|
|
|
|
*/
|
2017-10-21 22:29:50 +00:00
|
|
|
this._one = this.context.getConstant(1);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* invert the incoming signal
|
|
|
|
* @private
|
|
|
|
* @type {Tone.Subtract}
|
|
|
|
*/
|
2017-10-21 23:02:46 +00:00
|
|
|
this._invert = new Tone.Subtract();
|
2015-02-02 17:48:04 +00:00
|
|
|
|
|
|
|
//connections
|
|
|
|
this.a.connect(this.output);
|
|
|
|
this.b.connect(this.output);
|
2015-02-11 20:28:33 +00:00
|
|
|
this.fade.chain(this._equalPowerB, this.b.gain);
|
2017-10-21 22:29:50 +00:00
|
|
|
this._one.connect(this._invert, 0, 0);
|
|
|
|
this.fade.connect(this._invert, 0, 1);
|
|
|
|
this._invert.chain(this._equalPowerA, this.a.gain);
|
2015-04-05 19:13:15 +00:00
|
|
|
this._readOnly("fade");
|
2015-02-02 17:48:04 +00:00
|
|
|
};
|
|
|
|
|
2017-08-27 21:50:31 +00:00
|
|
|
Tone.extend(Tone.CrossFade, Tone.AudioNode);
|
2015-02-02 17:48:04 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* clean up
|
2015-06-14 00:54:29 +00:00
|
|
|
* @returns {Tone.CrossFade} this
|
2015-02-02 17:48:04 +00:00
|
|
|
*/
|
|
|
|
Tone.CrossFade.prototype.dispose = function(){
|
2017-08-27 21:50:31 +00:00
|
|
|
Tone.AudioNode.prototype.dispose.call(this);
|
2015-04-05 19:13:15 +00:00
|
|
|
this._writable("fade");
|
2015-02-11 20:28:33 +00:00
|
|
|
this._equalPowerA.dispose();
|
|
|
|
this._equalPowerA = null;
|
|
|
|
this._equalPowerB.dispose();
|
|
|
|
this._equalPowerB = null;
|
2015-02-02 17:48:04 +00:00
|
|
|
this.fade.dispose();
|
|
|
|
this.fade = null;
|
|
|
|
this._invert.dispose();
|
|
|
|
this._invert = null;
|
2017-10-21 22:29:50 +00:00
|
|
|
this._one = null;
|
2016-09-20 03:53:07 +00:00
|
|
|
this.a.dispose();
|
2015-02-02 17:48:04 +00:00
|
|
|
this.a = null;
|
2016-09-20 03:53:07 +00:00
|
|
|
this.b.dispose();
|
2015-02-02 17:48:04 +00:00
|
|
|
this.b = null;
|
|
|
|
return this;
|
|
|
|
};
|
|
|
|
|
|
|
|
return Tone.CrossFade;
|
|
|
|
});
|