Tone.js/Tone/core/context/AbstractParam.ts

295 lines
9.5 KiB
TypeScript
Raw Normal View History

2024-05-03 14:10:40 +00:00
import { Time, UnitMap, UnitName } from "../type/Units.js";
2019-04-12 14:37:47 +00:00
2019-08-26 17:44:43 +00:00
/**
2024-04-29 14:48:37 +00:00
* Abstract base class for {@link Param} and {@link Signal}
2019-08-26 17:44:43 +00:00
*/
export abstract class AbstractParam<TypeName extends UnitName> {
2019-04-12 14:37:47 +00:00
/**
* Schedules a parameter value change at the given time.
* @param value The value to set the signal.
* @param time The time when the change should occur.
* @example
2020-07-26 20:55:06 +00:00
* return Tone.Offline(() => {
* const osc = new Tone.Oscillator(20).toDestination().start();
* // set the frequency to 40 at exactly 0.25 seconds
* osc.frequency.setValueAtTime(40, 0.25);
* }, 0.5, 1);
2019-04-12 14:37:47 +00:00
*/
abstract setValueAtTime(value: UnitMap[TypeName], time: Time): this;
2019-04-12 14:37:47 +00:00
/**
2019-09-14 20:39:18 +00:00
* Get the signals value at the given time. Subsequent scheduling
* may invalidate the returned value.
* @param time When to get the value
2019-04-12 14:37:47 +00:00
* @example
2020-04-29 14:06:18 +00:00
* const signal = new Tone.Signal().toDestination();
* // ramp up to '8' over 3 seconds
* signal.rampTo(8, 3);
* // ramp back down to '0' over 3 seconds
* signal.rampTo(0, 3, "+3");
2019-10-23 20:30:07 +00:00
* setInterval(() => {
* // check the value every 100 ms
2020-04-29 14:06:18 +00:00
* console.log(signal.getValueAtTime(Tone.now()));
2019-10-23 20:30:07 +00:00
* }, 100);
2019-04-12 14:37:47 +00:00
*/
abstract getValueAtTime(time: Time): UnitMap[TypeName];
/**
* Creates a schedule point with the current value at the current time.
2024-04-29 14:48:37 +00:00
* Automation methods like {@link linearRampToValueAtTime} and {@link exponentialRampToValueAtTime}
* require a starting automation value usually set by {@link setValueAtTime}. This method
* is useful since it will do a `setValueAtTime` with whatever the currently computed
2024-05-03 15:09:28 +00:00
* value at the given time is.
* @param time When to add a ramp point.
* @example
* const osc = new Tone.Oscillator().toDestination().start();
* // set the frequency to "G4" in exactly 1 second from now.
* osc.frequency.setRampPoint("+1");
* osc.frequency.linearRampToValueAtTime("C1", "+2");
*/
2019-04-12 14:37:47 +00:00
abstract setRampPoint(time: Time): this;
/**
* Schedules a linear continuous change in parameter value from the
* previous scheduled parameter value to the given value.
2020-04-29 14:06:18 +00:00
* @example
2020-07-26 20:55:06 +00:00
* return Tone.Offline(() => {
* const signal = new Tone.Signal(0).toDestination();
* // the ramp starts from the previously scheduled value
2020-07-26 20:55:06 +00:00
* signal.setValueAtTime(0, 0.1);
* signal.linearRampToValueAtTime(1, 0.4);
* }, 0.5, 1);
2019-04-12 14:37:47 +00:00
*/
2024-05-03 15:09:28 +00:00
abstract linearRampToValueAtTime(
value: UnitMap[TypeName],
time: Time
): this;
2019-04-12 14:37:47 +00:00
/**
2019-09-14 20:39:18 +00:00
* Schedules an exponential continuous change in parameter value from
* the previous scheduled parameter value to the given value.
2020-04-29 14:06:18 +00:00
* @example
2020-07-26 20:55:06 +00:00
* return Tone.Offline(() => {
* const signal = new Tone.Signal(1).toDestination();
* // the ramp starts from the previously scheduled value, which must be positive
* signal.setValueAtTime(1, 0.1);
* signal.exponentialRampToValueAtTime(0, 0.4);
2020-07-26 20:55:06 +00:00
* }, 0.5, 1);
2019-04-12 14:37:47 +00:00
*/
2024-05-03 15:09:28 +00:00
abstract exponentialRampToValueAtTime(
value: UnitMap[TypeName],
time: Time
): this;
2019-04-12 14:37:47 +00:00
/**
* Schedules an exponential continuous change in parameter value from
* the current time and current value to the given value over the
* duration of the rampTime.
* @param value The value to ramp to.
* @param rampTime the time that it takes the
2019-09-14 20:39:18 +00:00
* value to ramp from it's current value
2019-04-12 14:37:47 +00:00
* @param startTime When the ramp should start.
* @example
* const delay = new Tone.FeedbackDelay(0.5, 0.98).toDestination();
2019-10-23 20:30:07 +00:00
* // a short burst of noise through the feedback delay
* const noise = new Tone.Noise().connect(delay).start().stop("+0.1");
* // making the delay time shorter over time will also make the pitch rise
* delay.delayTime.exponentialRampTo(0.01, 20);
* @example
* return Tone.Offline(() => {
* const signal = new Tone.Signal(.1).toDestination();
* signal.exponentialRampTo(5, 0.3, 0.1);
* }, 0.5, 1);
2019-04-12 14:37:47 +00:00
*/
2024-05-03 15:09:28 +00:00
abstract exponentialRampTo(
value: UnitMap[TypeName],
rampTime: Time,
startTime?: Time
): this;
2019-04-12 14:37:47 +00:00
/**
2019-09-14 20:39:18 +00:00
* Schedules an linear continuous change in parameter value from
* the current time and current value to the given value over the
* duration of the rampTime.
2019-04-12 14:37:47 +00:00
*
* @param value The value to ramp to.
* @param rampTime the time that it takes the
2019-09-14 20:39:18 +00:00
* value to ramp from it's current value
* @param startTime When the ramp should start.
* @returns {Param} this
* @example
* const delay = new Tone.FeedbackDelay(0.5, 0.98).toDestination();
* // a short burst of noise through the feedback delay
* const noise = new Tone.Noise().connect(delay).start().stop("+0.1");
* // making the delay time shorter over time will also make the pitch rise
* delay.delayTime.linearRampTo(0.01, 20);
* @example
2020-07-26 20:55:06 +00:00
* return Tone.Offline(() => {
* const signal = new Tone.Signal(1).toDestination();
* signal.linearRampTo(0, 0.3, 0.1);
* }, 0.5, 1);
2019-04-12 14:37:47 +00:00
*/
2024-05-03 15:09:28 +00:00
abstract linearRampTo(
value: UnitMap[TypeName],
rampTime: Time,
startTime?: Time
): this;
2019-04-12 14:37:47 +00:00
/**
2019-09-14 20:39:18 +00:00
* Start exponentially approaching the target value at the given time. Since it
* is an exponential approach it will continue approaching after the ramp duration. The
* rampTime is the time that it takes to reach over 99% of the way towards the value.
* @param value The value to ramp to.
* @param rampTime the time that it takes the
2019-09-14 20:39:18 +00:00
* value to ramp from it's current value
* @param startTime When the ramp should start.
* @example
2020-04-29 14:06:18 +00:00
* @example
2020-07-26 20:55:06 +00:00
* return Tone.Offline(() => {
* const signal = new Tone.Signal(1).toDestination();
* signal.targetRampTo(0, 0.3, 0.1);
* }, 0.5, 1);
2019-04-12 14:37:47 +00:00
*/
2024-05-03 15:09:28 +00:00
abstract targetRampTo(
value: UnitMap[TypeName],
rampTime: Time,
startTime?: Time
): this;
2019-04-12 14:37:47 +00:00
/**
* Start exponentially approaching the target value at the given time. Since it
* is an exponential approach it will continue approaching after the ramp duration. The
* rampTime is the time that it takes to reach over 99% of the way towards the value. This methods
* is similar to setTargetAtTime except the third argument is a time instead of a 'timeConstant'
* @param value The value to ramp to.
* @param time When the ramp should start.
* @param rampTime the time that it takes the value to ramp from it's current value
* @example
* const osc = new Tone.Oscillator().toDestination().start();
2019-10-23 20:30:07 +00:00
* // exponential approach over 4 seconds starting in 1 second
* osc.frequency.exponentialApproachValueAtTime("C4", "+1", 4);
2019-04-12 14:37:47 +00:00
*/
2024-05-03 15:09:28 +00:00
abstract exponentialApproachValueAtTime(
value: UnitMap[TypeName],
time: Time,
rampTime: Time
): this;
2019-04-12 14:37:47 +00:00
/**
* Start exponentially approaching the target value at the given time with
* a rate having the given time constant.
* @param value
* @param startTime
* @param timeConstant
*/
2024-05-03 15:09:28 +00:00
abstract setTargetAtTime(
value: UnitMap[TypeName],
startTime: Time,
timeConstant: number
): this;
2019-04-12 14:37:47 +00:00
/**
* Sets an array of arbitrary parameter values starting at the given time
* for the given duration.
*
* @param values
* @param startTime
* @param duration
* @param scaling If the values in the curve should be scaled by some value
2020-04-29 14:06:18 +00:00
* @example
2020-07-26 20:55:06 +00:00
* return Tone.Offline(() => {
* const signal = new Tone.Signal(1).toDestination();
* signal.setValueCurveAtTime([1, 0.2, 0.8, 0.1, 0], 0.2, 0.3);
* }, 0.5, 1);
2019-04-12 14:37:47 +00:00
*/
2024-05-03 15:09:28 +00:00
abstract setValueCurveAtTime(
values: UnitMap[TypeName][],
startTime: Time,
duration: Time,
scaling?: number
): this;
2019-04-12 14:37:47 +00:00
/**
* Cancels all scheduled parameter changes with times greater than or
* equal to startTime.
2020-04-29 14:06:18 +00:00
* @example
2020-07-26 20:55:06 +00:00
* return Tone.Offline(() => {
* const signal = new Tone.Signal(0).toDestination();
* signal.setValueAtTime(0.1, 0.1);
* signal.setValueAtTime(0.2, 0.2);
* signal.setValueAtTime(0.3, 0.3);
* signal.setValueAtTime(0.4, 0.4);
* // cancels the last two scheduled changes
* signal.cancelScheduledValues(0.3);
* }, 0.5, 1);
2019-04-12 14:37:47 +00:00
*/
abstract cancelScheduledValues(time: Time): this;
/**
2024-04-29 14:48:37 +00:00
* This is similar to {@link cancelScheduledValues} except
2019-04-12 14:37:47 +00:00
* it holds the automated value at time until the next automated event.
2020-04-29 14:06:18 +00:00
* @example
2020-07-26 20:55:06 +00:00
* return Tone.Offline(() => {
* const signal = new Tone.Signal(0).toDestination();
* signal.linearRampTo(1, 0.5, 0);
* signal.cancelAndHoldAtTime(0.3);
* }, 0.5, 1);
2019-04-12 14:37:47 +00:00
*/
abstract cancelAndHoldAtTime(time: Time): this;
/**
* Ramps to the given value over the duration of the rampTime.
* Automatically selects the best ramp type (exponential or linear)
* depending on the `units` of the signal
*
* @param value
* @param rampTime The time that it takes the value to ramp from it's current value
* @param startTime When the ramp should start.
* @example
* const osc = new Tone.Oscillator().toDestination().start();
2019-10-23 20:30:07 +00:00
* // schedule it to ramp either linearly or exponentially depending on the units
2019-10-28 15:50:32 +00:00
* osc.frequency.rampTo("A2", 10);
2019-04-12 14:37:47 +00:00
* @example
* const osc = new Tone.Oscillator().toDestination().start();
2019-10-23 20:30:07 +00:00
* // schedule it to ramp starting at a specific time
2019-10-25 20:54:33 +00:00
* osc.frequency.rampTo("A2", 10, "+2");
2019-04-12 14:37:47 +00:00
*/
2024-05-03 15:09:28 +00:00
abstract rampTo(
value: UnitMap[TypeName],
rampTime: Time,
startTime?: Time
): this;
2019-04-12 14:37:47 +00:00
/**
* The current value of the parameter. Setting this value
* is equivalent to setValueAtTime(value, context.currentTime)
*/
abstract value: UnitMap[TypeName];
2019-04-12 14:37:47 +00:00
/**
* If the value should be converted or not
*/
abstract convert: boolean;
/**
* The unit type
*/
2019-07-15 19:37:25 +00:00
abstract readonly units: UnitName;
2019-04-12 14:37:47 +00:00
/**
* True if the signal value is being overridden by
* a connected signal. Internal use only.
*/
abstract overridden: boolean;
2019-04-12 14:37:47 +00:00
/**
* The minimum value of the output given the units
*/
2019-07-15 19:37:25 +00:00
abstract readonly minValue: number;
2019-04-12 14:37:47 +00:00
/**
* The maximum value of the output given the units
*/
2019-07-15 19:37:25 +00:00
abstract readonly maxValue: number;
2019-04-12 14:37:47 +00:00
}