UNPKG

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
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