2024-05-03 18:31:14 +00:00
|
|
|
import { Gain } from "../core/context/Gain.js";
|
|
|
|
import { Param } from "../core/context/Param.js";
|
|
|
|
import { optionsFromArguments } from "../core/util/Defaults.js";
|
|
|
|
import { Signal, SignalOptions } from "./Signal.js";
|
|
|
|
import { InputNode, OutputNode } from "../core/context/ToneAudioNode.js";
|
2019-07-11 21:11:17 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Multiply two incoming signals. Or, if a number is given in the constructor,
|
|
|
|
* multiplies the incoming signal by that value.
|
|
|
|
*
|
|
|
|
* @example
|
2019-10-25 20:54:33 +00:00
|
|
|
* // multiply two signals
|
2020-04-17 02:24:18 +00:00
|
|
|
* const mult = new Tone.Multiply();
|
|
|
|
* const sigA = new Tone.Signal(3);
|
|
|
|
* const sigB = new Tone.Signal(4);
|
2019-07-11 21:11:17 +00:00
|
|
|
* sigA.connect(mult);
|
|
|
|
* sigB.connect(mult.factor);
|
2019-10-25 20:54:33 +00:00
|
|
|
* // output of mult is 12.
|
2019-08-27 15:53:14 +00:00
|
|
|
* @example
|
2019-10-25 20:54:33 +00:00
|
|
|
* // multiply a signal and a number
|
2020-04-17 02:24:18 +00:00
|
|
|
* const mult = new Tone.Multiply(10);
|
|
|
|
* const sig = new Tone.Signal(2).connect(mult);
|
2019-10-25 20:54:33 +00:00
|
|
|
* // the output of mult is 20.
|
2019-09-16 14:15:23 +00:00
|
|
|
* @category Signal
|
2019-07-11 21:11:17 +00:00
|
|
|
*/
|
2024-05-03 18:31:14 +00:00
|
|
|
export class Multiply<
|
|
|
|
TypeName extends "number" | "positive" = "number",
|
|
|
|
> extends Signal<TypeName> {
|
2019-09-04 23:18:44 +00:00
|
|
|
readonly name: string = "Multiply";
|
2019-07-11 21:11:17 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Indicates if the value should be overridden on connection
|
|
|
|
*/
|
|
|
|
readonly override = false;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* the input gain node
|
|
|
|
*/
|
2019-12-15 07:19:25 +00:00
|
|
|
private _mult: Gain;
|
2019-07-11 21:11:17 +00:00
|
|
|
|
|
|
|
/**
|
2019-09-08 17:48:31 +00:00
|
|
|
* The multiplicand input.
|
2019-07-11 21:11:17 +00:00
|
|
|
*/
|
2019-12-15 07:19:25 +00:00
|
|
|
input: InputNode;
|
2019-07-11 21:11:17 +00:00
|
|
|
|
|
|
|
/**
|
2024-04-29 14:48:37 +00:00
|
|
|
* The product of the input and {@link factor}
|
2019-07-11 21:11:17 +00:00
|
|
|
*/
|
2019-12-15 07:19:25 +00:00
|
|
|
output: OutputNode;
|
2019-07-11 21:11:17 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The multiplication factor. Can be set directly or a signal can be connected to it.
|
|
|
|
*/
|
2019-10-28 15:37:53 +00:00
|
|
|
factor: Param<TypeName>;
|
2019-07-11 21:11:17 +00:00
|
|
|
|
2019-08-27 15:53:14 +00:00
|
|
|
/**
|
|
|
|
* @param value Constant value to multiple
|
|
|
|
*/
|
2019-07-11 21:11:17 +00:00
|
|
|
constructor(value?: number);
|
2019-10-28 15:37:53 +00:00
|
|
|
constructor(options?: Partial<SignalOptions<TypeName>>);
|
2019-07-11 21:11:17 +00:00
|
|
|
constructor() {
|
2024-05-03 18:31:14 +00:00
|
|
|
super(
|
|
|
|
Object.assign(
|
|
|
|
optionsFromArguments(Multiply.getDefaults(), arguments, [
|
|
|
|
"value",
|
|
|
|
])
|
|
|
|
)
|
|
|
|
);
|
|
|
|
const options = optionsFromArguments(
|
|
|
|
Multiply.getDefaults(),
|
|
|
|
arguments,
|
|
|
|
["value"]
|
|
|
|
);
|
2019-07-11 21:11:17 +00:00
|
|
|
|
2024-05-03 18:31:14 +00:00
|
|
|
this._mult =
|
|
|
|
this.input =
|
|
|
|
this.output =
|
|
|
|
new Gain({
|
|
|
|
context: this.context,
|
|
|
|
minValue: options.minValue,
|
|
|
|
maxValue: options.maxValue,
|
|
|
|
});
|
2019-12-15 07:19:25 +00:00
|
|
|
|
2024-05-03 18:31:14 +00:00
|
|
|
this.factor = this._param = this._mult
|
|
|
|
.gain as unknown as Param<TypeName>;
|
2019-07-11 21:11:17 +00:00
|
|
|
this.factor.setValueAtTime(options.value, 0);
|
|
|
|
}
|
|
|
|
|
2019-10-28 15:37:53 +00:00
|
|
|
static getDefaults(): SignalOptions<any> {
|
2019-07-11 21:11:17 +00:00
|
|
|
return Object.assign(Signal.getDefaults(), {
|
|
|
|
value: 0,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
dispose(): this {
|
|
|
|
super.dispose();
|
|
|
|
this._mult.dispose();
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
}
|