2014-07-02 19:37:17 +00:00
|
|
|
define(["Tone/core/Tone"], function(Tone){
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Threshold an incoming signal between -1 to 1
|
|
|
|
*
|
|
|
|
* Set the threshold value such that signal above the value will equal 1,
|
|
|
|
* and below will equal 0.
|
|
|
|
*
|
|
|
|
* Values below 0.5 will return 0 and values above 0.5 will return 1
|
|
|
|
*
|
|
|
|
* @constructor
|
|
|
|
* @param {number=} thresh threshold value above which the output will equal 1
|
|
|
|
* and below which the output will equal 0
|
|
|
|
* @default 0
|
|
|
|
* @extends {Tone}
|
|
|
|
*/
|
|
|
|
Tone.Threshold = function(thresh){
|
2014-07-02 21:07:40 +00:00
|
|
|
|
2014-07-02 19:37:17 +00:00
|
|
|
/**
|
|
|
|
* @type {WaveShaperNode}
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._thresh = this.context.createWaveShaper();
|
|
|
|
|
2014-07-02 21:07:40 +00:00
|
|
|
/**
|
|
|
|
* make doubly sure that the input is thresholded by
|
|
|
|
* passing it through two waveshapers
|
|
|
|
*
|
|
|
|
* @type {WaveShaperNode}
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._doubleThresh = this.context.createWaveShaper();
|
|
|
|
|
2014-07-02 19:37:17 +00:00
|
|
|
/**
|
|
|
|
* @type {WaveShaperNode}
|
|
|
|
*/
|
2014-07-02 21:07:40 +00:00
|
|
|
this.input = this._thresh;
|
|
|
|
this.output = this._doubleThresh;
|
|
|
|
|
|
|
|
this._thresh.connect(this._doubleThresh);
|
2014-07-02 19:37:17 +00:00
|
|
|
|
2014-07-02 21:07:40 +00:00
|
|
|
this._setThresh(this._thresh, this.defaultArg(thresh, 0));
|
|
|
|
this._setThresh(this._doubleThresh, 1);
|
2014-07-02 19:37:17 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
Tone.extend(Tone.Threshold);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param {number} thresh
|
|
|
|
* @private
|
|
|
|
*/
|
2014-07-02 21:07:40 +00:00
|
|
|
Tone.Threshold.prototype._setThresh = function(component, thresh){
|
2014-07-02 19:37:17 +00:00
|
|
|
var curveLength = 1024;
|
|
|
|
var curve = new Float32Array(curveLength);
|
|
|
|
for (var i = 0; i < curveLength; i++){
|
2014-07-02 21:07:40 +00:00
|
|
|
var normalized = (i / (curveLength - 1)) * 2 - 1;
|
2014-07-02 19:37:17 +00:00
|
|
|
var val;
|
|
|
|
if (normalized < thresh){
|
|
|
|
val = 0;
|
|
|
|
} else {
|
|
|
|
val = 1;
|
|
|
|
}
|
|
|
|
curve[i] = val;
|
|
|
|
}
|
2014-07-02 21:07:40 +00:00
|
|
|
component.curve = curve;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* sets the threshold value
|
|
|
|
*
|
|
|
|
* @param {number} thresh number must be between -1 and 1
|
|
|
|
*/
|
|
|
|
Tone.Threshold.prototype.setThreshold = function(thresh){
|
|
|
|
this._setThresh(this._thresh, thresh);
|
2014-07-02 19:37:17 +00:00
|
|
|
};
|
|
|
|
|
2014-07-02 19:47:05 +00:00
|
|
|
/**
|
|
|
|
* dispose method
|
|
|
|
*/
|
|
|
|
Tone.Threshold.prototype.dispose = function(){
|
|
|
|
this._thresh.disconnect();
|
2014-07-02 21:07:40 +00:00
|
|
|
this._doubleThresh.disconnect();
|
2014-07-02 19:47:05 +00:00
|
|
|
this._thresh = null;
|
2014-07-02 21:07:40 +00:00
|
|
|
this._doubleThresh = null;
|
2014-07-02 19:47:05 +00:00
|
|
|
};
|
|
|
|
|
2014-07-02 19:37:17 +00:00
|
|
|
return Tone.Threshold;
|
|
|
|
});
|