PaintWorkletGlobalScope: registerPaint() メソッド
Limited availability
This feature is not Baseline because it does not work in some of the most widely-used browsers.
Experimental: これは実験的な機能です。
本番で使用する前にブラウザー互換性一覧表をチェックしてください。
registerPaint()
は PaintWorkletGlobalScope
インターフェイスのメソッドで、CSS プロパティがファイルを指定している場合に、プログラムで画像を生成するクラスを登録します。
構文
registerPaint(name, classRef)
引数
返値
なし (undefined
)。
例外
TypeError
-
引数のいずれかが不正な場合、または見つからない場合に発生します。
InvalidModificationError
DOMException
-
指定した名前のワークレットが既に存在する場合に発生します。
例
以下は、ワークレットモジュールの例を登録することを示しています。これは別個の js ファイルにする必要があります。registerPaint()
は PaintWorkletGlobalScope
を参照せずに呼び出されていることに注意してください。ファイル自体は CSS.paintWorklet.addModule()
(PaintWorkletの親クラスWorklet.addModule()
で文書化)を通して読み込まれます。
/* checkboardWorklet.js */
class CheckerboardPainter {
paint(ctx, geom, properties) {
// 通常のキャンバスのように `ctx` を使用します。
const colors = ["red", "green", "blue"];
const size = 32;
for (let y = 0; y < geom.height / size; y++) {
for (let x = 0; x < geom.width / size; x++) {
const color = colors[(x + y) % colors.length];
ctx.beginPath();
ctx.fillStyle = color;
ctx.rect(x * size, y * size, size, size);
ctx.fill();
}
}
}
}
// 固有の名前でクラスを登録します。
registerPaint("checkerboard", CheckerboardPainter);
描画ワークレットを使用する最初の段階は、上記のように registerPaint()
関数を使用して描画ワークレットを定義することです。これを使用するには、CSS.paintWorklet.addModule()
メソッドで登録します。
<script>
CSS.paintWorklet.addModule("checkboardWorklet.js");
</script>
そうすると、
という CSS 関数を、paint()
の値が有益な場所であればどこでも CSS の中で使用することができます。<image>
li {
background-image: paint(checkerboard);
}
仕様書
Specification |
---|
CSS Painting API Level 1 # dom-paintworkletglobalscope-registerpaint |