2

キャンバスの背景として画像をレンダリングする次のコードがあります。

window.onload = function(){
    var canvas = document.getElementById("myCanvas");
    var context = canvas.getContext("2d");
    var destX = 69;
    var destY = 50;
    var imageObj = new Image();

    imageObj.onload = function(){
        context.drawImage(imageObj, destX, destY);
    };
    imageObj.src = "myImage.jpg";
};

外部ファイルの代わりに、インライン画像を背景として使用したい場合はどうなりますか?例えば、

<img src="..." />

どうすればキャンバスの背景にすることができますか?

編集:これについて言及しているチュートリアル(https://developer.mozilla.org/en/Canvas_tutorial/Using_images)を見つけましたが、その使用方法については言及されていません。

4

2 に答える 2

1

イメージを「canvas」に書き込みたい場合は、drawImage API を使用する必要があります (既に行っています)。

ただし、画像をタグに配置する場合は、「画像ファイル」を「base64」URI に変換する必要があります。通常はサーバーサイドプログラミング(PHP、Python)で行います こちら をご確認ください

于 2012-03-15T09:19:25.167 に答える
0

<!DOCTYPE html>
<html>
<body onload="do_onload()">

<h1>Hello World!</h1>
<p>
<canvas width="640" height="400" id="myCanvas">
Canvas not supported!
</canvas>
</p>
<script>
function do_onload(){
    var canvas = document.getElementById("myCanvas");
    var context = canvas.getContext("2d");
    var destX = 69;
    var destY = 50;
    var imageObj = new Image();
    imageObj.src = "";
    imageObj.onload = function(){
        context.drawImage(imageObj, destX, destY);
    };
};

</script>
</body>
</html>

これは完全に機能する例です。

于 2015-07-22T12:37:31.327 に答える