A lógica é boa? Está correta?
<canvas width="600" height="400"></canvas>
<script>
var tela = document.querySelector('canvas');
var pincel = tela.getContext('2d');
pincel.fillStyle = "gray";
pincel.fillRect(0,0,600,400);
var cores = ["blue", "red", "green"];
var indiceCorAtual = 0;
var raio = 10;
function desenhaCirculo(evento){
var x = evento.pageX - tela.offsetLeft;
var y = evento.pageY - tela.offsetTop;
while(raio <= 40){
if(evento.shiftKey){
raio = raio + 10;
}
break;
}
while(raio >= 10){
if(evento.altKey){
raio = raio - 5;
}
break;
}
pincel.fillStyle = "blue";
pincel.beginPath();
pincel.arc(x, y, raio, 0, 2*3.14);
pincel.fill();
console.log("Posição do clique: " + x + ", " + y);
}
tela.onclick = desenhaCirculo;