Minha solução:
<!-- bandeiras.html -->
<canvas width="600" height="400"></canvas>
<script>
let tela = document.querySelector("canvas");
let pincel = tela.getContext("2d");
desenhaBandeiraBrasil = () => {
pincel.fillStyle = "green";
pincel.fillRect(0, 0, 600, 400);
pincel.fillStyle = "yellow";
pincel.beginPath();
pincel.moveTo(300, 50);
pincel.lineTo(50, 200);
pincel.lineTo(550, 200);
pincel.fill();
pincel.beginPath();
pincel.moveTo(50, 200);
pincel.lineTo(300, 350);
pincel.lineTo(550, 200);
pincel.fill();
pincel.fillStyle = "darkblue";
pincel.beginPath();
pincel.arc(300, 200, 100, 0, 2 * 3.14);
pincel.fill();
};
desenhaBandeiraAlemanha = () => {
pincel.fillStyle = "black";
pincel.fillRect(0, 0, 600, 133);
pincel.fillStyle = "red";
pincel.fillRect(0, 133, 600, 133);
pincel.fillStyle = "yellow";
pincel.fillRect(0, 266, 600, 133);
};
let troca = true;
trocabandeira = () => {
if (troca) {
desenhaBandeiraBrasil();
troca = false;
} else {
desenhaBandeiraAlemanha();
troca = true;
}
};
intervalos = () => {
trocabandeira();
setInterval(trocabandeira, 3000);
};
intervalos();
</script>