canvas 实现一张图片 旋转下落


var canvas = document.getElementById('canvas');
var  ctx = canvas.getContext("2d");
var img = new Image(),i = 1;
    img.crossOrigin = "anonymous";
    img.src = 'http://s18.mogucdn.com/p2/160804/upload_632bjgig656cech975lk32kebbe53_230x440.png';
    img.onload = function(){
       
        setInterval(function(){
            ctx.clearRect(0, 0, canvas.width, canvas.height);
            ctx.drawImage(img,200,i);
            ctx.translate(315,i+220);
            ctx.rotate(i* Math.PI / 180);
            ctx.translate(-315,-i-220);
            i++;

        },160);
    }
    
     这样好像只会原地旋转
阅读 3.9k
1 个回答
<canvas id="canvas" width='800' height='800'></canvas>


var canvas = document.getElementById('canvas');
var  ctx = canvas.getContext("2d");
var img = new Image(),i = 1;
    img.crossOrigin = "anonymous";
    img.src = 'http://s18.mogucdn.com/p2/160804/upload_632bjgig656cech975lk32kebbe53_230x440.png';
    img.onload = function(){
           var imgW = img.width, imgH = img.height, posx = 100;
        setInterval(function(){
            ctx.clearRect(0, 0, canvas.width, canvas.height);
            ctx.save();
            ctx.translate(posx + imgW/2,imgH/2+i);
            ctx.rotate(i* Math.PI / 180);
            ctx.translate(-posx -imgW/2,-imgH/2-i);
            ctx.drawImage(img, posx, i);
            ctx.restore();
            i++;

        },16);
    }
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题