Вы можете использовать функцию setInterval
, как предложено в вашем коде, вот как я это сделал ..
var context, canvas;
var x = 100;
var y = 200;
var dx = 5;
var dy = 5; //0.02 makes it move v. slowly!
function drawCircle(move) {
if(move) {
x = move.x
y = move.y
}
context.clearRect(0,0,canvas.width, canvas.height);
context.beginPath()
context.fillStyle = "#0000ff";
context.arc(x, y, 20, 0, Math.PI*2, true);
context.closePath();
context.fill();
}
window.onload = function(e){
canvas = document.getElementById('myCanvas');
context = canvas.getContext('2d');
drawCircle()
var interval;
canvas.onclick = function(){
if(interval) //don't run if already doing so..
return;
var end_move = {
x: 100,
y: 100
};
var interval = setInterval(function(){
if(x === end_move.x && y === end_move.y){
//stop animation case..
clearInterval(interval);
interval = undefined;
} else {
var newX;
if(Math.abs(x - end_move.x) < dx){
newX = x;
} else {
newX = (x > end_move.x) ? x-dx : x+dx;
}
var newY;
if(Math.abs(y - end_move.y) < dy){
newY = y;
} else {
newY = (y > end_move.y) ? y-dy : y+dy;
}
drawCircle({
x: newX,
y: newY
});
}
}, 10);
}
}
Код устанавливает end_position
, где он должен закончиться. Затем он устанавливает интервал для перемещения на одно и то же расстояние на каждой итерации, когда он приближается к желаемой позиции, он гарантирует, что интервал заканчивается, устанавливая позицию на желаемую.