绘制的图像没有移动 canvas

Drawn image not moving on canvas

我用 html 制作游戏 canvas.I 需要移动图像精灵但我的代码只在相同的图像上重绘图像 position.Where 有问题吗?代码在这里


class Duck{
   constructor(x,y){
       this.x = x;
       this.y = y;
       this.skin = 'img/path/';
   }

   draw() {    
     var img = new Image();  
     img.src = this.skin;
     img.onload = function () {    
     ctx.clearRect(0, 0, canvas.width, canvas.height);
     ctx.drawImage(img,this.x, this.y);
     ctx.restore();
     }
    
   }

   move(){
         this.x+=10;
         this.y+=10;     
   }
}


var canvas = document.getElementById("canv");
var ctx = canvas.getContext("2d");

var d = new Duck(0,0);

//this function called from another file and it works
function mainLoop() {
    d.move();
    d.draw();
    requestAnimationFrame(mainLoop);
    }

您的代码已修复:

  • 你不需要ctx.restore();
  • 您需要在draw方法中存储this上下文,以供在img.onload回调
  • 中引用

class Duck {
    constructor(x, y) {
        this.x = x;
        this.y = y;
        this.skin = '';
    }

    draw() {
        var img = new Image();
        img.src = this.skin;
        const that = this;
        img.onload = function () {
            ctx.clearRect(0, 0, canvas.width, canvas.height);
            ctx.drawImage(img, that.x, that.y);
        }

    }

    move() {
        this.x += 10;
        this.y += 10;
    }
}

var canvas = document.getElementById("canv");
var ctx = canvas.getContext("2d");

var d = new Duck(0, 0);

//this function called from another file and it works
function mainLoop() {
    d.move();
    d.draw();
    requestAnimationFrame(mainLoop);
}

mainLoop();
<canvas id="canv" height="600px" width="600px"></canvas>