mirror of
https://github.com/Tonejs/Tone.js
synced 2025-01-23 00:55:02 +00:00
63 lines
1.6 KiB
JavaScript
63 lines
1.6 KiB
JavaScript
define(["Tone/core/Tone", "Tone/signal/Signal"], function(Tone){
|
|
|
|
"use strict";
|
|
|
|
/**
|
|
* @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.call(this, 2, 0);
|
|
|
|
/**
|
|
* the input node is the same as the output node
|
|
* it is also the GainNode which handles the scaling of incoming signal
|
|
*
|
|
* @type {GainNode}
|
|
* @private
|
|
*/
|
|
this._mult = this.input[0] = this.output = this.context.createGain();
|
|
|
|
/**
|
|
* the scaling parameter
|
|
* @type {AudioParam}
|
|
* @private
|
|
*/
|
|
this._value = this.input[1] = this.output.gain;
|
|
|
|
this._value.value = this.defaultArg(value, 0);
|
|
};
|
|
|
|
Tone.extend(Tone.Multiply, Tone.Signal);
|
|
|
|
/**
|
|
* clean up
|
|
* @returns {Tone.Multiply} this
|
|
*/
|
|
Tone.Multiply.prototype.dispose = function(){
|
|
Tone.prototype.dispose.call(this);
|
|
this._mult.disconnect();
|
|
this._mult = null;
|
|
this._value = null;
|
|
return this;
|
|
};
|
|
|
|
return Tone.Multiply;
|
|
});
|