--- 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")}}