freeCodeCamp/curriculum/challenges/portuguese/04-data-visualization/data-visualization-with-d3/invert-svg-elements.md

4.0 KiB

id title challengeType forumTopicId dashedName
587d7fa9367417b2b2512bd0 Inverter elementos do SVG 6 301488 invert-svg-elements

--description--

Você pode ter percebido que o gráfico de barras parecia estar de cabeça para baixo ou invertido. Isso ocorre porque o SVG usa coordenadas (x, y).

No SVG, o ponto de origem para as coordenadas está no canto superior esquerdo. Uma coordenada x de 0 coloca uma forma na borda esquerda da área do SVG. Uma coordenada y de 0 coloca uma forma na borda superior da área do SVG. Valores mais altos de x empurram o retângulo para a direita. Valores mais altos de y empurram o retângulo para baixo.

Para fazer as barras ficarem na posição correta, você precisa alterar a maneira como a coordenada y é calculada. Isso precisa levar em conta tanto a altura da barra quanto a altura total da área do SVG.

A altura da área do SVG é 100. Se você tem um ponto de dados de 0 no conjunto, você deve esperar que a barra comece na parte inferior da área do SVG (não na parte superior). Para fazer isso, a coordenada y precisa de um valor de 100. Se o valor do ponto de dados for 1, você começaria com uma coordenada y de 100 para definir a barra na parte inferior. Em seguida, você precisa levar em conta a altura da barra de 1. Assim, a coordenada y final seria 99.

A coordenada y que é y = heightOfSVG - heightOfBar colocaria as barras na posição correta.

--instructions--

Altere a função de callback para o atributo y para definir a posição das barras no lugar certo. Lembre-se de que a height da barra é 3 vezes o valor do dado d.

Observação: em geral, a relação é y = h - m * d, onde m é a constante que dimensiona os pontos de dados.

--hints--

O primeiro rect deve ter um valor de y igual a 64.

assert($('rect').eq(0).attr('y') == h - dataset[0] * 3);

O segundo rect deve ter um valor de y igual a 7.

assert($('rect').eq(1).attr('y') == h - dataset[1] * 3);

O terceiro rect deve ter um valor de y igual a 34.

assert($('rect').eq(2).attr('y') == h - dataset[2] * 3);

O quarto rect deve ter um valor de y igual a 49.

assert($('rect').eq(3).attr('y') == h - dataset[3] * 3);

O quinto rect deve ter um valor de y igual a 25.

assert($('rect').eq(4).attr('y') == h - dataset[4] * 3);

O sexto rect deve ter um valor de y igual a 46.

assert($('rect').eq(5).attr('y') == h - dataset[5] * 3);

O sétimo rect deve ter um valor de y igual a 13.

assert($('rect').eq(6).attr('y') == h - dataset[6] * 3);

O oitavo rect deve ter um valor de y igual a 58.

assert($('rect').eq(7).attr('y') == h - dataset[7] * 3);

O nono rect deve ter um valor de y igual a 73.

assert($('rect').eq(8).attr('y') == h - dataset[8] * 3);

--seed--

--seed-contents--

<body>
  <script>
    const dataset = [12, 31, 22, 17, 25, 18, 29, 14, 9];

    const w = 500;
    const h = 100;

    const svg = d3.select("body")
                  .append("svg")
                  .attr("width", w)
                  .attr("height", h);

    svg.selectAll("rect")
       .data(dataset)
       .enter()
       .append("rect")
       .attr("x", (d, i) => i * 30)
       .attr("y", (d, i) => {
         // Add your code below this line



         // Add your code above this line
       })
       .attr("width", 25)
       .attr("height", (d, i) => 3 * d);
  </script>
</body>

--solutions--

<body>
  <script>
    const dataset = [12, 31, 22, 17, 25, 18, 29, 14, 9];

    const w = 500;
    const h = 100;

    const svg = d3.select("body")
                  .append("svg")
                  .attr("width", w)
                  .attr("height", h);

    svg.selectAll("rect")
       .data(dataset)
       .enter()
       .append("rect")
       .attr("x", (d, i) => i * 30)
       .attr("y", (d, i) => h - 3 * d)
       .attr("width", 25)
       .attr("height", (d, i) => 3 * d);
  </script>
</body>