ImageDecoder: decode()-Methode
Eingeschränkt verfügbar
Diese Funktion ist nicht Baseline, da sie in einigen der am weitesten verbreiteten Browser nicht funktioniert.
Sicherer Kontext: Diese Funktion ist nur in sicheren Kontexten (HTTPS) in einigen oder allen unterstützenden Browsern verfügbar.
Hinweis: Diese Funktion ist in Dedicated Web Workers verfügbar.
Die decode()-Methode der ImageDecoder-Schnittstelle stellt eine Steuerungsnachricht für das Dekodieren des Bildrahmens in die Warteschlange.
Syntax
decode()
decode(options)
Parameter
optionsOptional-
Ein Objekt, das die folgenden Mitglieder enthält:
frameIndexOptional-
Ein Integer, der den Index des zu dekodierenden Rahmens darstellt. Standardmäßig
0(der erste Rahmen). completeFramesOnlyOptional-
Ein
Boolean, der standardmäßig auftruegesetzt ist. Wenntrue, wird das von der Methode zurückgegebenePromisenur aufgelöst, wenn das Bild vollständig dekodiert ist. Wennfalse, wird die Methode ein neuesPromisezurückgeben, das möglicherweise mit einem teilweise dekodierten Bild aufgelöst wird. Die Methode kann wiederholt aufgerufen werden, bisresult.completewahr ist. Jeder Schritt liefert ein Bild mit dem nächsten verfügbaren Detailgrad.
Rückgabewert
Ein Promise, das mit einem Objekt aufgelöst wird, das die folgenden Mitglieder enthält:
image-
Ein
VideoFrame, das das dekodierte Bild enthält. complete-
Ein
Boolean, der angibt, obtruedie endgültige Ausgabe in voller Detailtiefe enthält.
Ausnahmen
Wenn ein Fehler auftritt, wird das Promise mit folgender Ausnahme aufgelöst:
InvalidStateErrorDOMException-
Wird zurückgegeben, wenn eine der folgenden Bedingungen zutrifft:
closeist wahr, was bedeutet, dassclose()bereits aufgerufen wurde.- Der angeforderte Rahmen existiert nicht.
Beispiele
>Synchrones Dekodieren eines abgeschlossenen Bildrahmens
Das folgende Beispiel dekodiert den zweiten Rahmen (bei Index 1) und gibt den resultierenden VideoFrame in der Konsole aus.
let result = await imageDecoder.decode({ frameIndex: 1 });
console.log(result.image);
Teilweises Dekodieren eines progressiven Bildrahmens
Das folgende Beispiel dekodiert den ersten Rahmen wiederholt, bis er vollständig ist:
let complete = false;
while (!complete) {
// The promise returned by `decode()` will only resolve when a new
// level of detail is available or the frame is complete. I.e.,
// calling `decode()` in a loop like this won't needlessly spin.
let result = await imageDecoder.decode({ completeFramesOnly: false });
// Do something with `result.image`.
complete = result.complete;
}
Spezifikationen
| Spezifikation |
|---|
| WebCodecs> # dom-imagedecoder-decode> |