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>