Source code

Revision control

Copy as Markdown

Other Tools

Test Info:

<!DOCTYPE html>
<html class="reftest-wait">
<link rel="match" href="paint2d-composite-ref.html">
<style>
div {
display: inline-block;
width: 80px;
height: 80px;
}
#source-over { background-image: paint(source-over); }
#source-in { background-image: paint(source-in); }
#source-out { background-image: paint(source-out); }
#source-atop { background-image: paint(source-atop); }
#destination-over { background-image: paint(destination-over); }
#destination-in { background-image: paint(destination-in); }
#destination-out { background-image: paint(destination-out); }
#destination-atop { background-image: paint(destination-atop); }
#lighter { background-image: paint(lighter); }
#xor { background-image: paint(xor); }
</style>
<script src="/common/reftest-wait.js"></script>
<script src="/common/worklet-reftest.js"></script>
<body>
<div id="source-over"></div>
<div id="source-in"></div>
<div id="source-out"></div>
<div id="source-atop"></div>
<br>
<div id="destination-over"></div>
<div id="destination-in"></div>
<div id="destination-out"></div>
<div id="destination-atop"></div>
<br>
<div id="lighter"></div>
<div id="xor"></div>
<script id="code" type="text/worklet">
var compositeOps = [
'source-over',
'source-in',
'source-out',
'source-atop',
'destination-over',
'destination-in',
'destination-out',
'destination-atop',
'lighter',
'xor'
];
function doPaint(ctx, op) {
ctx.fillStyle = 'red';
ctx.fillRect(5, 5, 40, 40);
ctx.globalCompositeOperation = op;
ctx.fillStyle = 'deepskyblue';
ctx.beginPath();
ctx.arc(45,45,20,0,Math.PI*2,true);
ctx.fill();
}
for (var i = 0; i < compositeOps.length; i++) {
let op = compositeOps[i];
registerPaint(op, class { paint(ctx, geom) { doPaint(ctx, op); } });
}
</script>
<script>
importWorkletAndTerminateTestAfterAsyncPaint(CSS.paintWorklet, document.getElementById('code').textContent);
</script>
</body>
</html>