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

为什么我的canvas容器里,画不出图片来呢?xx.png和这个html文件放在同一目录下了。就是空白,画不出来。<!DOCTYPEHTML><!--Thistextis... 为什么我的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绘制图形是可以的。
展开
 我来答
seavan
推荐于2017-11-25 · TA获得超过525个赞
知道小有建树答主
回答量:269
采纳率:100%
帮助的人:104万
展开全部
我当初犯的大错误:请你一定记清楚了:
ctx.drawImage(img,0,0);
改为
img.onload = function(){ctx.drawImage(img,0,0);}

只有img 加载完了 你画它才有意义。
追问
谢谢你,确定图出来了。但为什么所有教程都不写这个呢?
博思aippt
2024-07-20 广告
博思AIPPT是基于ai制作PPT的智能在线工具,它提供了4种AI制作PPT的方式,包括AI生成大纲、AI直接生成PPT、文本生成PPT、AI提炼文档生成PPT,一站式集成多种AI生成PPT的方式,可满足办公用户的不同需求和使用场景。ai生... 点击进入详情页
本回答由博思aippt提供
浅陌记忆lY
2021-12-12 · TA获得超过171个赞
知道小有建树答主
回答量:910
采纳率:100%
帮助的人:35.8万
展开全部

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

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

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
华萤远程
2021-12-18 · TA获得超过6.9万个赞
知道大有可为答主
回答量:6.8万
采纳率:100%
帮助的人:2395万
展开全部
  1. 把ctx.drawImage(img,0,0);改为img.onload = function(){ctx.drawImage(img,0,0);}

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

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
热情的ly265
2021-12-10 · 超过249用户采纳过TA的回答
知道小有建树答主
回答量:1834
采纳率:98%
帮助的人:68.9万
展开全部
ctx.drawImage(img,0,0);
改为
img.onload = function(){ctx.drawImage(img,0,0);}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式