Tone.js/Tone/signal/Switch.js
2015-04-05 14:25:01 -04:00

87 lines
No EOL
2.2 KiB
JavaScript

define(["Tone/core/Tone", "Tone/signal/SignalBase", "Tone/signal/GreaterThan"], function(Tone){
"use strict";
/**
* @class When the gate is set to 0, the input signal does not pass through to the output.
* If the gate is set to 1, the input signal passes through.
* the gate is initially closed.
*
* @constructor
* @extends {Tone.SignalBase}
* @example
* var sigSwitch = new Tone.Switch();
* var signal = new Tone.Signal(2).connect(sigSwitch);
* //initially no output from sigSwitch
* sigSwitch.gate.value = 1;
* //open the switch and allow the signal through
* //the output of sigSwitch is now 2.
*/
Tone.Switch = function(){
Tone.call(this);
/**
* the control signal for the switch
* when this value is 0, the input signal will not pass through,
* when it is high (1), the input signal will pass through.
*
* @type {Tone.Signal}
*/
this.gate = new Tone.Signal(0);
this._readOnly("gate");
/**
* thresh the control signal to either 0 or 1
* @type {Tone.GreaterThan}
* @private
*/
this._thresh = new Tone.GreaterThan(0.5);
this.input.connect(this.output);
this.gate.chain(this._thresh, this.output.gain);
};
Tone.extend(Tone.Switch, Tone.SignalBase);
/**
* open the switch at a specific time
*
* @param {Tone.Time=} time the time when the switch will be open
* @returns {Tone.Switch} `this`
* @example
* //open the switch to let the signal through
* sigSwitch.open();
*/
Tone.Switch.prototype.open = function(time){
this.gate.setValueAtTime(1, this.toSeconds(time));
return this;
};
/**
* close the switch at a specific time
*
* @param {Tone.Time} time the time when the switch will be open
* @returns {Tone.Switch} `this`
* @example
* //close the switch a half second from now
* sigSwitch.close("+0.5");
*/
Tone.Switch.prototype.close = function(time){
this.gate.setValueAtTime(0, this.toSeconds(time));
return this;
};
/**
* clean up
* @returns {Tone.Switch} `this`
*/
Tone.Switch.prototype.dispose = function(){
Tone.prototype.dispose.call(this);
this.gate.dispose();
this._thresh.dispose();
this._thresh = null;
return this;
};
return Tone.Switch;
});