Tone.js/Tone/signal/Multiply.js

66 lines
1.6 KiB
JavaScript
Raw Normal View History

import Tone from "../core/Tone";
import "../core/Param";
import "../core/Gain";
import "../signal/SignalBase";
/**
* @class Multiply two incoming signals. Or, if a number is given in the constructor,
* multiplies the incoming signal by that value.
*
* @constructor
* @extends {Tone.Signal}
* @param {number=} value Constant value to multiple. If no value is provided,
* it will return the product of the first and second inputs
* @example
* var mult = new Tone.Multiply();
* var sigA = new Tone.Signal(3);
* var sigB = new Tone.Signal(4);
* sigA.connect(mult, 0, 0);
* sigB.connect(mult, 0, 1);
* //output of mult is 12.
* @example
* var mult = new Tone.Multiply(10);
* var sig = new Tone.Signal(2).connect(mult);
* //the output of mult is 20.
*/
Tone.Multiply = function(value){
Tone.Signal.call(this);
this.createInsOuts(2, 0);
2014-06-17 00:05:54 +00:00
/**
* the input node is the same as the output node
* it is also the GainNode which handles the scaling of incoming signal
2014-06-17 00:05:54 +00:00
*
* @type {GainNode}
* @private
2014-06-17 00:05:54 +00:00
*/
this._mult = this.input[0] = this.output = new Tone.Gain();
2014-10-23 01:20:43 +00:00
/**
* the scaling parameter
* @type {AudioParam}
* @private
*/
this._param = this.input[1] = this.output.gain;
this.value = Tone.defaultArg(value, 0);
this.proxy = false;
};
2014-10-23 01:20:43 +00:00
Tone.extend(Tone.Multiply, Tone.Signal);
/**
* clean up
* @returns {Tone.Multiply} this
*/
Tone.Multiply.prototype.dispose = function(){
Tone.Signal.prototype.dispose.call(this);
this._mult.dispose();
this._mult = null;
this._param = null;
return this;
};
export default Tone.Multiply;
2014-06-20 04:38:14 +00:00