tone
Version:
A Web Audio framework for making interactive music in the browser.
104 lines (103 loc) • 3.36 kB
TypeScript
import { NormalRange, Positive, Seconds, Time, TransportTime } from "../core/type/Units";
import { ToneWithContext, ToneWithContextOptions } from "../core/context/ToneWithContext";
import { BasicPlaybackState } from "../core/util/StateTimeline";
export interface LoopOptions extends ToneWithContextOptions {
callback: (time: Seconds) => void;
interval: Time;
playbackRate: Positive;
iterations: number;
probability: NormalRange;
mute: boolean;
humanize: boolean | Time;
}
/**
* Loop creates a looped callback at the
* specified interval. The callback can be
* started, stopped and scheduled along
* the Transport's timeline.
* @example
* import { Loop, Transport } from "tone";
* const loop = new Loop((time) => {
* // triggered every eighth note.
* console.log(time);
* }, "8n").start(0);
* Transport.start();
* @category Event
*/
export declare class Loop<Options extends LoopOptions = LoopOptions> extends ToneWithContext<Options> {
readonly name: string;
/**
* The event which produces the callbacks
*/
private _event;
/**
* The callback to invoke with the next event in the pattern
*/
callback: (time: Seconds) => void;
/**
* @param callback The callback to invoke at the time.
* @param interval The time between successive callback calls.
*/
constructor(callback?: (time: Seconds) => void, interval?: Time);
constructor(options?: Partial<LoopOptions>);
static getDefaults(): LoopOptions;
/**
* Start the loop at the specified time along the Transport's timeline.
* @param time When to start the Loop.
*/
start(time?: TransportTime): this;
/**
* Stop the loop at the given time.
* @param time When to stop the Loop.
*/
stop(time?: TransportTime): this;
/**
* Cancel all scheduled events greater than or equal to the given time
* @param time The time after which events will be cancel.
*/
cancel(time?: TransportTime): this;
/**
* Internal function called when the notes should be called
* @param time The time the event occurs
*/
protected _tick(time: Seconds): void;
/**
* The state of the Loop, either started or stopped.
*/
readonly state: BasicPlaybackState;
/**
* The progress of the loop as a value between 0-1. 0, when the loop is stopped or done iterating.
*/
readonly progress: NormalRange;
/**
* The time between successive callbacks.
* @example
* import { Loop, Transport } from "tone";
* const loop = new Loop();
* loop.interval = "8n"; // loop every 8n
*/
interval: Time;
/**
* The playback rate of the loop. The normal playback rate is 1 (no change).
* A `playbackRate` of 2 would be twice as fast.
*/
playbackRate: Positive;
/**
* Random variation +/-0.01s to the scheduled time.
* Or give it a time value which it will randomize by.
*/
humanize: boolean | Time;
/**
* The probably of the callback being invoked.
*/
probability: NormalRange;
/**
* Muting the Loop means that no callbacks are invoked.
*/
mute: boolean;
/**
* The number of iterations of the loop. The default value is `Infinity` (loop forever).
*/
iterations: number;
dispose(): this;
}