Tone.js/Tone/effect/Distortion.js

106 lines
2.3 KiB
JavaScript
Raw Normal View History

import Tone from "../core/Tone";
import "../effect/Effect";
import "../signal/WaveShaper";
2014-10-19 21:54:30 +00:00
/**
* @class Tone.Distortion is a simple distortion effect using Tone.WaveShaper.
* Algorithm from [a stackoverflow answer](http://stackoverflow.com/a/22313408).
*
* @extends {Tone.Effect}
* @constructor
* @param {Number|Object} [distortion] The amount of distortion (nominal range of 0-1)
* @example
* var dist = new Tone.Distortion(0.8).toMaster();
* var fm = new Tone.SimpleFM().connect(dist);
* //this sounds good on bass notes
* fm.triggerAttackRelease("A1", "8n");
*/
Tone.Distortion = function(){
var options = Tone.defaults(arguments, ["distortion"], Tone.Distortion);
Tone.Effect.call(this, options);
2014-10-19 21:54:30 +00:00
/**
* @type {Tone.WaveShaper}
* @private
2014-10-19 21:54:30 +00:00
*/
this._shaper = new Tone.WaveShaper(4096);
2014-10-19 21:54:30 +00:00
/**
* holds the distortion amount
* @type {number}
* @private
*/
this._distortion = options.distortion;
this.connectEffect(this._shaper);
this.distortion = options.distortion;
this.oversample = options.oversample;
};
2015-02-10 16:40:27 +00:00
Tone.extend(Tone.Distortion, Tone.Effect);
2014-10-19 21:54:30 +00:00
/**
* @static
* @const
* @type {Object}
*/
Tone.Distortion.defaults = {
"distortion" : 0.4,
"oversample" : "none"
};
2014-10-19 21:54:30 +00:00
/**
* The amount of distortion.
* @memberOf Tone.Distortion#
* @type {NormalRange}
* @name distortion
*/
Object.defineProperty(Tone.Distortion.prototype, "distortion", {
get : function(){
return this._distortion;
},
set : function(amount){
this._distortion = amount;
var k = amount * 100;
var deg = Math.PI / 180;
this._shaper.setMap(function(x){
if (Math.abs(x) < 0.001){
//should output 0 when input is 0
return 0;
} else {
return (3 + k) * x * 20 * deg / (Math.PI + k * Math.abs(x));
}
});
}
});
2014-10-19 21:54:30 +00:00
/**
* The oversampling of the effect. Can either be "none", "2x" or "4x".
* @memberOf Tone.Distortion#
* @type {string}
* @name oversample
*/
Object.defineProperty(Tone.Distortion.prototype, "oversample", {
get : function(){
return this._shaper.oversample;
},
set : function(oversampling){
this._shaper.oversample = oversampling;
}
});
2014-10-19 21:54:30 +00:00
/**
* Clean up.
* @returns {Tone.Distortion} this
*/
Tone.Distortion.prototype.dispose = function(){
Tone.Effect.prototype.dispose.call(this);
this._shaper.dispose();
this._shaper = null;
return this;
};
2014-12-19 17:20:47 +00:00
export default Tone.Distortion;
2014-10-19 21:54:30 +00:00