4
respostas

código não funciona (gráficos)

Na aula 2 exercício 7 o código não funciona. Pode me falar

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

<script>

function desenhaRentangulo (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);
}

function desenhaBarra(x, y, serie, cores, texto) {
desenhaTexto(x, y - 10, texto);

var somaAltura = 0;
for (var i = 0; i < serie.lenght; 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 = [35, 20, 13, 2];

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

 </script>

o por quê?

4 respostas

Aline, boa tarde! Dentro do for na função desenhaRetangulo você esqueceu de fechar o parenteses

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

E quando você declarou as variáveis cores[] abriu a array com [ e fechou com )

var cores = ['blue', 'green', 'yellow', 'red')<----;

Corrigindo isso irá funcionar normalmente

Espero ter ajudado e bons estudos!

Olá! Corrigi, mas continua não funcionando.

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

<script>

function desenhaRentangulo (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);
}

function desenhaBarra(x, y, serie, cores, texto) {
desenhaTexto(x, y - 10, texto);

var somaAltura = 0;
for (var i = 0; i < serie.lenght; 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 = [35, 20, 13, 2];

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

 </script>

Aline, bom dia!

Você digitou desenhaRetangulo() errado

function desenhaRentangulo (x, y, largura, altura, cor) {

Está escrito Rentangulo, e ainda está escrito lenght ao invés de length na parte do for

for (var i = 0; i < serie.lenght; i++) {

Espero ter ajudado e bons estudos!

O gráfico apareceu, mas está sobrepondo o outro.