Tone.js/Tone/effect/StereoFeedbackEffect.js

65 lines
1.6 KiB
JavaScript
Raw Normal View History

define(["Tone/core/Tone", "Tone/effect/StereoEffect", "Tone/effect/FeedbackEffect", "Tone/core/Gain"],
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.
*
* @constructor
2017-04-26 03:18:08 +00:00
* @extends {Tone.StereoEffect}
*/
Tone.StereoFeedbackEffect = function(){
2017-04-26 03:18:08 +00:00
var options = Tone.defaults(arguments, ["feedback"], Tone.FeedbackEffect);
Tone.StereoEffect.call(this, options);
/**
* controls the amount of feedback
2015-06-13 23:50:39 +00:00
* @type {NormalRange}
* @signal
*/
2015-06-13 23:50:39 +00:00
this.feedback = new Tone.Signal(options.feedback, Tone.Type.NormalRange);
/**
* the left side feeback
* @type {Tone.Gain}
* @private
*/
this._feedbackL = new Tone.Gain();
/**
* the right side feeback
* @type {Tone.Gain}
* @private
*/
this._feedbackR = new Tone.Gain();
//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"]);
};
2017-04-26 03:18:08 +00:00
Tone.extend(Tone.StereoFeedbackEffect, Tone.StereoEffect);
/**
* clean up
* @returns {Tone.StereoFeedbackEffect} this
*/
Tone.StereoFeedbackEffect.prototype.dispose = function(){
Tone.StereoEffect.prototype.dispose.call(this);
2015-04-18 14:54:08 +00:00
this._writable(["feedback"]);
this.feedback.dispose();
this.feedback = null;
this._feedbackL.dispose();
this._feedbackL = null;
this._feedbackR.dispose();
this._feedbackR = null;
2015-02-02 18:22:16 +00:00
return this;
};
return Tone.StereoFeedbackEffect;
});