Html5 用canvas绘制图片,绘制不出来。

为什么我的canvas容器里,画不出图片来呢?xx.png和这个html文件放在同一目录下了。就是空白,画不出来。
<!DOCTYPE HTML>

<!--This text is a comment-->
<html>
<body>

<canvas id="myCanvas">  Your browser is not support Canvas </canvas>

<script type="text/javascript">
var canvas = document.getElementById('myCanvas');
var ctx = canvas.getContext("2d");
var img = new Image();
img.src="xx.png";
ctx.drawImage(img,0,0);
</script>

</body>
</html>
我的是360极速浏览器,是支持html5的。因为我用ctx绘制图形是可以的。

我当初犯的大错误:请你一定记清楚了:
ctx.drawImage(img,0,0);
改为
img.onload = function(){ctx.drawImage(img,0,0);}

只有img 加载完了 你画它才有意义。追问

谢谢你,确定图出来了。但为什么所有教程都不写这个呢?

温馨提示:答案为网友推荐,仅供参考
第1个回答  2021-12-12

对于这个问题,只把ctx.drawImage(img,0,0);改为img.onload = function(){ctx.drawImage(img,0,0);},然后等图片加载进来之后绘画即可。其实出现这种情况的原因是图片没有准备好,就开始绘图所造成的。

html5是构建Web内容的一种语言描述方式,其新引进的语法特征能够在移动设备上支持多媒体,能更好地适应移动端设备。新的解析规则增强了灵活性、新属性、淘汰过时的或冗余的属性,真正地改变了用户与文档的交互方式。

第2个回答  2021-12-18

    把ctx.drawImage(img,0,0);改为img.onload = function(){ctx.drawImage(img,0,0);}

    然后等图片加载进来之后绘画即可。

第3个回答  2021-12-10
ctx.drawImage(img,0,0);
改为
img.onload = function(){ctx.drawImage(img,0,0);}

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网