---
title: BaseAudioContext
slug: Web/API/BaseAudioContext
tags:
- API
- Audio
- BaseAudioContext
- Interface
- Reference
- TopicStub
- Web Audio API
translation_of: Web/API/BaseAudioContext
---
{{APIRef("Web Audio API")}}
L'interface BaseAudioContext
agit comme une définition de base pour les graphiques de traitement audio en ligne et hors ligne, comme représenté par {{domxref("AudioContext")}} et {{domxref("OfflineAudioContext")}} respectivement. Vous n'utiliseriez pas BaseAudioContext
directement — vous utiliseriez ses fonctionnalités via l'une de ces deux interfaces héréditaires.
Un BaseAudioContext
peut être une cible d'événements, il implémente donc l'interface {{domxref("EventTarget")}}.
{{InheritanceDiagram}}
Propriétés
- {{domxref("BaseAudioContext.audioWorklet")}} {{experimental_inline}} {{readonlyInline}}
- Renvoie l'objet {{domxref("AudioWorklet")}}, utilisé pour créer des AudioNodes personnalisés avec traitement JavaScript.
- {{domxref("BaseAudioContext.currentTime")}} {{readonlyInline}}
- Renvoie un double représentant une durée matérielle toujours croissante en secondes utilisée pour la planification. Il commence à
0
.
- {{domxref("BaseAudioContext.destination")}} {{readonlyInline}}
- Renvoie un {{domxref("AudioDestinationNode")}} représentant la destination finale de tout l'audio dans le contexte. Il peut être considéré comme le périphérique de rendu audio.
- {{domxref("BaseAudioContext.listener")}} {{readonlyInline}}
- Renvoie l'objet {{domxref("AudioListener")}}, utilisé pour la spatialisation 3D.
- {{domxref("BaseAudioContext.sampleRate")}} {{readonlyInline}}
- Renvoie un float représentant la fréquence d'échantillonnage (en échantillons par seconde) utilisée par tous les nœuds dans ce contexte. La fréquence d'échantillonnage d'un {{domxref("AudioContext")}} ne peut pas être modifiée.
- {{domxref("BaseAudioContext.state")}} {{readonlyInline}}
- Renvoie l'état actuel de l'
AudioContext
.
Gestionnaires d'événements
- {{domxref("BaseAudioContext.onstatechange")}}
- Un gestionnaire d'événements qui s'exécute lorsqu'un événement de type {{event("statechange")}} s'est déclenché. Cela se produit lorsque l'état de l'
AudioContext
change, en raison de l'appel de l'une des méthodes de changement d'état ({{domxref("AudioContext.suspend")}}, {{domxref("AudioContext.resume")}}, ou {{domxref("AudioContext.close")}}).
Méthodes
Implémente également les méthodes de l'interface {{domxref("EventTarget")}}.
- {{domxref("BaseAudioContext.createBuffer()")}}
- Crée un nouvel objet {{ domxref("AudioBuffer") }} vide, qui peut ensuite être rempli de données et lu via un {{ domxref("AudioBufferSourceNode") }}.
- {{domxref("BaseAudioContext.createConstantSource()")}}
- Crée un objet {{domxref("ConstantSourceNode")}}, qui est une source audio qui émet en continu un signal sonore monophonique (un canal) dont les échantillons ont tous la même valeur.
- {{domxref("BaseAudioContext.createBufferSource()")}}
- Crée un {{domxref("AudioBufferSourceNode")}}, qui peut être utilisé pour lire et manipuler des données audio contenues dans un objet {{ domxref("AudioBuffer") }}. Les {{ domxref("AudioBuffer") }} sont créés à l'aide de {{domxref("AudioContext.createBuffer")}} ou renvoyés par {{domxref("AudioContext.decodeAudioData")}} lorsqu'il décode avec succès une piste audio.
- {{domxref("BaseAudioContext.createScriptProcessor()")}}
- Crée un {{domxref("ScriptProcessorNode")}}, qui peut être utilisé pour le traitement audio direct via JavaScript.
- {{domxref("BaseAudioContext.createStereoPanner()")}}
- Crée un {{domxref("StereoPannerNode")}}, qui peut être utilisé pour appliquer un panoramique stéréo à une source audio.
- {{domxref("BaseAudioContext.createAnalyser()")}}
- Crée un {{domxref("AnalyserNode")}}, qui peut être utilisé pour exposer les données de temps et de fréquence audio et par exemple pour créer des visualisations de données.
- {{domxref("BaseAudioContext.createBiquadFilter()")}}
- Crée un {{domxref("BiquadFilterNode")}}, qui représente un filtre du second ordre configurable en plusieurs types de filtres courants: passe-haut, passe-bas, passe-bande, etc.
- {{domxref("BaseAudioContext.createChannelMerger()")}}
- Crée un {{domxref("ChannelMergerNode")}}, qui est utilisé pour combiner les canaux de plusieurs flux audio en un seul flux audio.
- {{domxref("BaseAudioContext.createChannelSplitter()")}}
- Crée un {{domxref("ChannelSplitterNode")}}, qui est utilisé pour accéder aux canaux individuels d'un flux audio et les traiter séparément.
- {{domxref("BaseAudioContext.createConvolver()")}}
- Crée un {{domxref("ConvolverNode")}}, qui peut être utilisé pour appliquer des effets de convolution à votre graphique audio, par exemple un effet de réverbération.
- {{domxref("BaseAudioContext.createDelay()")}}
- Crée un {{domxref("DelayNode")}}, qui est utilisé pour retarder le signal audio entrant d'une certaine quantité. Ce nœud est également utile pour créer des boucles de rétroaction dans un graphique d'API Web Audio.
- {{domxref("BaseAudioContext.createDynamicsCompressor()")}}
- Crée un {{domxref("DynamicsCompressorNode")}}, qui peut être utilisé pour appliquer une compression acoustique à un signal audio.
- {{domxref("BaseAudioContext.createGain()")}}
- Crée un {{domxref("GainNode")}}, qui peut être utilisé pour contrôler le volume global du graphique audio.
- {{domxref("BaseAudioContext.createIIRFilter()")}}
- Crée un {{domxref("IIRFilterNode")}}, qui représente un filtre du second ordre configurable en plusieurs types de filtres communs différents.
- {{domxref("BaseAudioContext.createOscillator()")}}
- Crée un {{domxref("OscillatorNode")}}, une source représentant une forme d'one périodique. Cela génère essentiellement un ton.
- {{domxref("BaseAudioContext.createPanner()")}}
- Crée un {{domxref("PannerNode")}}, qui est utilisé pour spatialiser un flux audio entrant dans l'espace 3D.
- {{domxref("BaseAudioContext.createPeriodicWave()")}}
- Crée un {{domxref("PeriodicWave")}}, utilisé pour définir une forme d'one périodique qui peut être utilisée pour déterminer la sortie d'un {{ domxref("OscillatorNode") }}.
- {{domxref("BaseAudioContext.createWaveShaper()")}}
- Crée un {{domxref("WaveShaperNode")}}, qui est utilisé pour implémenter des effets de distorsion non linéaires.
- {{domxref("BaseAudioContext.decodeAudioData()")}}
- Décode de manière asynchrone les données de fichiers audio contenues dans un {{domxref("ArrayBuffer")}}. Dans ce cas, le ArrayBuffer est généralement chargé à partir de l'attribut
response
d'un {{domxref("XMLHttpRequest")}} après avoir défini le responseType
sur arraybuffer
. Cette méthode ne foncionne que sur des fichiers complets et non sur des fragments de fichiers audio.
- {{domxref("BaseAudioContext.resume()")}}
- Reprend la progression du temps dans un contexte audio précédemment suspendu / mis en pause.
Exemples
Déclaration de context audio de base:
var audioCtx = new AudioContext();
Variante de nagivateur croisé:
var AudioContext = window.AudioContext || window.webkitAudioContext;
var audioCtx = new AudioContext();
var oscillatorNode = audioCtx.createOscillator();
var gainNode = audioCtx.createGain();
var finish = audioCtx.destination;
// etc.
Spécifications
Spécification |
Statut |
Commentaire |
{{SpecName('Web Audio API', '#BaseAudioContext', 'BaseAudioContext')}} |
{{Spec2('Web Audio API')}} |
|
Compatibilité des navigateurs
{{CompatibilityTable}}
Fonctionnalité |
Chrome |
Edge |
Firefox (Gecko) |
Internet Explorer |
Opera |
Safari (WebKit) |
Support de base |
{{CompatVersionUnknown}} |
{{CompatVersionUnknown}} |
{{CompatVersionUnknown}} |
{{CompatNo}} |
15.0{{property_prefix("webkit")}}
22 |
6.0{{property_prefix("webkit")}} |
baseLatency |
{{CompatChrome(60)}} |
{{CompatUnknown}} |
{{CompatUnknown}} |
{{CompatUnknown}} |
{{CompatUnknown}} |
{{CompatUnknown}} |
createConstantSource() |
{{CompatChrome(56)}} |
{{CompatNo}} |
{{CompatGeckoDesktop(52)}} |
{{CompatNo}} |
{{CompatOpera(43)}} |
{{CompatNo}} |
createStereoPanner() |
{{CompatChrome(42)}} |
{{CompatVersionUnknown}} |
{{CompatGeckoDesktop(37.0)}} |
{{CompatNo}} |
{{CompatNo}} |
{{CompatNo}} |
onstatechange , state , suspend() , resume() |
{{CompatVersionUnknown}} |
{{CompatVersionUnknown}} |
{{CompatGeckoDesktop(40.0)}} |
{{CompatNo}} |
{{CompatNo}} |
{{CompatSafari(8.0)}} |
Sans préfixe |
{{CompatVersionUnknown}} |
{{CompatVersionUnknown}} |
|
|
|
|
Fonctionnalité |
Android Webview |
Chrome pour Android |
Edge |
Firefox Mobile (Gecko) |
Firefox OS |
IE Mobile |
Opera Mobile |
Safari Mobile |
Support de base |
{{CompatVersionUnknown}} |
{{CompatVersionUnknown}} |
{{CompatVersionUnknown}} |
{{CompatVersionUnknown}} |
2.2 |
{{CompatNo}} |
{{CompatVersionUnknown}} |
{{CompatNo}} |
baseLatency |
{{CompatChrome(60)}} |
{{CompatChrome(60)}} |
{{CompatUnknown}} |
{{CompatUnknown}} |
{{CompatUnknown}} |
{{CompatUnknown}} |
{{CompatUnknown}} |
{{CompatUnknown}} |
createConstantSource() |
{{CompatChrome(56)}} |
{{CompatChrome(56)}} |
{{CompatNo}} |
{{CompatGeckoMobile(52)}} |
{{CompatNo}} |
{{CompatNo}} |
{{CompatNo}} |
{{CompatNo}} |
createStereoPanner() |
{{CompatChrome(42)}} |
{{CompatChrome(42)}} |
{{CompatVersionUnknown}} |
{{CompatVersionUnknown}} |
{{CompatVersionUnknown}} |
{{CompatNo}} |
{{CompatNo}} |
{{CompatNo}} |
onstatechange , state , suspend() , resume() |
{{CompatVersionUnknown}} |
{{CompatVersionUnknown}} |
{{CompatVersionUnknown}} |
{{CompatVersionUnknown}} |
{{CompatVersionUnknown}} |
{{CompatNo}} |
{{CompatNo}} |
{{CompatNo}} |
Sans préfixe |
{{CompatVersionUnknown}} |
{{CompatVersionUnknown}} |
{{CompatVersionUnknown}} |
{{CompatUnknown}} |
{{CompatUnknown}} |
{{CompatUnknown}} |
{{CompatOperaMobile(43)}} |
{{CompatUnknown}} |
Voir aussi