Tone.js/Tone/effect/PingPongDelay.js

111 lines
2.8 KiB
JavaScript
Raw Normal View History

define(["Tone/core/Tone", "Tone/effect/StereoXFeedbackEffect", "Tone/signal/Signal", "Tone/signal/Multiply"],
function(Tone){
"use strict";
/**
* @class PingPongDelay is a dual delay effect where the echo is heard
* first in one channel and next in the opposite channel
*
* @constructor
* @extends {Tone.StereoXFeedbackEffect}
* @param {Tone.Time|Object=} delayTime is the interval between consecutive echos
*/
Tone.PingPongDelay = function(){
2014-08-23 17:51:02 +00:00
var options = this.optionsObject(arguments, ["delayTime"], Tone.PingPongDelay.defaults);
Tone.StereoXFeedbackEffect.call(this, options);
/**
* the delay node on the left side
* @type {DelayNode}
* @private
*/
this._leftDelay = this.context.createDelay(options.maxDelayTime);
/**
* the delay node on the right side
* @type {DelayNode}
2014-08-23 18:25:20 +00:00
* @private
*/
this._rightDelay = this.context.createDelay(options.maxDelayTime);
/**
* the predelay on the left side
* @private
* @type {DelayNode}
*/
this._leftPreDelay = this.context.createDelay(options.maxDelayTime);
2014-08-23 17:51:02 +00:00
/**
* the delay time signal
* @type {Tone.Signal}
*/
this.delayTime = new Tone.Signal(0);
2014-08-23 17:51:02 +00:00
/**
* double the delayTime
* @type {Tone.Multiply}
* @private
*/
this._half = new Tone.Multiply(1);
//connect it up
this.chain(this.effectSendL, this._leftPreDelay, this._leftDelay, this.effectReturnL);
this.chain(this.effectSendR, this._rightDelay, this.effectReturnR);
this.fan(this.delayTime, this._leftDelay.delayTime, this._rightDelay.delayTime, this._half);
this._half.connect(this._leftPreDelay.delayTime);
//rearranged the feedback to be after the leftPreDelay
this._feedbackRL.disconnect();
this._feedbackRL.connect(this._leftDelay);
this.setDelayTime(options.delayTime);
};
Tone.extend(Tone.PingPongDelay, Tone.StereoXFeedbackEffect);
/**
* @static
* @type {Object}
*/
Tone.PingPongDelay.defaults = {
"delayTime" : 0.25,
"maxDelayTime" : 1
};
/**
* setDelayTime
*
* @param {Tone.Time} delayTime
*/
Tone.PingPongDelay.prototype.setDelayTime = function(delayTime){
this.delayTime.setValue(this.toSeconds(delayTime));
};
/**
* set all of the parameters with an object
* @param {Object} params
*/
Tone.PingPongDelay.prototype.set = function(params){
if (!this.isUndef(params.delayTime)) this.setDelayTime(params.delayTime);
Tone.StereoXFeedbackEffect.prototype.set.call(this, params);
};
2014-08-20 21:10:12 +00:00
/**
* clean up
*/
Tone.PingPongDelay.prototype.dispose = function(){
Tone.StereoXFeedbackEffect.prototype.dispose.call(this);
this._leftDelay.disconnect();
this._rightDelay.disconnect();
this._half.dispose();
this.delayTime.dispose();
this._leftDelay = null;
this._rightDelay = null;
this._half = null;
this.delayTime = null;
2014-08-20 21:10:12 +00:00
};
return Tone.PingPongDelay;
});