mirror of
https://github.com/Tonejs/Tone.js
synced 2025-01-19 15:23:55 +00:00
ed71d8141b
no longer using AMD (require.js) style imports, and beginning to move to es6 "import/export" statements everywhere.
64 lines
1.5 KiB
JavaScript
64 lines
1.5 KiB
JavaScript
import Tone from "../core/Tone";
|
|
import "../effect/Effect";
|
|
import "../signal/Signal";
|
|
import "../signal/Multiply";
|
|
import "../core/Gain";
|
|
|
|
/**
|
|
* @class Tone.FeedbackEffect provides a loop between an
|
|
* audio source and its own output. This is a base-class
|
|
* for feedback effects.
|
|
*
|
|
* @constructor
|
|
* @extends {Tone.Effect}
|
|
* @param {NormalRange|Object} [feedback] The initial feedback value.
|
|
*/
|
|
Tone.FeedbackEffect = function(){
|
|
|
|
var options = Tone.defaults(arguments, ["feedback"], Tone.FeedbackEffect);
|
|
Tone.Effect.call(this, options);
|
|
|
|
/**
|
|
* the gain which controls the feedback
|
|
* @type {Tone.Gain}
|
|
* @private
|
|
*/
|
|
this._feedbackGain = new Tone.Gain(options.feedback, Tone.Type.NormalRange);
|
|
|
|
/**
|
|
* The amount of signal which is fed back into the effect input.
|
|
* @type {NormalRange}
|
|
* @signal
|
|
*/
|
|
this.feedback = this._feedbackGain.gain;
|
|
|
|
//the feedback loop
|
|
this.effectReturn.chain(this._feedbackGain, this.effectSend);
|
|
this._readOnly(["feedback"]);
|
|
};
|
|
|
|
Tone.extend(Tone.FeedbackEffect, Tone.Effect);
|
|
|
|
/**
|
|
* @static
|
|
* @type {Object}
|
|
*/
|
|
Tone.FeedbackEffect.defaults = {
|
|
"feedback" : 0.125
|
|
};
|
|
|
|
/**
|
|
* Clean up.
|
|
* @returns {Tone.FeedbackEffect} this
|
|
*/
|
|
Tone.FeedbackEffect.prototype.dispose = function(){
|
|
Tone.Effect.prototype.dispose.call(this);
|
|
this._writable(["feedback"]);
|
|
this._feedbackGain.dispose();
|
|
this._feedbackGain = null;
|
|
this.feedback = null;
|
|
return this;
|
|
};
|
|
|
|
export default Tone.FeedbackEffect;
|
|
|