2016-09-20 03:53:07 +00:00
|
|
|
define(["Tone/core/Tone", "Tone/effect/StereoEffect", "Tone/effect/FeedbackEffect", "Tone/core/Gain"],
|
2014-09-01 16:52:13 +00:00
|
|
|
function(Tone){
|
|
|
|
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
/**
|
2015-06-22 05:20:57 +00:00
|
|
|
* @class Base class for stereo feedback effects where the effectReturn
|
|
|
|
* is fed back into the same channel.
|
2014-09-01 16:52:13 +00:00
|
|
|
*
|
|
|
|
* @constructor
|
2017-04-26 03:18:08 +00:00
|
|
|
* @extends {Tone.StereoEffect}
|
2014-09-01 16:52:13 +00:00
|
|
|
*/
|
|
|
|
Tone.StereoFeedbackEffect = function(){
|
|
|
|
|
2017-04-26 03:18:08 +00:00
|
|
|
var options = Tone.defaults(arguments, ["feedback"], Tone.FeedbackEffect);
|
2014-09-01 16:52:13 +00:00
|
|
|
Tone.StereoEffect.call(this, options);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* controls the amount of feedback
|
2015-06-13 23:50:39 +00:00
|
|
|
* @type {NormalRange}
|
|
|
|
* @signal
|
2014-09-01 16:52:13 +00:00
|
|
|
*/
|
2015-06-13 23:50:39 +00:00
|
|
|
this.feedback = new Tone.Signal(options.feedback, Tone.Type.NormalRange);
|
2014-09-01 16:52:13 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* the left side feeback
|
2016-09-20 03:53:07 +00:00
|
|
|
* @type {Tone.Gain}
|
2014-09-01 16:52:13 +00:00
|
|
|
* @private
|
|
|
|
*/
|
2016-09-20 03:53:07 +00:00
|
|
|
this._feedbackL = new Tone.Gain();
|
2014-09-01 16:52:13 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* the right side feeback
|
2016-09-20 03:53:07 +00:00
|
|
|
* @type {Tone.Gain}
|
2014-09-01 16:52:13 +00:00
|
|
|
* @private
|
|
|
|
*/
|
2016-09-20 03:53:07 +00:00
|
|
|
this._feedbackR = new Tone.Gain();
|
2014-09-01 16:52:13 +00:00
|
|
|
|
|
|
|
//connect it up
|
2014-12-01 02:32:09 +00:00
|
|
|
this.effectReturnL.chain(this._feedbackL, this.effectSendL);
|
|
|
|
this.effectReturnR.chain(this._feedbackR, this.effectSendR);
|
2014-12-01 02:20:12 +00:00
|
|
|
this.feedback.fan(this._feedbackL.gain, this._feedbackR.gain);
|
2015-04-18 14:54:08 +00:00
|
|
|
this._readOnly(["feedback"]);
|
2014-09-01 16:52:13 +00:00
|
|
|
};
|
|
|
|
|
2017-04-26 03:18:08 +00:00
|
|
|
Tone.extend(Tone.StereoFeedbackEffect, Tone.StereoEffect);
|
2014-09-01 16:52:13 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* clean up
|
2015-06-14 00:54:29 +00:00
|
|
|
* @returns {Tone.StereoFeedbackEffect} this
|
2014-09-01 16:52:13 +00:00
|
|
|
*/
|
|
|
|
Tone.StereoFeedbackEffect.prototype.dispose = function(){
|
|
|
|
Tone.StereoEffect.prototype.dispose.call(this);
|
2015-04-18 14:54:08 +00:00
|
|
|
this._writable(["feedback"]);
|
2014-09-01 16:52:13 +00:00
|
|
|
this.feedback.dispose();
|
|
|
|
this.feedback = null;
|
2016-09-20 03:53:07 +00:00
|
|
|
this._feedbackL.dispose();
|
2014-09-01 16:52:13 +00:00
|
|
|
this._feedbackL = null;
|
2016-09-20 03:53:07 +00:00
|
|
|
this._feedbackR.dispose();
|
2014-09-01 16:52:13 +00:00
|
|
|
this._feedbackR = null;
|
2015-02-02 18:22:16 +00:00
|
|
|
return this;
|
2014-09-01 16:52:13 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
return Tone.StereoFeedbackEffect;
|
|
|
|
});
|