2019-01-27 18:05:20 +00:00
|
|
|
import Tone from "../core/Tone";
|
|
|
|
import "../signal/Abs";
|
|
|
|
import "../signal/Subtract";
|
|
|
|
import "../signal/Signal";
|
|
|
|
import "../type/Type";
|
|
|
|
import "../core/Delay";
|
|
|
|
import "../core/AudioNode";
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @class Tone.Follower is a crude envelope follower which will follow
|
|
|
|
* the amplitude of an incoming signal. Read more about envelope followers (also known
|
|
|
|
* as envelope detectors) on [Wikipedia](https://en.wikipedia.org/wiki/Envelope_detector).
|
|
|
|
*
|
|
|
|
* @constructor
|
|
|
|
* @extends {Tone.AudioNode}
|
|
|
|
* @param {Time} [smoothing=0.05] The rate of change of the follower.
|
|
|
|
* @example
|
|
|
|
* var follower = new Tone.Follower(0.3);
|
|
|
|
*/
|
|
|
|
Tone.Follower = function(){
|
|
|
|
|
|
|
|
var options = Tone.defaults(arguments, ["smoothing"], Tone.Follower);
|
|
|
|
Tone.AudioNode.call(this);
|
|
|
|
this.createInsOuts(1, 1);
|
2014-09-04 04:41:40 +00:00
|
|
|
|
2014-06-30 15:34:52 +00:00
|
|
|
/**
|
2019-01-27 18:05:20 +00:00
|
|
|
* @type {Tone.Abs}
|
|
|
|
* @private
|
2014-06-30 15:34:52 +00:00
|
|
|
*/
|
2019-01-27 18:05:20 +00:00
|
|
|
this._abs = new Tone.Abs();
|
2014-07-02 22:20:34 +00:00
|
|
|
|
2014-08-24 23:28:42 +00:00
|
|
|
/**
|
2019-01-27 18:05:20 +00:00
|
|
|
* the lowpass filter which smooths the input
|
|
|
|
* @type {BiquadFilterNode}
|
|
|
|
* @private
|
2014-08-24 23:28:42 +00:00
|
|
|
*/
|
2019-01-27 18:05:20 +00:00
|
|
|
this._filter = this.context.createBiquadFilter();
|
|
|
|
this._filter.type = "lowpass";
|
|
|
|
this._filter.frequency.value = 0;
|
|
|
|
this._filter.Q.value = 0;
|
2014-07-23 19:25:46 +00:00
|
|
|
|
2014-08-25 13:57:36 +00:00
|
|
|
/**
|
2019-01-27 18:05:20 +00:00
|
|
|
* @type {Tone.Subtract}
|
|
|
|
* @private
|
2014-08-25 13:57:36 +00:00
|
|
|
*/
|
2019-01-27 18:05:20 +00:00
|
|
|
this._sub = new Tone.Subtract();
|
2014-08-25 13:57:36 +00:00
|
|
|
|
2014-08-29 20:36:52 +00:00
|
|
|
/**
|
2019-01-27 18:05:20 +00:00
|
|
|
* delay node to compare change over time
|
|
|
|
* @type {Tone.Delay}
|
|
|
|
* @private
|
2014-08-29 20:36:52 +00:00
|
|
|
*/
|
2019-01-27 18:05:20 +00:00
|
|
|
this._delay = new Tone.Delay(this.blockTime);
|
2014-08-29 20:36:52 +00:00
|
|
|
|
2014-07-02 22:20:34 +00:00
|
|
|
/**
|
2019-01-27 18:05:20 +00:00
|
|
|
* the smoothing value
|
|
|
|
* @private
|
|
|
|
* @type {Number}
|
2014-07-02 22:20:34 +00:00
|
|
|
*/
|
2019-01-27 18:05:20 +00:00
|
|
|
this._smoothing = options.smoothing;
|
|
|
|
|
2019-01-28 16:02:15 +00:00
|
|
|
Tone.connect(this.input, this._delay);
|
|
|
|
Tone.connect(this.input, this._sub, 0, 1);
|
2019-01-27 18:05:20 +00:00
|
|
|
this._sub.chain(this._abs, this._filter, this.output);
|
|
|
|
|
|
|
|
//set the smoothing initially
|
|
|
|
this.smoothing = options.smoothing;
|
|
|
|
};
|
|
|
|
|
|
|
|
Tone.extend(Tone.Follower, Tone.AudioNode);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @static
|
|
|
|
* @type {Object}
|
|
|
|
*/
|
|
|
|
Tone.Follower.defaults = {
|
|
|
|
"smoothing" : 0.05,
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The attack time.
|
|
|
|
* @memberOf Tone.Follower#
|
|
|
|
* @type {Time}
|
|
|
|
* @name smoothing
|
|
|
|
*/
|
|
|
|
Object.defineProperty(Tone.Follower.prototype, "smoothing", {
|
|
|
|
get : function(){
|
|
|
|
return this._smoothing;
|
|
|
|
},
|
|
|
|
set : function(smoothing){
|
|
|
|
this._smoothing = smoothing;
|
|
|
|
this._filter.frequency.value = Tone.Time(smoothing).toFrequency() * 0.5;
|
|
|
|
}
|
2017-08-27 21:50:31 +00:00
|
|
|
});
|
2019-01-27 18:05:20 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Borrows the connect method from Signal so that the output can be used
|
|
|
|
* as a Tone.Signal control signal.
|
|
|
|
* @function
|
|
|
|
*/
|
|
|
|
Tone.Follower.prototype.connect = Tone.SignalBase.prototype.connect;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* dispose
|
|
|
|
* @returns {Tone.Follower} this
|
|
|
|
*/
|
|
|
|
Tone.Follower.prototype.dispose = function(){
|
|
|
|
Tone.AudioNode.prototype.dispose.call(this);
|
|
|
|
this._filter.disconnect();
|
|
|
|
this._filter = null;
|
|
|
|
this._delay.dispose();
|
|
|
|
this._delay = null;
|
|
|
|
this._sub.disconnect();
|
|
|
|
this._sub = null;
|
|
|
|
this._abs.dispose();
|
|
|
|
this._abs = null;
|
|
|
|
return this;
|
|
|
|
};
|
|
|
|
|
|
|
|
export default Tone.Follower;
|
|
|
|
|