2024-05-03 18:31:14 +00:00
|
|
|
import { Signal, SignalOptions } from "../../signal/Signal.js";
|
|
|
|
import { InputNode } from "../context/ToneAudioNode.js";
|
|
|
|
import { Seconds, Ticks, Time, UnitMap, UnitName } from "../type/Units.js";
|
|
|
|
import { optionsFromArguments } from "../util/Defaults.js";
|
|
|
|
import { TickParam } from "./TickParam.js";
|
2019-05-22 03:37:03 +00:00
|
|
|
|
2024-05-03 18:31:14 +00:00
|
|
|
interface TickSignalOptions<TypeName extends UnitName>
|
|
|
|
extends SignalOptions<TypeName> {
|
2019-10-28 15:37:53 +00:00
|
|
|
value: UnitMap[TypeName];
|
2019-05-22 03:37:03 +00:00
|
|
|
multiplier: number;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* TickSignal extends Tone.Signal, but adds the capability
|
|
|
|
* to calculate the number of elapsed ticks. exponential and target curves
|
|
|
|
* are approximated with multiple linear ramps.
|
|
|
|
*
|
|
|
|
* Thank you Bruno Dias, H. Sofia Pinto, and David M. Matos,
|
|
|
|
* for your [WAC paper](https://smartech.gatech.edu/bitstream/handle/1853/54588/WAC2016-49.pdf)
|
|
|
|
* describing integrating timing functions for tempo calculations.
|
|
|
|
*/
|
2024-05-03 18:31:14 +00:00
|
|
|
export class TickSignal<
|
|
|
|
TypeName extends "hertz" | "bpm",
|
|
|
|
> extends Signal<TypeName> {
|
2019-09-04 23:18:44 +00:00
|
|
|
readonly name: string = "TickSignal";
|
2019-05-22 03:37:03 +00:00
|
|
|
|
2019-09-07 23:16:04 +00:00
|
|
|
/**
|
|
|
|
* The param which controls the output signal value
|
|
|
|
*/
|
2019-10-28 15:37:53 +00:00
|
|
|
protected _param: TickParam<TypeName>;
|
2019-09-08 18:08:18 +00:00
|
|
|
readonly input: InputNode;
|
2019-05-22 03:37:03 +00:00
|
|
|
|
2019-08-21 20:59:01 +00:00
|
|
|
/**
|
|
|
|
* @param value The initial value of the signal
|
|
|
|
*/
|
2019-10-28 15:37:53 +00:00
|
|
|
constructor(value?: UnitMap[TypeName]);
|
|
|
|
constructor(options: Partial<TickSignalOptions<TypeName>>);
|
2019-05-22 03:37:03 +00:00
|
|
|
constructor() {
|
2024-05-03 18:31:14 +00:00
|
|
|
const options = optionsFromArguments(
|
|
|
|
TickSignal.getDefaults(),
|
|
|
|
arguments,
|
|
|
|
["value"]
|
|
|
|
);
|
2024-05-06 14:55:55 +00:00
|
|
|
super(options);
|
2019-05-22 03:37:03 +00:00
|
|
|
|
2019-09-08 18:08:18 +00:00
|
|
|
this.input = this._param = new TickParam({
|
2019-09-07 23:16:04 +00:00
|
|
|
context: this.context,
|
|
|
|
convert: options.convert,
|
2019-09-16 03:32:40 +00:00
|
|
|
multiplier: options.multiplier,
|
2019-09-07 23:16:04 +00:00
|
|
|
param: this._constantSource.offset,
|
|
|
|
units: options.units,
|
|
|
|
value: options.value,
|
2019-05-22 03:37:03 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2019-09-07 23:16:04 +00:00
|
|
|
static getDefaults(): TickSignalOptions<any> {
|
|
|
|
return Object.assign(Signal.getDefaults(), {
|
2019-05-22 03:37:03 +00:00
|
|
|
multiplier: 1,
|
|
|
|
units: "hertz",
|
|
|
|
value: 1,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2019-09-07 23:16:04 +00:00
|
|
|
ticksToTime(ticks: Ticks, when: Time): Seconds {
|
|
|
|
return this._param.ticksToTime(ticks, when);
|
2019-05-22 03:37:03 +00:00
|
|
|
}
|
|
|
|
|
2019-09-07 23:16:04 +00:00
|
|
|
timeToTicks(duration: Time, when: Time): Ticks {
|
|
|
|
return this._param.timeToTicks(duration, when);
|
2019-05-22 03:37:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
getTimeOfTick(tick: Ticks): Seconds {
|
2019-09-07 23:16:04 +00:00
|
|
|
return this._param.getTimeOfTick(tick);
|
2019-05-22 03:37:03 +00:00
|
|
|
}
|
|
|
|
|
2019-09-07 23:16:04 +00:00
|
|
|
getDurationOfTicks(ticks: Ticks, time: Time): Seconds {
|
|
|
|
return this._param.getDurationOfTicks(ticks, time);
|
2019-05-22 03:37:03 +00:00
|
|
|
}
|
|
|
|
|
2019-09-07 23:16:04 +00:00
|
|
|
getTicksAtTime(time: Time): Ticks {
|
|
|
|
return this._param.getTicksAtTime(time);
|
2019-05-22 03:37:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A multiplier on the bpm value. Useful for setting a PPQ relative to the base frequency value.
|
|
|
|
*/
|
|
|
|
get multiplier(): number {
|
2019-09-07 23:16:04 +00:00
|
|
|
return this._param.multiplier;
|
2019-05-22 03:37:03 +00:00
|
|
|
}
|
|
|
|
set multiplier(m: number) {
|
2019-09-07 23:16:04 +00:00
|
|
|
this._param.multiplier = m;
|
2019-05-22 03:37:03 +00:00
|
|
|
}
|
2019-07-11 03:33:12 +00:00
|
|
|
|
2019-09-07 23:16:04 +00:00
|
|
|
dispose(): this {
|
|
|
|
super.dispose();
|
|
|
|
this._param.dispose();
|
2019-07-11 03:33:12 +00:00
|
|
|
return this;
|
|
|
|
}
|
2019-05-22 03:37:03 +00:00
|
|
|
}
|