2018-08-27 02:29:17 +00:00
|
|
|
define(["../core/Tone", "../core/Buffer", "../effect/Effect"], function(Tone){
|
2014-10-22 21:58:03 +00:00
|
|
|
|
2014-10-23 15:42:41 +00:00
|
|
|
"use strict";
|
2014-10-22 21:58:03 +00:00
|
|
|
|
|
|
|
/**
|
2017-10-21 23:02:46 +00:00
|
|
|
* @class Tone.Convolver is a wrapper around the Native Web Audio
|
2015-07-04 19:25:37 +00:00
|
|
|
* [ConvolverNode](http://webaudio.github.io/web-audio-api/#the-convolvernode-interface).
|
2015-07-04 16:40:33 +00:00
|
|
|
* Convolution is useful for reverb and filter emulation. Read more about convolution reverb on
|
2015-07-04 19:25:37 +00:00
|
|
|
* [Wikipedia](https://en.wikipedia.org/wiki/Convolution_reverb).
|
2017-10-21 23:02:46 +00:00
|
|
|
*
|
2014-10-23 15:42:41 +00:00
|
|
|
* @constructor
|
|
|
|
* @extends {Tone.Effect}
|
2015-06-22 05:20:57 +00:00
|
|
|
* @param {string|Tone.Buffer|Object} [url] The URL of the impulse response or the Tone.Buffer
|
2017-10-21 23:02:46 +00:00
|
|
|
* contianing the impulse response.
|
2017-12-16 04:36:39 +00:00
|
|
|
* @param {Function=} onload The callback to invoke when the url is loaded.
|
2015-02-27 21:53:10 +00:00
|
|
|
* @example
|
2015-07-04 16:40:33 +00:00
|
|
|
* //initializing the convolver with an impulse response
|
2016-09-19 00:05:01 +00:00
|
|
|
* var convolver = new Tone.Convolver("./path/to/ir.wav").toMaster();
|
2014-10-22 21:58:03 +00:00
|
|
|
*/
|
2015-04-24 21:45:12 +00:00
|
|
|
Tone.Convolver = function(){
|
2014-10-22 21:58:03 +00:00
|
|
|
|
2017-04-26 03:18:08 +00:00
|
|
|
var options = Tone.defaults(arguments, ["url", "onload"], Tone.Convolver);
|
2015-04-24 21:45:12 +00:00
|
|
|
Tone.Effect.call(this, options);
|
2014-10-22 21:58:03 +00:00
|
|
|
|
2017-10-21 23:02:46 +00:00
|
|
|
/**
|
2014-10-23 15:42:41 +00:00
|
|
|
* convolver node
|
|
|
|
* @type {ConvolverNode}
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._convolver = this.context.createConvolver();
|
2014-10-22 21:58:03 +00:00
|
|
|
|
2014-10-23 15:42:41 +00:00
|
|
|
/**
|
|
|
|
* the convolution buffer
|
2015-01-05 02:46:10 +00:00
|
|
|
* @type {Tone.Buffer}
|
2014-10-23 15:42:41 +00:00
|
|
|
* @private
|
|
|
|
*/
|
2017-12-16 04:36:39 +00:00
|
|
|
this._buffer = new Tone.Buffer(options.url, function(buffer){
|
2018-10-22 01:27:35 +00:00
|
|
|
this.buffer = buffer.get();
|
2016-11-07 01:13:18 +00:00
|
|
|
options.onload();
|
2017-12-16 04:36:39 +00:00
|
|
|
}.bind(this));
|
2014-10-22 21:58:03 +00:00
|
|
|
|
2018-10-22 01:27:35 +00:00
|
|
|
//set if it's already loaded
|
|
|
|
if (this._buffer.loaded){
|
|
|
|
this.buffer = this._buffer;
|
|
|
|
}
|
|
|
|
|
2018-09-10 16:17:51 +00:00
|
|
|
//initially set normalization
|
|
|
|
this.normalize = options.normalize;
|
|
|
|
|
2014-10-23 15:42:41 +00:00
|
|
|
this.connectEffect(this._convolver);
|
|
|
|
};
|
2014-10-22 21:58:03 +00:00
|
|
|
|
2014-10-23 15:42:41 +00:00
|
|
|
Tone.extend(Tone.Convolver, Tone.Effect);
|
2014-10-22 21:58:03 +00:00
|
|
|
|
2015-04-24 21:45:12 +00:00
|
|
|
/**
|
|
|
|
* @static
|
|
|
|
* @const
|
|
|
|
* @type {Object}
|
|
|
|
*/
|
|
|
|
Tone.Convolver.defaults = {
|
2018-09-10 16:17:51 +00:00
|
|
|
"onload" : Tone.noOp,
|
|
|
|
"normalize" : true
|
2015-04-24 21:45:12 +00:00
|
|
|
};
|
|
|
|
|
2015-02-23 05:28:07 +00:00
|
|
|
/**
|
|
|
|
* The convolver's buffer
|
|
|
|
* @memberOf Tone.Convolver#
|
|
|
|
* @type {AudioBuffer}
|
|
|
|
* @name buffer
|
|
|
|
*/
|
|
|
|
Object.defineProperty(Tone.Convolver.prototype, "buffer", {
|
2018-08-07 03:46:41 +00:00
|
|
|
"get" : function(){
|
2018-10-22 01:27:35 +00:00
|
|
|
if (this._buffer.length){
|
|
|
|
return this._buffer;
|
|
|
|
} else {
|
|
|
|
return null;
|
|
|
|
}
|
2015-02-23 05:28:07 +00:00
|
|
|
},
|
2018-08-07 03:46:41 +00:00
|
|
|
"set" : function(buffer){
|
2015-02-23 05:28:07 +00:00
|
|
|
this._buffer.set(buffer);
|
2018-10-22 01:27:35 +00:00
|
|
|
//if it's already got a buffer, create a new one
|
|
|
|
if (this._convolver.buffer){
|
|
|
|
//disconnect the old one
|
|
|
|
this.effectSend.disconnect();
|
|
|
|
this._convolver.disconnect();
|
|
|
|
//create and connect a new one
|
|
|
|
this._convolver = this.context.createConvolver();
|
|
|
|
this.connectEffect(this._convolver);
|
|
|
|
}
|
2015-03-10 18:08:16 +00:00
|
|
|
this._convolver.buffer = this._buffer.get();
|
2015-02-23 05:28:07 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2018-09-10 16:17:51 +00:00
|
|
|
/**
|
|
|
|
* The normalize property of the ConvolverNode interface is a boolean that controls whether the impulse response from the buffer will be scaled by an equal-power normalization when the buffer attribute is set, or not.
|
|
|
|
* @memberOf Tone.Convolver#
|
|
|
|
* @type {Boolean}
|
|
|
|
* @name normalize
|
|
|
|
*/
|
|
|
|
Object.defineProperty(Tone.Convolver.prototype, "normalize", {
|
|
|
|
"get" : function(){
|
|
|
|
return this._convolver.normalize;
|
|
|
|
},
|
|
|
|
"set" : function(norm){
|
|
|
|
this._convolver.normalize = norm;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2014-10-23 15:42:41 +00:00
|
|
|
/**
|
2015-02-27 21:53:10 +00:00
|
|
|
* Load an impulse response url as an audio buffer.
|
2014-10-23 15:42:41 +00:00
|
|
|
* Decodes the audio asynchronously and invokes
|
|
|
|
* the callback once the audio buffer loads.
|
2015-06-22 05:20:57 +00:00
|
|
|
* @param {string} url The url of the buffer to load.
|
2014-10-23 15:42:41 +00:00
|
|
|
* filetype support depends on the
|
|
|
|
* browser.
|
2015-02-23 05:28:07 +00:00
|
|
|
* @param {function=} callback
|
2016-11-22 18:31:06 +00:00
|
|
|
* @returns {Promise}
|
2014-10-23 15:42:41 +00:00
|
|
|
*/
|
|
|
|
Tone.Convolver.prototype.load = function(url, callback){
|
2016-11-22 18:31:06 +00:00
|
|
|
return this._buffer.load(url, function(buff){
|
2015-02-23 05:28:07 +00:00
|
|
|
this.buffer = buff;
|
2015-01-06 02:49:21 +00:00
|
|
|
if (callback){
|
2015-02-23 05:28:07 +00:00
|
|
|
callback();
|
2015-01-06 02:49:21 +00:00
|
|
|
}
|
2015-02-23 05:28:07 +00:00
|
|
|
}.bind(this));
|
2014-10-23 15:42:41 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
2017-10-21 23:02:46 +00:00
|
|
|
* Clean up.
|
2015-06-14 00:54:29 +00:00
|
|
|
* @returns {Tone.Convolver} this
|
2014-10-23 15:42:41 +00:00
|
|
|
*/
|
|
|
|
Tone.Convolver.prototype.dispose = function(){
|
|
|
|
Tone.Effect.prototype.dispose.call(this);
|
2015-01-05 02:46:10 +00:00
|
|
|
this._buffer.dispose();
|
2014-10-23 15:42:41 +00:00
|
|
|
this._buffer = null;
|
2018-08-07 03:46:41 +00:00
|
|
|
this._convolver.disconnect();
|
|
|
|
this._convolver = null;
|
2015-02-02 18:22:16 +00:00
|
|
|
return this;
|
2017-10-21 23:02:46 +00:00
|
|
|
};
|
2014-10-23 15:42:41 +00:00
|
|
|
|
|
|
|
return Tone.Convolver;
|
2017-10-21 23:02:46 +00:00
|
|
|
});
|