DedicatedWorkerGlobalScope: cancelAnimationFrame()-Methode
Baseline 2023
Newly available
Since March 2023, this feature works across the latest devices and browser versions. This feature might not work in older devices or browsers.
Hinweis: Dieses Feature ist nur verfügbar in Dedicated Web Workers.
Die cancelAnimationFrame()
-Methode der DedicatedWorkerGlobalScope
-Schnittstelle storniert eine Animationsrahmenanforderung, die zuvor durch einen Aufruf von requestAnimationFrame()
geplant wurde.
Der Aufruf der cancelAnimationFrame()
-Methode erfordert, dass der aktuelle Worker ein zugehöriges Eigentümer-window
hat. Das bedeutet, dass der aktuelle Worker von window
oder von einem dedizierten Worker erstellt werden muss, der ebenfalls ein zugehöriges Eigentümer-window
hat.
Syntax
cancelAnimationFrame(handle)
Parameter
handle
-
Der ID-Wert, der durch einen Aufruf von
requestAnimationFrame()
zurückgegeben wird; der Aufruf muss im selben Worker erfolgt sein.
Rückgabewert
Keiner (undefined
).
Ausnahmen
NotSupportedError
DOMException
-
Wird ausgelöst, wenn die Methode vom aktuellen Worker nicht unterstützt wird.
Beispiele
Im Hauptthread beginnen wir mit der Übergabe der Kontrolle eines <canvas>
-Elements an ein OffscreenCanvas
, indem wir HTMLCanvasElement.transferControlToOffscreen()
verwenden und eine Nachricht senden, um die Arbeit mit dem Offscreen-Canvas zu "start"
en:
const offscreenCanvas = document
.querySelector("canvas")
.transferControlToOffscreen();
worker.postMessage(
{
type: "start",
canvas: offscreenCanvas,
},
[offscreenCanvas],
);
Beim Empfang der "start"
-Nachricht beginnt der Worker mit der Animation und bewegt das Rechteck von links nach rechts. Beim Empfang einer "stop"
-Nachricht wird die Animation gestoppt.
let ctx;
let pos = 0;
function draw(dt) {
ctx.clearRect(0, 0, 100, 100);
ctx.fillRect(pos, 0, 10, 10);
pos += 10 * dt;
self.requestAnimationFrame(draw);
}
self.addEventListener("message", (e) => {
if (e.data.type === "start") {
const transferredCanvas = e.data.canvas;
ctx = transferredCanvas.getContext("2d");
self.requestAnimationFrame(draw);
}
if (e.data.type === "stop") {
self.cancelAnimationFrame(handle);
}
});
Schließlich kann der Hauptthread bei Bedarf eine "stop"
-Nachricht an den Worker senden, um die Animation zu stoppen:
worker.postMessage({
type: "stop",
});
Spezifikationen
Specification |
---|
HTML Standard # animationframeprovider-cancelanimationframe |
Browser-Kompatibilität
BCD tables only load in the browser