2017-08-27 21:50:31 +00:00
|
|
|
define(["Tone/core/Tone", "Tone/signal/Signal", "Tone/core/Gain", "Tone/core/AudioNode"], function(Tone){
|
2015-03-24 20:30:04 +00:00
|
|
|
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
/**
|
2017-08-27 21:50:31 +00:00
|
|
|
* @class Tone.Volume is a simple volume node, useful for creating a volume fader.
|
2015-03-24 20:30:04 +00:00
|
|
|
*
|
2017-08-27 21:50:31 +00:00
|
|
|
* @extends {Tone.AudioNode}
|
2015-03-24 20:30:04 +00:00
|
|
|
* @constructor
|
2015-06-20 19:50:57 +00:00
|
|
|
* @param {Decibels} [volume=0] the initial volume
|
2015-03-24 20:30:04 +00:00
|
|
|
* @example
|
2015-06-14 05:09:06 +00:00
|
|
|
* var vol = new Tone.Volume(-12);
|
|
|
|
* instrument.chain(vol, Tone.Master);
|
2015-03-24 20:30:04 +00:00
|
|
|
*/
|
2015-08-28 22:32:32 +00:00
|
|
|
Tone.Volume = function(){
|
|
|
|
|
2017-04-26 03:08:23 +00:00
|
|
|
var options = Tone.defaults(arguments, ["volume"], Tone.Volume);
|
2018-07-28 14:20:36 +00:00
|
|
|
Tone.AudioNode.call(this, options);
|
2015-03-24 20:30:04 +00:00
|
|
|
|
2015-11-01 22:49:33 +00:00
|
|
|
/**
|
|
|
|
* the output node
|
|
|
|
* @type {GainNode}
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this.output = this.input = new Tone.Gain(options.volume, Tone.Type.Decibels);
|
|
|
|
|
2016-05-14 21:34:23 +00:00
|
|
|
/**
|
|
|
|
* The unmuted volume
|
|
|
|
* @type {Decibels}
|
|
|
|
* @private
|
|
|
|
*/
|
2017-03-26 20:40:00 +00:00
|
|
|
this._unmutedVolume = options.volume;
|
2016-05-14 21:34:23 +00:00
|
|
|
|
2015-11-01 22:49:33 +00:00
|
|
|
/**
|
2017-08-27 21:50:31 +00:00
|
|
|
* The volume control in decibels.
|
2015-11-01 22:49:33 +00:00
|
|
|
* @type {Decibels}
|
|
|
|
* @signal
|
|
|
|
*/
|
|
|
|
this.volume = this.output.gain;
|
|
|
|
|
|
|
|
this._readOnly("volume");
|
2016-05-14 21:46:21 +00:00
|
|
|
|
|
|
|
//set the mute initially
|
|
|
|
this.mute = options.mute;
|
2015-03-24 20:30:04 +00:00
|
|
|
};
|
|
|
|
|
2017-08-27 21:50:31 +00:00
|
|
|
Tone.extend(Tone.Volume, Tone.AudioNode);
|
2015-03-24 20:30:04 +00:00
|
|
|
|
2015-08-28 22:32:32 +00:00
|
|
|
/**
|
|
|
|
* Defaults
|
|
|
|
* @type {Object}
|
|
|
|
* @const
|
|
|
|
* @static
|
|
|
|
*/
|
|
|
|
Tone.Volume.defaults = {
|
2016-05-14 21:46:21 +00:00
|
|
|
"volume" : 0,
|
|
|
|
"mute" : false
|
2015-11-01 22:49:33 +00:00
|
|
|
};
|
|
|
|
|
2016-05-14 21:34:23 +00:00
|
|
|
/**
|
2017-08-27 21:50:31 +00:00
|
|
|
* Mute the output.
|
2016-05-14 21:34:23 +00:00
|
|
|
* @memberOf Tone.Volume#
|
|
|
|
* @type {boolean}
|
|
|
|
* @name mute
|
|
|
|
* @example
|
|
|
|
* //mute the output
|
|
|
|
* volume.mute = true;
|
|
|
|
*/
|
|
|
|
Object.defineProperty(Tone.Volume.prototype, "mute", {
|
|
|
|
get : function(){
|
2017-03-24 21:27:40 +00:00
|
|
|
return this.volume.value === -Infinity;
|
2017-08-27 21:50:31 +00:00
|
|
|
},
|
2016-05-14 21:34:23 +00:00
|
|
|
set : function(mute){
|
2017-03-24 21:27:40 +00:00
|
|
|
if (!this.mute && mute){
|
2016-05-14 21:34:23 +00:00
|
|
|
this._unmutedVolume = this.volume.value;
|
|
|
|
//maybe it should ramp here?
|
|
|
|
this.volume.value = -Infinity;
|
2017-03-24 21:27:40 +00:00
|
|
|
} else if (this.mute && !mute){
|
2016-05-14 21:34:23 +00:00
|
|
|
this.volume.value = this._unmutedVolume;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2015-11-01 22:49:33 +00:00
|
|
|
/**
|
|
|
|
* clean up
|
|
|
|
* @returns {Tone.Volume} this
|
|
|
|
*/
|
|
|
|
Tone.Volume.prototype.dispose = function(){
|
|
|
|
this.input.dispose();
|
2017-08-27 21:50:31 +00:00
|
|
|
Tone.AudioNode.prototype.dispose.call(this);
|
2015-11-01 22:49:33 +00:00
|
|
|
this._writable("volume");
|
|
|
|
this.volume.dispose();
|
|
|
|
this.volume = null;
|
|
|
|
return this;
|
2015-03-24 20:30:04 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
return Tone.Volume;
|
2017-08-27 21:50:31 +00:00
|
|
|
});
|