--- title: AnalyserNode slug: Web/API/AnalyserNode tags: - API - AnalyserNode - Reference translation_of: Web/API/AnalyserNode ---
L' interface AnalyserNode
représente un noeud capable de fournir en temps réel des informations d'analyse de la fréquence et du domaine temporel. C'est un {{domxref("AudioNode")}} qui transmet le flux audio inchangé depuis l'entrée vers la sortie, mais permet de capturer les données générées pour les traiter et/ou les visualiser.
Il a exactement une entrée et une sortie. Le noeud fonctionne même si la sortie n'est pas connectée.
Nombre d'entrées | 1 |
---|---|
Nombre de sorties | 1 (mais peut ne pas être connectée) |
Mode de comptage des canaux | "explicit" |
Nombre de canaux | 1 |
Interprétation du canal | "speakers" |
L'interface hérite des parents suivants:
{{InheritanceDiagram}}
AnalyserNode
.Hérite des propriétés de son parent. {{domxref("AudioNode")}}.
getByteFrequencyData()
.getByteFrequencyData()
.Hérite des propriétés de son parent, {{domxref("AudioNode")}}.
Note: Voir Visualisations avec la Web Audio API pour plus d'informations.
L'exemple suivant montre comment créer simplement un AnalyserNode
avec {{domxref("AudioContext")}}, puis utiliser {{domxref("window.requestAnimationFrame()","requestAnimationFrame")}} et {{htmlelement("canvas")}} pour collecter les données temporelles et dessiner un oscilloscope en sortie. Pour des exemples plus complets, voir notre démo Voice-change-O-matic (et en particulier app.js lines 128–205).
var contexteAudio = new (window.AudioContext || window.webkitAudioContext)(); var analyseur = contexteAudio.createAnalyser(); ... analyseur.fftSize = 2048; var tailleMemoireTampon = analyseur.frequencyBinCount; var tableauDonnees = new Uint8Array(tailleMemoireTampon); analyseur.getByteTimeDomainData(tableauDonnees); // dessine un oscilloscope de la source audio
var canvas = document.getElementById("oscilloscope"); var contexteCanvas = canvas.getContext("2d"); function dessiner() { requestAnimationFrame(dessiner); analyseur.getByteTimeDomainData(tableauDonnees); contexteCanvas.fillStyle = 'rgb(200, 200, 200)'; contexteCanvas.fillRect(0, 0, WIDTH, HEIGHT); contexteCanvas.lineWidth = 2; contexteCanvas.strokeStyle = 'rgb(0, 0, 0)'; contexteCanvas.beginPath(); var sliceWidth = WIDTH * 1.0 / tailleMemoireTampon; var x = 0; for(var i = 0; i < tailleMemoireTampon; i++) { var v = tableauDonnees[i] / 128.0; var y = v * HEIGHT/2; if(i === 0) { contexteCanvas.moveTo(x, y); } else { contexteCanvas.lineTo(x, y); } x += sliceWidth; } contexteCanvas.lineTo(canvas.width, canvas.height/2); contexteCanvas.stroke(); }; dessiner();
Spécification | État | Commentaires |
---|---|---|
{{SpecName('Web Audio API', '#the-analysernode-interface', 'AnalyserNode')}} | {{Spec2('Web Audio API')}} |
{{Compat("api.AnalyserNode")}}