Tone.js/Tone/effect/Convolver.js
2015-03-10 14:08:16 -04:00

89 lines
No EOL
2 KiB
JavaScript

define(["Tone/core/Tone", "Tone/core/Buffer", "Tone/effect/Effect"], function(Tone){
"use strict";
/**
* @class Convolver wrapper for reverb and emulation.
*
* @constructor
* @extends {Tone.Effect}
* @param {string|AudioBuffer=} url
* @example
* var convolver = new Tone.Convolver("./path/to/ir.wav");
*/
Tone.Convolver = function(url){
Tone.Effect.apply(this, arguments);
/**
* convolver node
* @type {ConvolverNode}
* @private
*/
this._convolver = this.context.createConvolver();
/**
* the convolution buffer
* @type {Tone.Buffer}
* @private
*/
this._buffer = new Tone.Buffer(url, function(buffer){
this.buffer = buffer;
}.bind(this));
this.connectEffect(this._convolver);
};
Tone.extend(Tone.Convolver, Tone.Effect);
/**
* The convolver's buffer
* @memberOf Tone.Convolver#
* @type {AudioBuffer}
* @name buffer
*/
Object.defineProperty(Tone.Convolver.prototype, "buffer", {
get : function(){
return this._buffer.get();
},
set : function(buffer){
this._buffer.set(buffer);
this._convolver.buffer = this._buffer.get();
}
});
/**
* Load an impulse response url as an audio buffer.
* Decodes the audio asynchronously and invokes
* the callback once the audio buffer loads.
* @param {string} url the url of the buffer to load.
* filetype support depends on the
* browser.
* @param {function=} callback
* @returns {Tone.Convolver} `this`
*/
Tone.Convolver.prototype.load = function(url, callback){
this._buffer.load(url, function(buff){
this.buffer = buff;
if (callback){
callback();
}
}.bind(this));
return this;
};
/**
* dispose and disconnect
* @returns {Tone.Convolver} `this`
*/
Tone.Convolver.prototype.dispose = function(){
Tone.Effect.prototype.dispose.call(this);
this._convolver.disconnect();
this._convolver = null;
this._buffer.dispose();
this._buffer = null;
return this;
};
return Tone.Convolver;
});