Tone.js/Tone/component/CrossFade.js

107 lines
2.7 KiB
JavaScript
Raw Normal View History

2015-02-02 17:48:04 +00:00
define(["Tone/core/Tone", "Tone/signal/Signal", "Tone/signal/Expr", "Tone/signal/EqualPowerGain"], function(Tone){
"use strict";
/**
2015-07-02 19:45:40 +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
* @extends {Tone}
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;
* // ^ the two signals are mixed equally.
2015-02-02 17:48:04 +00:00
*/
Tone.CrossFade = function(initialFade){
Tone.call(this, 2, 1);
/**
2015-06-20 23:25:49 +00:00
* Alias for <code>input[0]</code>.
2015-02-02 17:48:04 +00:00
* @type {GainNode}
*/
this.a = this.input[0] = this.context.createGain();
/**
2015-06-20 23:25:49 +00:00
* Alias for <code>input[1]</code>.
2015-02-02 17:48:04 +00:00
* @type {GainNode}
*/
this.b = this.input[1] = this.context.createGain();
/**
2015-06-20 23:25:49 +00:00
* The mix between the two inputs. A fade value of 0
* 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
*/
2015-05-24 13:45:15 +00:00
this.fade = new Tone.Signal(this.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();
2015-02-02 17:48:04 +00:00
/**
* invert the incoming signal
* @private
* @type {Tone}
*/
this._invert = new Tone.Expr("1 - $0");
//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);
this.fade.chain(this._invert, this._equalPowerA, this.a.gain);
2015-04-05 19:13:15 +00:00
this._readOnly("fade");
2015-02-02 17:48:04 +00:00
};
Tone.extend(Tone.CrossFade);
/**
* clean up
* @returns {Tone.CrossFade} this
2015-02-02 17:48:04 +00:00
*/
Tone.CrossFade.prototype.dispose = function(){
Tone.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;
this.a.disconnect();
this.a = null;
this.b.disconnect();
this.b = null;
return this;
};
return Tone.CrossFade;
});