2014-03-11 23:27:46 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// FEEDBACK DELAY
|
|
|
|
//
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2014-04-06 20:51:30 +00:00
|
|
|
define(["Tone/core/Tone", "Tone/effects/FeedbackEffect"], function(Tone){
|
2014-03-11 23:27:46 +00:00
|
|
|
|
2014-04-06 04:12:18 +00:00
|
|
|
//@param {number} delayTime
|
|
|
|
Tone.FeedbackDelay = function(delayTime){
|
|
|
|
Tone.FeedbackEffect.call(this);
|
2014-03-11 23:27:46 +00:00
|
|
|
|
2014-04-06 04:12:18 +00:00
|
|
|
this.delay = this.context.createDelay(4);
|
2014-04-11 23:17:01 +00:00
|
|
|
this.delay.delayTime.value = this.toSeconds(this.defaultArg(delayTime, .25));
|
2014-03-11 23:27:46 +00:00
|
|
|
|
2014-04-06 04:12:18 +00:00
|
|
|
//connect it up
|
|
|
|
this.connectEffect(this.delay);
|
|
|
|
}
|
2014-03-11 23:27:46 +00:00
|
|
|
|
2014-04-06 04:12:18 +00:00
|
|
|
Tone.extend(Tone.FeedbackDelay, Tone.FeedbackEffect);
|
|
|
|
|
2014-06-18 18:44:10 +00:00
|
|
|
/**
|
|
|
|
* sets the delay time
|
|
|
|
* @param {Tone.Time} time
|
|
|
|
*/
|
|
|
|
Tone.FeedbackDelay.prototype.setDelayTime = function(time){
|
|
|
|
this.rampToValueNow(this.delay.delayTime, this.toSeconds(time));
|
2014-04-06 04:12:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return Tone.FeedbackDelay;
|
|
|
|
});
|