2019-01-27 18:05:20 +00:00
|
|
|
import Tone from "../core/Tone";
|
|
|
|
import "../core/Param";
|
|
|
|
import "../core/Gain";
|
|
|
|
import "../signal/SignalBase";
|
2014-04-16 20:47:25 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
/**
|
|
|
|
* @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-09-04 04:41:40 +00:00
|
|
|
|
2014-06-17 00:05:54 +00:00
|
|
|
/**
|
2019-01-27 18:05:20 +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
|
|
|
*
|
2019-01-27 18:05:20 +00:00
|
|
|
* @type {GainNode}
|
|
|
|
* @private
|
2014-06-17 00:05:54 +00:00
|
|
|
*/
|
2019-01-27 18:05:20 +00:00
|
|
|
this._mult = this.input[0] = this.output = new Tone.Gain();
|
2014-10-23 01:20:43 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
/**
|
|
|
|
* the scaling parameter
|
|
|
|
* @type {AudioParam}
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._param = this.input[1] = this.output.gain;
|
|
|
|
this.value = Tone.defaultArg(value, 0);
|
|
|
|
};
|
2014-10-23 01:20:43 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
Tone.extend(Tone.Multiply, Tone.Signal);
|
2014-04-16 20:47:25 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
/**
|
|
|
|
* 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;
|
|
|
|
};
|
2018-06-06 01:53:28 +00:00
|
|
|
|
2019-01-27 18:05:20 +00:00
|
|
|
export default Tone.Multiply;
|
2014-06-20 04:38:14 +00:00
|
|
|
|