--- title: BaseAudioContext.createBuffer() slug: Web/API/BaseAudioContext/createBuffer tags: - API - AudioContext - BaseAudioContext - Method - Reference - Web Audio API - createBuffer translation_of: Web/API/BaseAudioContext/createBuffer ---
{{APIRef("API Web Audio")}}
La méthode createBuffer()
de l'interface {{domxref("BaseAudioContext")}} est utilisée pour créer un nouvel objet {{domxref("AudioBuffer")}} vide, qui peut ensuite être rempli.
Pour plus de détails sur les tampons audio, consultez la page de référence {{domxref ("AudioBuffer")}}.
Note : createBuffer()
permettait de prendre des données compressées et de restituer des échantillons décodés, mais cette possibilité a été supprimée de la spécification, du fait que tout le décodage était effectué dans le thread principal, donc createBuffer()
bloquait l'exécution du reste du code. La méthode asynchrone decodeAudioData()
fait la même chose - prend l'audio compressé, par exemple, un fichier MP3, et vous renvoie directement un {{domxref("AudioBuffer")}} que vous pouvez ensuite faire jouer via {{domxref("AudioBufferSourceNode")}}. Pour des utilisations simples comme la lecture d'un fichier MP3, decodeAudioData()
est ce que vous devriez utiliser.
var tampon = baseAudioContext.createBuffer(nbDeCanaux, longueur, frequenceDEchantillonnage);
Note : pour une explication en profondeur de la façon dont les tampons audio fonctionnent, ainsi que de leur signification, lire Les concepts de base de la Web Audio API de notre guide des concepts de base.
Un {{domxref("AudioBuffer")}}.
Tout d'abord, deux exemples triviaux simples pour aider à expliquer comment les paramètres sont utilisés :
var ctxAudio = new AudioContext(); var tampon = ctxAudio.createBuffer(2, 22050, 44100);
Si vous utilisez cet appel, vous obtiendrez un tampon stéréo (deux canaux), qui, lorsque relu avec un AudioContext
fonctionnant à 44100Hz (très courant, la plupart des cartes son normales fonctionnent à cette fréquence), durera 0,5 seconde : 22050 trames / 44100 Hz = 0,5 seconde.
var ctxAudio = new AudioContext(); var tampon = ctxAudio.createBuffer(1, 22050, 22050);
Si vous utilisez cet appel, vous obtiendrez un tampon mono (un canal), qui, lorsqu'il sera relu avec un AudioContext
fonctionnant à 44100Hz, sera automatiquement *rééchantillonné* à 44100Hz (et produira donc 44100 trames), et durera 1,0 seconde : 44100 images / 44100Hz = 1 seconde.
Note : le rééchantillonnage audio est très similaire au redimensionnement d'une image : supposons que vous ayez une image 16 x 16, mais que vous vouliez qu'elle remplisse une zone 32x32: vous la redimensionnez (rééchantillonnez). Le résultat aura une qualité moindre (il pourra être flou ou bizarre, selon l'algorithme de redimensionnement), mais cela fonctionnera, et l'image redimensionnée prendra moins de place. L'audio rééchantillonné est exactement la même chose - vous économisez de l'espace, mais en pratique, vous ne pourrez pas reproduire correctement le contenu haute fréquence (les sons aigus).
Examinons maintenant un exemple de createBuffer()
plus complexe, dans lequel nous créons un tampon de deux secondes, le remplissons de bruit blanc, puis le reproduisons via {{domxref("AudioBufferSourceNode")}}. Le commentaire devrait clairement faire comprendre ce qui se passe. Vous pouvez également exécuter le code en direct ou regarder le source.
var ctxAudio = new (window.AudioContext || window.webkitAudioContext)(); // Création d'un tampon stéréo vide de trois secondes à la fréquence d'échantillonnage de l'AudioContext var monArrayBuffer = ctxAudio.createBuffer(2, ctxAudio.sampleRate * 3, ctxAudio.sampleRate); // Remplissage du tampon avec du bruit blanc ; // simplement des valeurs aléatoires entre -1,0 et 1,0 for (var canal = 0; canal < monArrayBuffer.numberOfChannels; canal++) { // Cela nous donne le ArrayBuffer qui contient effectivement les données var donneesCourantes = monArrayBuffer.getChannelData(canal); for (var i = 0; i < monArrayBuffer.length; i++) { // Math.random() est dans [0; 1,0] // l'audio doit se trouver dans [-1,0; 1,0] donneesCourantes[i] = Math.random() * 2 - 1; } } // Récupération d'un AudioBufferSourceNode. // C'est l'AudioNode à utiliser quand nous voulons lire un AudioBuffer var source = ctxAudio.createBufferSource(); // Définir le tampon dans l'AudioBufferSourceNode source.buffer = monArrayBuffer; // Connecter l'AudioBufferSourceNode à la destination, // de sorte que nous puissions entendre le son source.connect(ctxAudio.destination); // Démarrer la lecture de la source source.start();
Spécification | Statut | Commentaire |
---|---|---|
{{SpecName('Web Audio API', '#dom-baseaudiocontext-createbuffer', 'createBuffer()')}} | {{Spec2('Web Audio API')}} |
{{Compat("api.BaseAudioContext.createBuffer")}}