2017-10-21 23:02:46 +00:00
|
|
|
define(["Tone/core/Tone", "Tone/effect/Effect", "Tone/signal/Subtract", "Tone/signal/Modulo"], function(Tone){
|
2015-01-18 16:09:31 +00:00
|
|
|
|
2014-09-04 04:41:40 +00:00
|
|
|
"use strict";
|
2015-01-18 16:09:31 +00:00
|
|
|
|
2014-06-17 16:30:45 +00:00
|
|
|
/**
|
2017-10-21 23:02:46 +00:00
|
|
|
* @class Tone.Bitcrusher downsamples the incoming signal to a different bitdepth.
|
2015-07-04 16:40:33 +00:00
|
|
|
* Lowering the bitdepth of the signal creates distortion. Read more about Bitcrushing
|
2015-07-04 19:25:37 +00:00
|
|
|
* on [Wikipedia](https://en.wikipedia.org/wiki/Bitcrusher).
|
2014-06-17 16:30:45 +00:00
|
|
|
*
|
|
|
|
* @constructor
|
2014-08-23 18:23:54 +00:00
|
|
|
* @extends {Tone.Effect}
|
2015-06-22 05:20:57 +00:00
|
|
|
* @param {Number} bits The number of bits to downsample the signal. Nominal range
|
2017-10-21 23:02:46 +00:00
|
|
|
* of 1 to 8.
|
2015-02-27 21:53:10 +00:00
|
|
|
* @example
|
2015-07-04 16:40:33 +00:00
|
|
|
* //initialize crusher and route a synth through it
|
|
|
|
* var crusher = new Tone.BitCrusher(4).toMaster();
|
|
|
|
* var synth = new Tone.MonoSynth().connect(crusher);
|
2014-06-17 16:30:45 +00:00
|
|
|
*/
|
2014-08-25 14:23:37 +00:00
|
|
|
Tone.BitCrusher = function(){
|
2015-01-18 16:09:31 +00:00
|
|
|
|
2017-04-26 03:18:08 +00:00
|
|
|
var options = Tone.defaults(arguments, ["bits"], Tone.BitCrusher);
|
2014-08-25 14:23:37 +00:00
|
|
|
Tone.Effect.call(this, options);
|
2015-01-18 16:09:31 +00:00
|
|
|
|
2014-11-01 20:16:14 +00:00
|
|
|
var invStepSize = 1 / Math.pow(2, options.bits - 1);
|
2015-01-18 16:09:31 +00:00
|
|
|
|
2014-09-08 15:54:03 +00:00
|
|
|
/**
|
2015-02-27 18:00:20 +00:00
|
|
|
* Subtract the input signal and the modulus of the input signal
|
|
|
|
* @type {Tone.Subtract}
|
2014-09-08 15:54:03 +00:00
|
|
|
* @private
|
2014-06-18 21:39:05 +00:00
|
|
|
*/
|
2015-02-27 18:00:20 +00:00
|
|
|
this._subtract = new Tone.Subtract();
|
2015-01-18 16:09:31 +00:00
|
|
|
|
|
|
|
/**
|
2015-02-27 18:00:20 +00:00
|
|
|
* The mod function
|
|
|
|
* @type {Tone.Modulo}
|
|
|
|
* @private
|
2015-01-18 16:09:31 +00:00
|
|
|
*/
|
2015-02-27 18:00:20 +00:00
|
|
|
this._modulo = new Tone.Modulo(invStepSize);
|
2015-01-18 16:09:31 +00:00
|
|
|
|
2015-01-20 13:05:27 +00:00
|
|
|
/**
|
2015-02-27 18:00:20 +00:00
|
|
|
* keeps track of the bits
|
|
|
|
* @type {number}
|
|
|
|
* @private
|
2015-01-20 13:05:27 +00:00
|
|
|
*/
|
2015-02-27 18:00:20 +00:00
|
|
|
this._bits = options.bits;
|
2015-01-20 13:05:27 +00:00
|
|
|
|
2014-04-06 00:47:59 +00:00
|
|
|
//connect it up
|
2015-02-27 18:00:20 +00:00
|
|
|
this.effectSend.fan(this._subtract, this._modulo);
|
|
|
|
this._modulo.connect(this._subtract, 0, 1);
|
|
|
|
this._subtract.connect(this.effectReturn);
|
2014-06-17 16:30:45 +00:00
|
|
|
};
|
2015-01-18 16:09:31 +00:00
|
|
|
|
2014-08-23 18:23:54 +00:00
|
|
|
Tone.extend(Tone.BitCrusher, Tone.Effect);
|
2014-04-06 00:47:59 +00:00
|
|
|
|
2014-08-25 14:23:37 +00:00
|
|
|
/**
|
|
|
|
* the default values
|
|
|
|
* @static
|
|
|
|
* @type {Object}
|
|
|
|
*/
|
|
|
|
Tone.BitCrusher.defaults = {
|
2014-09-08 15:54:03 +00:00
|
|
|
"bits" : 4
|
2014-06-17 16:30:45 +00:00
|
|
|
};
|
2014-04-06 00:47:59 +00:00
|
|
|
|
2015-02-27 18:00:20 +00:00
|
|
|
/**
|
2017-10-21 23:02:46 +00:00
|
|
|
* The bit depth of the effect. Nominal range of 1-8.
|
2015-02-27 18:00:20 +00:00
|
|
|
* @memberOf Tone.BitCrusher#
|
|
|
|
* @type {number}
|
|
|
|
* @name bits
|
|
|
|
*/
|
|
|
|
Object.defineProperty(Tone.BitCrusher.prototype, "bits", {
|
|
|
|
get : function(){
|
|
|
|
return this._bits;
|
|
|
|
},
|
|
|
|
set : function(bits){
|
|
|
|
this._bits = bits;
|
|
|
|
var invStepSize = 1 / Math.pow(2, bits - 1);
|
|
|
|
this._modulo.value = invStepSize;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2014-06-20 04:38:14 +00:00
|
|
|
/**
|
2017-10-21 23:02:46 +00:00
|
|
|
* Clean up.
|
2015-06-14 00:54:29 +00:00
|
|
|
* @returns {Tone.BitCrusher} this
|
2014-06-20 04:38:14 +00:00
|
|
|
*/
|
|
|
|
Tone.BitCrusher.prototype.dispose = function(){
|
2014-08-23 19:51:21 +00:00
|
|
|
Tone.Effect.prototype.dispose.call(this);
|
2015-02-27 18:00:20 +00:00
|
|
|
this._subtract.dispose();
|
|
|
|
this._subtract = null;
|
|
|
|
this._modulo.dispose();
|
|
|
|
this._modulo = null;
|
2015-02-02 18:22:16 +00:00
|
|
|
return this;
|
2017-10-21 23:02:46 +00:00
|
|
|
};
|
2015-01-18 16:09:31 +00:00
|
|
|
|
2014-04-06 00:47:59 +00:00
|
|
|
return Tone.BitCrusher;
|
2015-03-05 16:06:27 +00:00
|
|
|
});
|