在尝试globalCompositeOperation在Chrome中更正地掩盖/混合形状和文本(形状掩码/与其他形状混合工作得很好)时遇到问题我使用Chrome 12.0.7)。任何人都可以提出我可能在这里误入歧途的地方,或者在画布元素中提出解决方法吗?在Chrome中使用带有形状和文本元素的HTML5 globalCompositeOperation“xor”
这里是一个图像显示我所看到的:http://i.stack.imgur.com/wRunv.jpg
这里是一个将重现这些结果的代码:
<!DOCTYPE HTML>
<html>
<body>
<canvas id="testCanvas" width="500" height="500"></canvas>
<script type="text/javascript">
// setup canvas
var tcanvas = document.getElementById("testCanvas");
var tcontext = tcanvas.getContext("2d");
// draw square
tcontext.fillStyle = "#FF3366";
tcontext.fillRect(15,15,70,70);
// set composite property
tcontext.globalCompositeOperation = "xor";
// draw text
tcontext.fillStyle="#0099FF";
tcontext.font = "35px sans-serif";
tcontext.fillText("test", 22, 25);
</script>
</body>
</html>
你遇到了什么样的问题?为什么你看到的不是你想要的? –
globalCompositeOperation的使用似乎按照Firefox和IE中的预期工作,但是在试图混合文本和形状的Chrome中似乎工作方式不同。对于特定的xor例子,与正方形重叠的文本部分应该是白色的。这可以在我原始问题中链接的图像中看到。 – Ninx