Tone.js/Tone/effect/Tremolo.js

202 lines
4.8 KiB
JavaScript
Raw Normal View History

2015-11-01 22:52:02 +00:00
define(["Tone/core/Tone", "Tone/component/LFO", "Tone/effect/StereoEffect"], function(Tone){
2015-04-24 17:10:16 +00:00
"use strict";
/**
2015-12-06 00:29:08 +00:00
* @class Tone.Tremolo modulates the amplitude of an incoming signal using a Tone.LFO.
* The type, frequency, and depth of the LFO is controllable.
2015-04-24 17:10:16 +00:00
*
2015-11-01 22:52:02 +00:00
* @extends {Tone.StereoEffect}
2015-04-24 17:10:16 +00:00
* @constructor
2015-12-08 05:07:16 +00:00
* @param {Frequency} [frequency] The rate of the effect.
* @param {NormalRange} [depth] The depth of the effect.
2015-04-24 17:10:16 +00:00
* @example
2015-11-01 22:52:02 +00:00
* //create a tremolo and start it's LFO
2015-06-22 05:21:25 +00:00
* var tremolo = new Tone.Tremolo(9, 0.75).toMaster().start();
* //route an oscillator through the tremolo and start it
* var oscillator = new Tone.Oscillator().connect(tremolo).start();
2015-04-24 17:10:16 +00:00
*/
Tone.Tremolo = function(){
2017-04-26 03:18:08 +00:00
var options = Tone.defaults(arguments, ["frequency", "depth"], Tone.Tremolo);
2015-11-01 22:52:02 +00:00
Tone.StereoEffect.call(this, options);
2015-04-24 17:10:16 +00:00
/**
2015-11-01 22:52:02 +00:00
* The tremelo LFO in the left channel
2015-04-24 17:10:16 +00:00
* @type {Tone.LFO}
* @private
*/
2015-11-01 22:52:02 +00:00
this._lfoL = new Tone.LFO({
2015-12-06 00:29:08 +00:00
"phase" : options.spread,
2015-06-07 16:12:03 +00:00
"min" : 1,
2015-11-01 22:52:02 +00:00
"max" : 0,
2015-06-07 16:12:03 +00:00
});
2015-04-24 17:10:16 +00:00
2015-11-01 22:52:02 +00:00
/**
* The tremelo LFO in the left channel
* @type {Tone.LFO}
* @private
*/
this._lfoR = new Tone.LFO({
2015-12-06 00:29:08 +00:00
"phase" : options.spread,
2015-11-01 22:52:02 +00:00
"min" : 1,
"max" : 0,
});
/**
* Where the gain is multiplied
* @type {Tone.Gain}
* @private
*/
this._amplitudeL = new Tone.Gain();
2015-04-24 17:10:16 +00:00
/**
* Where the gain is multiplied
2015-11-01 22:52:02 +00:00
* @type {Tone.Gain}
2015-04-24 17:10:16 +00:00
* @private
*/
2015-11-01 22:52:02 +00:00
this._amplitudeR = new Tone.Gain();
2015-04-24 17:10:16 +00:00
/**
2015-12-06 00:29:08 +00:00
* The frequency of the tremolo.
2015-06-13 23:50:39 +00:00
* @type {Frequency}
* @signal
2015-04-24 17:10:16 +00:00
*/
2015-11-01 22:52:02 +00:00
this.frequency = new Tone.Signal(options.frequency, Tone.Type.Frequency);
2015-04-24 17:10:16 +00:00
/**
2015-06-22 05:21:25 +00:00
* The depth of the effect. A depth of 0, has no effect
* on the amplitude, and a depth of 1 makes the amplitude
2015-12-06 00:29:08 +00:00
* modulate fully between 0 and 1.
2015-06-13 23:50:39 +00:00
* @type {NormalRange}
* @signal
2015-04-24 17:10:16 +00:00
*/
2015-11-01 22:52:02 +00:00
this.depth = new Tone.Signal(options.depth, Tone.Type.NormalRange);
2015-04-24 17:10:16 +00:00
this._readOnly(["frequency", "depth"]);
2015-11-01 22:52:02 +00:00
this.effectSendL.chain(this._amplitudeL, this.effectReturnL);
this.effectSendR.chain(this._amplitudeR, this.effectReturnR);
this._lfoL.connect(this._amplitudeL.gain);
this._lfoR.connect(this._amplitudeR.gain);
this.frequency.fan(this._lfoL.frequency, this._lfoR.frequency);
this.depth.fan(this._lfoR.amplitude, this._lfoL.amplitude);
2015-04-24 17:10:16 +00:00
this.type = options.type;
this.spread = options.spread;
2015-04-24 17:10:16 +00:00
};
2015-11-01 22:52:02 +00:00
Tone.extend(Tone.Tremolo, Tone.StereoEffect);
2015-04-24 17:10:16 +00:00
/**
* @static
* @const
* @type {Object}
*/
Tone.Tremolo.defaults = {
"frequency" : 10,
"type" : "sine",
2015-12-06 00:29:08 +00:00
"depth" : 0.5,
"spread" : 180,
2015-04-24 17:10:16 +00:00
};
/**
* Start the tremolo.
2015-06-14 00:20:36 +00:00
* @param {Time} [time=now] When the tremolo begins.
* @returns {Tone.Tremolo} this
2015-04-24 17:10:16 +00:00
*/
Tone.Tremolo.prototype.start = function(time){
2015-11-01 22:52:02 +00:00
this._lfoL.start(time);
this._lfoR.start(time);
2015-04-24 17:10:16 +00:00
return this;
};
/**
* Stop the tremolo.
2015-06-22 05:21:25 +00:00
* @param {Time} [time=now] When the tremolo stops.
* @returns {Tone.Tremolo} this
2015-04-24 17:10:16 +00:00
*/
Tone.Tremolo.prototype.stop = function(time){
2015-11-01 22:52:02 +00:00
this._lfoL.stop(time);
this._lfoR.stop(time);
2015-04-24 17:10:16 +00:00
return this;
};
/**
* Sync the effect to the transport.
2015-06-14 00:20:36 +00:00
* @param {Time} [delay=0] Delay time before starting the effect after the
2015-12-06 00:29:08 +00:00
* Transport has started.
* @returns {Tone.AutoFilter} this
2015-04-24 17:10:16 +00:00
*/
Tone.Tremolo.prototype.sync = function(delay){
2015-11-01 22:52:02 +00:00
this._lfoL.sync(delay);
this._lfoR.sync(delay);
2017-12-29 18:48:01 +00:00
Tone.Transport.syncSignal(this.frequency);
2015-04-24 17:10:16 +00:00
return this;
};
/**
* Unsync the filter from the transport
* @returns {Tone.Tremolo} this
2015-04-24 17:10:16 +00:00
*/
Tone.Tremolo.prototype.unsync = function(){
2015-11-01 22:52:02 +00:00
this._lfoL.unsync();
this._lfoR.unsync();
2017-12-29 18:48:01 +00:00
Tone.Transport.unsyncSignal(this.frequency);
2015-04-24 17:10:16 +00:00
return this;
};
/**
2015-12-08 05:07:16 +00:00
* The Tremolo's oscillator type.
2015-04-24 17:10:16 +00:00
* @memberOf Tone.Tremolo#
* @type {string}
* @name type
*/
Object.defineProperty(Tone.Tremolo.prototype, "type", {
get : function(){
2015-11-01 22:52:02 +00:00
return this._lfoL.type;
2015-04-24 17:10:16 +00:00
},
set : function(type){
2015-11-01 22:52:02 +00:00
this._lfoL.type = type;
this._lfoR.type = type;
2015-04-24 17:10:16 +00:00
}
});
2017-12-29 18:48:01 +00:00
/**
* Amount of stereo spread. When set to 0, both LFO's will be panned centrally.
2015-12-06 00:29:08 +00:00
* When set to 180, LFO's will be panned hard left and right respectively.
* @memberOf Tone.Tremolo#
* @type {Degrees}
2015-12-06 00:29:08 +00:00
* @name spread
*/
Object.defineProperty(Tone.Tremolo.prototype, "spread", {
get : function(){
return this._lfoR.phase - this._lfoL.phase; //180
},
set : function(spread){
this._lfoL.phase = 90 - (spread/2);
this._lfoR.phase = (spread/2) + 90;
}
});
2015-04-24 17:10:16 +00:00
/**
* clean up
* @returns {Tone.Tremolo} this
2015-04-24 17:10:16 +00:00
*/
Tone.Tremolo.prototype.dispose = function(){
2015-11-01 22:52:02 +00:00
Tone.StereoEffect.prototype.dispose.call(this);
2015-04-24 17:10:16 +00:00
this._writable(["frequency", "depth"]);
2015-11-01 22:52:02 +00:00
this._lfoL.dispose();
this._lfoL = null;
this._lfoR.dispose();
this._lfoR = null;
this._amplitudeL.dispose();
this._amplitudeL = null;
this._amplitudeR.dispose();
this._amplitudeR = null;
2015-04-24 17:10:16 +00:00
this.frequency = null;
this.depth = null;
return this;
};
return Tone.Tremolo;
2017-10-26 20:02:01 +00:00
});