Solucionado (ver solução)
Solucionado
(ver solução)
2
respostas

Exercício - Gráfico de Barras

Olá, pessoal!

Fiz o exercício em questão por partes, porém as barras não aparecem como no exempo, ficando duas barras pretas do mesmo tamanho. Verifiquei o código, está igual à resposta.

Fiquei na dúvida também do porquê que o array série e cores possuem o 'i': serie[i] e cores[i].

Agradeço pela ajuda!

<canvas width = "600" height = "400"></canvas>

<script>

    function desenhaRetangulo(x, y, largura, altura, cor) {
        var tela = document.querySelector("canvas");
        var pincel = tela.getContext("2d");


        pincel.fillStyle = cor;
        pincel.fillRect(x, y, largura, altura);

        pincel.strokeStyle = "black";
        pincel.strokeRect(x, y, largura, altura);

    }

    function desenhaTexto(x, y, texto) {
        var tela = document.querySelector("canvas");
        var pincel = tela.getContext("2d");

        pincel.font = "15px Georgia";
        pincel.fillStyle = "black";
        pincel.fillText(texto, x, y);

    }

    /*
    desenhaRetangulo(100, 100, 250, 150, "green");

    desenhaTexto(400, 200, "Mensagem de Teste", "red", "24px Arial");
    */

    function desenhaBarra(x, y, serie, cores, texto) {

        desenhaTexto(x, y - 10, texto);
        var somaAltura = 0
        for (var i = 0; i < serie.length; i++) {
            var altura = serie[i];
            desenhaRetangulo(x, y, somaAltura, 50, altura, cores[i]);
            somaAltura = somaAltura + altura;
        }
    }

    var cores = ["blue", "green", "yellow", "red"];
    var serie2015 = [50, 25, 20, 5];
    var serie2016 = [65, 20, 13, 2];

    desenhaBarra(50, 50, serie2015, cores, "2015");
    desenhaBarra(150, 50, serie2016, cores, "2016");

</script>
2 respostas
solução!

Fala Matheus, tudo bem? Um leve erro que eu percebi aqui que pode ter confundido todo o seu código, na linha dentro da função desenhaBarra:

desenhaRetangulo(x, y, somaAltura, 50, altura, cores[i]);

Nesse caso, você tá passando um parâmetro a mais pra função desenhaRetangulo, que recebe apenas 5. Acredito eu que para que a lógica funcionasse, na verdade a linha deveria ser substituída por:

desenhaRetangulo(x, y + somaAltura, 50, altura, cores[i]);

Substituindo por y+somaAltura, como acima.

Já a sua dúvida sobre o ''i'' nos Arrays, é simples: como os arrays estão dentro de um laço for, a intenção do código é acessar cada endereço do array de cada vez. Ou seja, quando i = 0, cores[0] = 'blue'. Quando esse valor é incrementado para i=1, cores[i]=cores[1]='green'. Trata-se de um laço de repetição.

Acredito que com essa modificação seu código vai funcionar. No demais, boa prática!

Fala, José Henrique! Tudo bem e você?

Obrigado pelas orientações. Corrigi o código e agora deu certo!

Valeu também pelos esclarecimentos sobre os arrays. Relacionei com o que já foi aprendido sobre isso e, com seu exemplo, consegui fechar o raciocínio.

Um abraço!