Escrevi meu código e tentei limitar a bolinha para não ir além do canvas quando encostasse na borda. Funciona para o eixo x. Mas não sei o que houve com o eixo y. Quando x > 20 ou x < 580 e eu movo o eixo y até o limite, funciona perfeitamente e a bolinha não avança. Mas se x = 20 ou x = 580 e eu movo a bolinha y até o limite, ela avança além da borda. No que errei?
<canvas width="600" height="400"></canvas>
<script>
var tela = document.querySelector('canvas');
var pincel = tela.getContext('2d');
pincel.fillStyle = 'lightgray';
pincel.fillRect(0, 0, 600, 400);
function desenhaCirculo(x, y, raio) {
pincel.fillStyle = "blue";
pincel.beginPath();
pincel.arc(x, y, raio, 0, 2 * Math.PI);
pincel.fill();
}
function limpaTela() {
pincel.clearRect(0, 0, 600, 400);
pincel.fillStyle = 'lightgray';
pincel.fillRect(0, 0, 600, 400);
}
var x = 20;
var y = 20;
var esquerda = 37;
var cima = 38;
var direita = 39;
var baixo = 40;
var move = 10;
function animacao () {
limpaTela();
desenhaCirculo(x, y, 20);
if(x <= 20) {
x = 20;
} else if(x >= 580) {
x = 580;
} else if(y <= 20) {
y = 20;
} else if (y >= 380) {
y = 380;
}
}
setInterval(animacao, 20);
function teclaPressionada (evento) {
if(evento.keyCode == direita ) {
x += move;
} else if(evento.keyCode == esquerda) {
x -= move;
} else if(evento.keyCode == cima) {
y -= move;
} else if(evento.keyCode == baixo) {
y += move;
}
}
document.onkeydown = teclaPressionada;
</script>