Reciclei o código da atividade do deslocamento da bola, ficou diferente da opinião do instrutor mas funcional.
Segue o código:
<canvas width="600" height="400"></canvas>
<script>
var tela = document.querySelector('canvas');
var pincel = tela.getContext('2d');
var r = 20;
var sentido = 1;
pincel.fillStyle = 'lightgray';
pincel.fillRect(0, 0, 600, 400);
function desenhaCirculo(x, y, raio, cor) {
pincel.fillStyle = cor;
pincel.beginPath();
pincel.arc(x, y, raio, 0, 2 * Math.PI);
pincel.fill();
}
function limpaTela() {
pincel.clearRect(0, 0, 600, 400);
}
function atualizaTela() {
limpaTela();
desenhaCirculo(300, 200, r, "red");
r = r + sentido
if (r > 30) {
sentido = -1;
} if (r < 20) {
sentido = + 1;
}
}
setInterval(atualizaTela, 20 );
</script>