许雷_ 2022-07-26 21:41 采纳率: 100%
浏览 30
已结题

canvas的drawImage

额,直接看码吧…

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title></title>
        <style>
            body{
                margin: 0;
                overflow: hidden;
            }
            #canvas{
                position: absolute;
            }
        </style>
    </head>
    <body>
        <canvas id="canvas"></canvas>
        <script>
            var canvas=document.getElementById("canvas");
            var ctx=canvas.getContext("2d");
            canvas.width=window.innerWidth;
            canvas.height=window.innerHeight;
            for(var i=0;i<=1;i++){
                var img=new Image();
                img.onload=function(){
                    ctx.drawImage(img,i*100,0,100,100);
                }
                img.src="img/map/2.svg";
            }
        </script>
    </body>
</html>

照理说应该有两张一样的图片,但是…

img

它只显示了最后一张,试了很多遍,只要drawImage用到for循环里它就只显示最后一张
这是为啥,有啥解决方法吗…(这个只是我简化出来的一个例子,不能手动把for给拆成一大串

  • 写回答

1条回答 默认 最新

  • 洋哥登陆 2022-07-26 22:27
    关注

    var img=new Image();
    img.onload=function(){
    for(var i=0;i<=1;i++){
    ctx.drawImage(img,i*100,0,100,100);
    }
    }
    img.src="img/map/2.svg";

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 8月4日
  • 已采纳回答 7月27日
  • 创建了问题 7月26日

悬赏问题

  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭
  • ¥15 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么