Ahoy StackOverflow!
次の問題が発生しました。IE7でのみ、キャンバスに何かを描画した後にdrawImage()を呼び出すと、excanvasは目的のx、y座標で画像を描画しません。excanvasプロジェクトページ/グーグルグループを調べたところ、drawImage()関数に既知の問題があることがわかりました。(例:http ://code.google.com/p/explorercanvas/issues/detail?id = 104&q = IE7 )
ここで提案されているように、単位行列を復元しようとしました:Excanvas vmlのポジショニングの問題ですが、効果がなかったようです。
添付されているのは、この問題を示す簡単なhtmlドキュメントです。
<!DOCTYPE HTML>
<html>
<head>
<script type="text/javascript" src="excanvas.js"></script>
<script type="text/javascript">
window.onload = function(){
var icon, ctx;
icon = new Image();
icon.width = "20";
icon.height = "20";
icon.src = "http://www.shangalulu.com/resources/images/icons/small/30.png";
icon.onload = function(){
var ctx;
ctx = document.getElementById('the_canvas').getContext('2d');
ctx.beginPath();
ctx.moveTo(0,0);
ctx.lineTo(500,0);
ctx.lineTo(500,500);
ctx.lineTo(0,500);
ctx.lineTo(0,0);
ctx.moveTo(200,200);
ctx.lineTo(300,200);
ctx.lineTo(300,300);
ctx.lineTo(200,300);
ctx.lineTo(200,200);
ctx.moveTo(0,0);
ctx.lineTo(500,500);
ctx.moveTo(0,500);
ctx.lineTo(500,0);
ctx.stroke();
ctx.drawImage(icon, 190, 190, 20, 20);
ctx.drawImage(icon, 240, 240, 20, 20);
ctx.drawImage(icon, 290, 290, 20, 20);
return;
}
}
</script>
</head>
<body>
<canvas id="the_canvas" width="500" height="500"></canvas>
</body>
</html>
これを実行するためにexcanvasライブラリが必要な場合は、ここから入手できます:http ://code.google.com/p/explorercanvas/
上記のスクリプトは次のことを行う必要があります。
- キャンバスの外縁の輪郭を描く必要があります(あなたがそれを見ることができるように)
- キャンバスの中央に100x100の長方形を描画する必要があります。
- キャンバスの中心を横切る2本の線を描画する必要があります。
- 内箱の左上隅に1つ、中央に1つ、内箱の右下隅に1つ、合計3つの画像を描画する必要があります。
私が知りたいのは、この問題に対する既知のパッチ/回避策はありますか?