Googleでは、globalCompositeOperationを使用してシェイプとテキストをシェイプ/ブレンドする際に問題が発生しました。私はChrome 12.0.7を使用しています)。誰かが私がここで迷子になっているかもしれないと示唆したり、キャンバス要素内で回避策を提案することはできますか?ここでhttp://i.stack.imgur.com/wRunv.jpgChromeのシェイプとテキスト要素でHTML5のglobalCompositeOperation "xor"を使用する
これらの結果を再現するコードされています:XOR globalCompositeOperationの問題は、クロームのバグであるよう
<!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