2019-01-27 18:05:20 +00:00
|
|
|
import Tone from "../core/Tone";
|
|
|
|
import "../component/Analyser";
|
|
|
|
import "../core/AudioNode";
|
2017-08-31 14:56:19 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
/**
|
2019-04-11 21:43:21 +00:00
|
|
|
* @class Get the current frequency data of the connected audio source
|
|
|
|
* using a fast Fourier transform.
|
2019-01-27 18:05:20 +00:00
|
|
|
* @extends {Tone.AudioNode}
|
|
|
|
* @param {Number=} size The size of the FFT. Value must be a power of
|
2019-04-12 14:45:35 +00:00
|
|
|
* two in the range 16 to 16384.
|
2019-01-27 18:05:20 +00:00
|
|
|
*/
|
|
|
|
Tone.FFT = function(){
|
2017-08-31 14:56:19 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
var options = Tone.defaults(arguments, ["size"], Tone.FFT);
|
|
|
|
options.type = Tone.Analyser.Type.FFT;
|
|
|
|
Tone.AudioNode.call(this);
|
2017-08-31 14:56:19 +00:00
|
|
|
|
|
|
|
/**
|
2019-01-27 18:05:20 +00:00
|
|
|
* The analyser node.
|
|
|
|
* @private
|
|
|
|
* @type {Tone.Analyser}
|
2017-08-31 14:56:19 +00:00
|
|
|
*/
|
2019-01-27 18:05:20 +00:00
|
|
|
this._analyser = this.input = this.output = new Tone.Analyser(options);
|
|
|
|
};
|
2017-08-31 14:56:19 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
Tone.extend(Tone.FFT, Tone.AudioNode);
|
2017-08-31 14:56:19 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
/**
|
|
|
|
* The default values.
|
|
|
|
* @type {Object}
|
|
|
|
* @const
|
|
|
|
*/
|
|
|
|
Tone.FFT.defaults = {
|
|
|
|
"size" : 1024
|
|
|
|
};
|
2017-08-31 14:56:19 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
/**
|
|
|
|
* Gets the current frequency data from the connected audio source.
|
|
|
|
* Returns the frequency data of length [size](#size) as a Float32Array of decibel values.
|
|
|
|
* @returns {TypedArray}
|
|
|
|
*/
|
|
|
|
Tone.FFT.prototype.getValue = function(){
|
|
|
|
return this._analyser.getValue();
|
|
|
|
};
|
2017-08-31 14:56:19 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
/**
|
2019-04-12 14:45:35 +00:00
|
|
|
* The size of analysis. This must be a power of two in the range 16 to 16384.
|
|
|
|
* Determines the size of the array returned by [getValue](#getvalue) (i.e. the number of
|
|
|
|
* frequency bins). Large FFT sizes may be costly to compute.
|
2019-01-27 18:05:20 +00:00
|
|
|
* @memberOf Tone.FFT#
|
|
|
|
* @type {Number}
|
|
|
|
* @name size
|
|
|
|
*/
|
|
|
|
Object.defineProperty(Tone.FFT.prototype, "size", {
|
|
|
|
get : function(){
|
|
|
|
return this._analyser.size;
|
|
|
|
},
|
|
|
|
set : function(size){
|
|
|
|
this._analyser.size = size;
|
|
|
|
}
|
2017-08-31 14:56:19 +00:00
|
|
|
});
|
2019-01-27 18:05:20 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Clean up.
|
|
|
|
* @return {Tone.FFT} this
|
|
|
|
*/
|
|
|
|
Tone.FFT.prototype.dispose = function(){
|
|
|
|
Tone.AudioNode.prototype.dispose.call(this);
|
|
|
|
this._analyser.dispose();
|
|
|
|
this._analyser = null;
|
|
|
|
};
|
|
|
|
|
|
|
|
export default Tone.FFT;
|
|
|
|
|