2019-10-28 15:37:53 +00:00
|
|
|
import { Time, Unit, UnitMap, UnitName } from "../type/Units";
|
2019-04-12 14:37:47 +00:00
|
|
|
|
2019-08-26 17:44:43 +00:00
|
|
|
/**
|
|
|
|
* Abstract base class for [[Param]] and [[Signal]]
|
|
|
|
*/
|
2019-10-28 15:37:53 +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.
|
|
|
|
* Does this work? is this working. are you working?
|
|
|
|
* @param value The value to set the signal.
|
|
|
|
* @param time The time when the change should occur.
|
|
|
|
* @example
|
2019-10-23 20:30:07 +00:00
|
|
|
* import { Oscillator } from "tone";
|
|
|
|
* const osc = new Oscillator().toDestination().start();
|
|
|
|
* // set the frequency to "G4" in exactly 1 second from now.
|
|
|
|
* osc.frequency.setValueAtTime("G4", "+1");
|
2019-04-12 14:37:47 +00:00
|
|
|
*/
|
2019-10-28 15:37:53 +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.
|
2019-08-30 16:06:38 +00:00
|
|
|
* @param time When to get the value
|
2019-04-12 14:37:47 +00:00
|
|
|
*/
|
2019-10-28 15:37:53 +00:00
|
|
|
abstract getValueAtTime(time: Time): UnitMap[TypeName];
|
2019-04-12 14:37:47 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a schedule point with the current value at the current time.
|
|
|
|
* This is useful for creating an automation anchor point in order to
|
|
|
|
* schedule changes from the current value.
|
|
|
|
* @param time When to add a ramp point.
|
|
|
|
* @example
|
2019-10-23 20:30:07 +00:00
|
|
|
* import { Oscillator } from "tone";
|
|
|
|
* const osc = new Oscillator().toDestination().start();
|
|
|
|
* // set the frequency to "G4" in exactly 1 second from now.
|
|
|
|
* osc.frequency.setValueAtTime("G4", "+1");
|
|
|
|
* setInterval(() => {
|
|
|
|
* // check the value every 100 ms
|
|
|
|
* osc.frequency.getValueAtTime(Tone.now());
|
|
|
|
* }, 100);
|
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.
|
|
|
|
*/
|
2019-10-28 15:37:53 +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.
|
2019-04-12 14:37:47 +00:00
|
|
|
*/
|
2019-10-28 15:37:53 +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
|
2019-10-23 20:30:07 +00:00
|
|
|
* import { FeedbackDelay, Noise } from "tone";
|
|
|
|
* const delay = new FeedbackDelay(0.5, 0.98).toDestination();
|
|
|
|
* // a short burst of noise through the feedback delay
|
|
|
|
* const noise = new Noise().connect(delay).start().stop("+0.1");
|
|
|
|
* // exponentially ramp to the value to 2 over 4 seconds.
|
|
|
|
* delay.delayTime.exponentialRampTo(2, 4);
|
2019-04-12 14:37:47 +00:00
|
|
|
*/
|
2019-10-28 15:37:53 +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
|
|
|
*
|
2019-08-30 16:06:38 +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
|
2019-08-30 16:06:38 +00:00
|
|
|
* @param startTime When the ramp should start.
|
|
|
|
* @returns {Param} this
|
|
|
|
* @example
|
2019-10-23 20:30:07 +00:00
|
|
|
* import { FeedbackDelay, Noise } from "tone";
|
|
|
|
* const delay = new FeedbackDelay(0.5, 0.98).toDestination();
|
|
|
|
* // a short burst of noise through the feedback delay
|
|
|
|
* const noise = new Noise().connect(delay).start().stop("+0.1");
|
|
|
|
* // linearly ramp to the value 4 over 3 seconds.
|
|
|
|
* delay.delayTime.linearRampTo(4, 3);
|
2019-04-12 14:37:47 +00:00
|
|
|
*/
|
2019-10-28 15:37:53 +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.
|
2019-08-30 16:06:38 +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
|
2019-08-30 16:06:38 +00:00
|
|
|
* @param startTime When the ramp should start.
|
|
|
|
* @example
|
2019-10-23 20:30:07 +00:00
|
|
|
* import { Oscillator } from "tone";
|
|
|
|
* const osc = new Oscillator().toDestination().start();
|
|
|
|
* osc.frequency.targetRampTo("C4", 4);
|
2019-04-12 14:37:47 +00:00
|
|
|
*/
|
2019-10-28 15:37:53 +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
|
2019-10-23 20:30:07 +00:00
|
|
|
* import { Oscillator } from "tone";
|
|
|
|
* const osc = new Oscillator().toDestination().start();
|
|
|
|
* // exponential approach over 4 seconds starting in 1 second
|
|
|
|
* osc.frequency.exponentialApproachValueAtTime("C4", "+1", 4);
|
2019-04-12 14:37:47 +00:00
|
|
|
*/
|
2019-10-28 15:37:53 +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
|
|
|
|
*/
|
2019-10-28 15:37:53 +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
|
|
|
|
*/
|
2019-10-28 15:37:53 +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.
|
|
|
|
*/
|
|
|
|
abstract cancelScheduledValues(time: Time): this;
|
|
|
|
|
|
|
|
/**
|
2019-09-14 23:55:50 +00:00
|
|
|
* This is similar to [[cancelScheduledValues]] except
|
2019-04-12 14:37:47 +00:00
|
|
|
* it holds the automated value at time until the next automated event.
|
|
|
|
*/
|
|
|
|
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
|
2019-10-23 20:30:07 +00:00
|
|
|
* import { Oscillator } from "tone";
|
|
|
|
* const osc = new Oscillator().toDestination().start();
|
|
|
|
* // 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
|
2019-10-23 20:30:07 +00:00
|
|
|
* import { Oscillator } from "tone";
|
|
|
|
* const osc = new Oscillator().toDestination().start();
|
|
|
|
* // 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
|
|
|
*/
|
2019-10-28 15:37:53 +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)
|
|
|
|
*/
|
2019-10-28 15:37:53 +00:00
|
|
|
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.
|
|
|
|
*/
|
2019-08-12 18:18:34 +00:00
|
|
|
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
|
|
|
}
|