mirror of
https://github.com/Tonejs/Tone.js
synced 2024-12-31 22:18:44 +00:00
7a099b2310
either because it's loaded in node.js or because of the context that the script is loaded in
49 lines
1.2 KiB
TypeScript
49 lines
1.2 KiB
TypeScript
/**
|
|
* Interface for things that Tone.js adds to the window
|
|
*/
|
|
interface ToneWindow extends Window {
|
|
TONE_AUDIO_CONTEXT?: BaseAudioContext;
|
|
TONE_SILENCE_LOGGING?: boolean;
|
|
}
|
|
|
|
/**
|
|
* A reference to the window object
|
|
*/
|
|
export const theWindow: ToneWindow | null = typeof self === "object" ? self : null;
|
|
|
|
/**
|
|
* If the browser has a window object which has an AudioContext
|
|
*/
|
|
export const hasAudioContext = theWindow && theWindow.hasOwnProperty("AudioContext");
|
|
|
|
/**
|
|
* The global audio context which is getable and assignable through
|
|
* getAudioContext and setAudioContext
|
|
*/
|
|
let globalContext: BaseAudioContext;
|
|
|
|
// if it was created already, use that one
|
|
// this enables multiple versions of Tone.js to run on the same page.
|
|
if (theWindow && theWindow.TONE_AUDIO_CONTEXT) {
|
|
globalContext = theWindow.TONE_AUDIO_CONTEXT;
|
|
}
|
|
|
|
/**
|
|
* Returns the default system-wide AudioContext
|
|
*/
|
|
export function getAudioContext(): BaseAudioContext {
|
|
if (!globalContext && hasAudioContext) {
|
|
setAudioContext(new AudioContext());
|
|
}
|
|
return globalContext;
|
|
}
|
|
|
|
/**
|
|
* Set the default audio context
|
|
*/
|
|
export function setAudioContext(context: BaseAudioContext): void {
|
|
globalContext = context;
|
|
if (theWindow) {
|
|
theWindow.TONE_AUDIO_CONTEXT = globalContext;
|
|
}
|
|
}
|