react-native-audio-api
Version:
react-native-audio-api provides system for controlling audio in React Native environment compatible with Web Audio API specification
139 lines • 5.79 kB
TypeScript
import { WindowType, ContextState, OscillatorType, BiquadFilterType, ChannelCountMode, ChannelInterpretation } from './types';
import { AudioEventName, AudioEventCallback } from './events/types';
export interface IBaseAudioContext {
readonly destination: IAudioDestinationNode;
readonly state: ContextState;
readonly sampleRate: number;
readonly currentTime: number;
createRecorderAdapter(): IRecorderAdapterNode;
createOscillator(): IOscillatorNode;
createGain(): IGainNode;
createStereoPanner(): IStereoPannerNode;
createBiquadFilter: () => IBiquadFilterNode;
createBufferSource: (pitchCorrection: boolean) => IAudioBufferSourceNode;
createBufferQueueSource: () => IAudioBufferQueueSourceNode;
createBuffer: (channels: number, length: number, sampleRate: number) => IAudioBuffer;
createPeriodicWave: (real: Float32Array, imag: Float32Array, disableNormalization: boolean) => IPeriodicWave;
createAnalyser: () => IAnalyserNode;
decodeAudioDataSource: (sourcePath: string) => Promise<IAudioBuffer>;
decodeAudioData: (arrayBuffer: ArrayBuffer) => Promise<IAudioBuffer>;
decodePCMAudioDataInBase64: (b64: string, playbackRate: number) => Promise<IAudioBuffer>;
}
export interface IAudioContext extends IBaseAudioContext {
close(): Promise<boolean>;
resume(): Promise<boolean>;
suspend(): Promise<boolean>;
}
export interface IOfflineAudioContext extends IBaseAudioContext {
resume(): Promise<void>;
suspend(suspendTime: number): Promise<void>;
startRendering(): Promise<IAudioBuffer>;
}
export interface IAudioNode {
readonly context: BaseAudioContext;
readonly numberOfInputs: number;
readonly numberOfOutputs: number;
readonly channelCount: number;
readonly channelCountMode: ChannelCountMode;
readonly channelInterpretation: ChannelInterpretation;
connect: (destination: IAudioNode | IAudioParam) => void;
disconnect: (destination?: IAudioNode | IAudioParam) => void;
}
export interface IGainNode extends IAudioNode {
readonly gain: IAudioParam;
}
export interface IStereoPannerNode extends IAudioNode {
readonly pan: IAudioParam;
}
export interface IBiquadFilterNode extends IAudioNode {
readonly frequency: AudioParam;
readonly detune: AudioParam;
readonly Q: AudioParam;
readonly gain: AudioParam;
type: BiquadFilterType;
getFrequencyResponse(frequencyArray: Float32Array, magResponseOutput: Float32Array, phaseResponseOutput: Float32Array): void;
}
export interface IAudioDestinationNode extends IAudioNode {
}
export interface IAudioScheduledSourceNode extends IAudioNode {
start(when: number): void;
stop: (when: number) => void;
onEnded: string;
}
export interface IAudioBufferBaseSourceNode extends IAudioScheduledSourceNode {
detune: IAudioParam;
playbackRate: IAudioParam;
onPositionChanged: string;
onPositionChangedInterval: number;
}
export interface IOscillatorNode extends IAudioScheduledSourceNode {
readonly frequency: IAudioParam;
readonly detune: IAudioParam;
type: OscillatorType;
setPeriodicWave(periodicWave: IPeriodicWave): void;
}
export interface IAudioBufferSourceNode extends IAudioBufferBaseSourceNode {
buffer: IAudioBuffer | null;
loop: boolean;
loopSkip: boolean;
loopStart: number;
loopEnd: number;
start: (when?: number, offset?: number, duration?: number) => void;
setBuffer: (audioBuffer: IAudioBuffer | null) => void;
}
export interface IAudioBufferQueueSourceNode extends IAudioBufferBaseSourceNode {
dequeueBuffer: (bufferId: number) => void;
clearBuffers: () => void;
enqueueBuffer: (audioBuffer: IAudioBuffer) => string;
pause: () => void;
}
export interface IAudioBuffer {
readonly length: number;
readonly duration: number;
readonly sampleRate: number;
readonly numberOfChannels: number;
getChannelData(channel: number): Float32Array;
copyFromChannel(destination: Float32Array, channelNumber: number, startInChannel: number): void;
copyToChannel(source: Float32Array, channelNumber: number, startInChannel: number): void;
}
export interface IAudioParam {
value: number;
defaultValue: number;
minValue: number;
maxValue: number;
setValueAtTime: (value: number, startTime: number) => void;
linearRampToValueAtTime: (value: number, endTime: number) => void;
exponentialRampToValueAtTime: (value: number, endTime: number) => void;
setTargetAtTime: (target: number, startTime: number, timeConstant: number) => void;
setValueCurveAtTime: (values: Float32Array, startTime: number, duration: number) => void;
cancelScheduledValues: (cancelTime: number) => void;
cancelAndHoldAtTime: (cancelTime: number) => void;
}
export interface IPeriodicWave {
}
export interface IAnalyserNode extends IAudioNode {
fftSize: number;
readonly frequencyBinCount: number;
minDecibels: number;
maxDecibels: number;
smoothingTimeConstant: number;
window: WindowType;
getFloatFrequencyData: (array: Float32Array) => void;
getByteFrequencyData: (array: Uint8Array) => void;
getFloatTimeDomainData: (array: Float32Array) => void;
getByteTimeDomainData: (array: Uint8Array) => void;
}
export interface IRecorderAdapterNode extends IAudioNode {
}
export interface IAudioRecorder {
start: () => void;
stop: () => void;
connect: (node: IRecorderAdapterNode) => void;
disconnect: () => void;
onAudioReady: string;
}
export interface IAudioEventEmitter {
addAudioEventListener<Name extends AudioEventName>(name: Name, callback: AudioEventCallback<Name>): string;
removeAudioEventListener<Name extends AudioEventName>(name: Name, subscriptionId: string): void;
}
//# sourceMappingURL=interfaces.d.ts.map