Tone.js/Tone/component/channel/Volume.js

100 lines
1.9 KiB
JavaScript
Raw Normal View History

2019-05-23 18:00:49 +00:00
import Tone from "../../core/Tone";
import "../../signal/Signal";
import "../core/Gain";
import "../core/AudioNode";
2015-03-24 20:30:04 +00:00
/**
* @class Tone.Volume is a simple volume node, useful for creating a volume fader.
*
* @extends {Tone.AudioNode}
* @constructor
* @param {Decibels} [volume=0] the initial volume
* @example
* var vol = new Tone.Volume(-12);
* instrument.chain(vol, Tone.Master);
*/
Tone.Volume = function(){
var options = Tone.defaults(arguments, ["volume"], Tone.Volume);
Tone.AudioNode.call(this, options);
2015-03-24 20:30:04 +00:00
/**
* the output node
* @type {GainNode}
* @private
2015-03-24 20:30:04 +00:00
*/
this.output = this.input = new Tone.Gain(options.volume, Tone.Type.Decibels);
2015-03-24 20:30:04 +00:00
/**
* The unmuted volume
* @type {Decibels}
* @private
*/
this._unmutedVolume = options.volume;
2016-05-14 21:34:23 +00:00
/**
* The volume control in decibels.
* @type {Decibels}
* @signal
*/
this.volume = this.output.gain;
2015-11-01 22:49:33 +00:00
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
/**
* Defaults
* @type {Object}
* @const
* @static
*/
Tone.Volume.defaults = {
"volume" : 0,
"mute" : false
};
2015-11-01 22:49:33 +00:00
/**
* Mute the output.
* @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;
},
set : function(mute){
if (!this.mute && mute){
this._unmutedVolume = this.volume.value;
//maybe it should ramp here?
this.volume.value = -Infinity;
} else if (this.mute && !mute){
this.volume.value = this._unmutedVolume;
2016-05-14 21:34:23 +00:00
}
}
});
2016-05-14 21:34:23 +00:00
/**
* clean up
* @returns {Tone.Volume} this
*/
Tone.Volume.prototype.dispose = function(){
this.input.dispose();
Tone.AudioNode.prototype.dispose.call(this);
this._writable("volume");
this.volume.dispose();
this.volume = null;
return this;
};
export default Tone.Volume;
2015-03-24 20:30:04 +00:00