mirror of
https://github.com/Tonejs/Tone.js
synced 2025-01-25 01:55:00 +00:00
64 lines
No EOL
1.6 KiB
JavaScript
64 lines
No EOL
1.6 KiB
JavaScript
define(["Tone/core/Tone", "Tone/effect/StereoEffect", "Tone/effect/FeedbackEffect"],
|
|
function(Tone){
|
|
|
|
"use strict";
|
|
|
|
/**
|
|
* @class Just like a stereo feedback effect, but the feedback is routed from left to right
|
|
* and right to left instead of on the same channel.
|
|
*
|
|
* @constructor
|
|
* @extends {Tone.FeedbackEffect}
|
|
*/
|
|
Tone.StereoXFeedbackEffect = function(){
|
|
|
|
var options = this.optionsObject(arguments, ["feedback"], Tone.FeedbackEffect.defaults);
|
|
Tone.StereoEffect.call(this, options);
|
|
|
|
/**
|
|
* controls the amount of feedback
|
|
* @type {Tone.Signal}
|
|
*/
|
|
this.feedback = new Tone.Signal(options.feedback);
|
|
|
|
/**
|
|
* the left side feeback
|
|
* @type {GainNode}
|
|
* @private
|
|
*/
|
|
this._feedbackLR = this.context.createGain();
|
|
|
|
/**
|
|
* the right side feeback
|
|
* @type {GainNode}
|
|
* @private
|
|
*/
|
|
this._feedbackRL = this.context.createGain();
|
|
|
|
//connect it up
|
|
this.effectReturnL.chain(this._feedbackLR, this.effectSendR);
|
|
this.effectReturnR.chain(this._feedbackRL, this.effectSendL);
|
|
this.feedback.fan(this._feedbackLR.gain, this._feedbackRL.gain);
|
|
this._readOnly(["feedback"]);
|
|
};
|
|
|
|
Tone.extend(Tone.StereoXFeedbackEffect, Tone.FeedbackEffect);
|
|
|
|
/**
|
|
* clean up
|
|
* @returns {Tone.StereoXFeedbackEffect} `this`
|
|
*/
|
|
Tone.StereoXFeedbackEffect.prototype.dispose = function(){
|
|
Tone.StereoEffect.prototype.dispose.call(this);
|
|
this._writable(["feedback"]);
|
|
this.feedback.dispose();
|
|
this.feedback = null;
|
|
this._feedbackLR.disconnect();
|
|
this._feedbackLR = null;
|
|
this._feedbackRL.disconnect();
|
|
this._feedbackRL = null;
|
|
return this;
|
|
};
|
|
|
|
return Tone.StereoXFeedbackEffect;
|
|
}); |