youxizhizuo22222 2017-05-06 15:16 采纳率: 33.3%
浏览 914

关于javascript里面函数的问题。

<script >
    var can=document.getElementById("canvas");
    var ctx=can.getContext("2d");
    var w=can.width=window.innerWidth;
    var h=can.height=window.innerHeight;
    window.onresize=function(){
        var w=can.width=window.innerWidth;
        var h=can.height=window.innerHeight;
    }

            function star(){
                console.log('star');
                var img=new Image();
                img.src='earth.png';
                img.onload=function(){
                    var time=0;
                    ctx.save();
                    ctx.translate(600,400);
                    ctx.rotate(time*(360/365)*Math.PI/180);
                    ctx.drawImage(img,180,0,60,60);
                    time++;
                    ctx.restore();
                }
            }
            star();

</script>


上面这段函数想用star();来调用,原本想让<img id="earth"src="earth.png"style="display:none" />加载的图片按固定轨迹运行,用img.onload=function(){}来调用执行,但为什么感觉好像程序里面的time++并没有执行,而是执行了一次就停止了。
有什么方法能让加载的图片按固定轨道运行,然后在下方用setInterval();来刷新达到运动的效果。

没有运行的根本是不是因为函数作用域的关系?

希望各位大神指点一下。
  • 写回答

3条回答 默认 最新

  • devmiao 2017-05-06 15:53
    关注
    评论

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog