Tone.js/Tone/component/Volume.js

99 lines
2 KiB
JavaScript
Raw Normal View History

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";
/**
* @class Tone.Volume is a simple volume node, useful for creating a volume fader.
2015-03-24 20:30:04 +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(){
var options = Tone.defaults(arguments, ["volume"], Tone.Volume);
Tone.AudioNode.call(this);
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
*/
this._unmutedVolume = options.volume;
2016-05-14 21:34:23 +00:00
2015-11-01 22:49:33 +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");
//set the mute initially
this.mute = options.mute;
2015-03-24 20:30:04 +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 = {
"volume" : 0,
"mute" : false
2015-11-01 22:49:33 +00:00
};
2016-05-14 21:34:23 +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(){
return this.volume.value === -Infinity;
},
2016-05-14 21:34:23 +00:00
set : function(mute){
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;
} 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();
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;
});