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

144 lines
4.0 KiB
Markdown
Raw Normal View History

---
id: 587d7fa9367417b2b2512bd0
title: Inverter elementos do SVG
challengeType: 6
forumTopicId: 301488
dashedName: 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`.
```js
assert($('rect').eq(0).attr('y') == h - dataset[0] * 3);
```
O segundo `rect` deve ter um valor de `y` igual a `7`.
```js
assert($('rect').eq(1).attr('y') == h - dataset[1] * 3);
```
O terceiro `rect` deve ter um valor de `y` igual a `34`.
```js
assert($('rect').eq(2).attr('y') == h - dataset[2] * 3);
```
O quarto `rect` deve ter um valor de `y` igual a `49`.
```js
assert($('rect').eq(3).attr('y') == h - dataset[3] * 3);
```
O quinto `rect` deve ter um valor de `y` igual a `25`.
```js
assert($('rect').eq(4).attr('y') == h - dataset[4] * 3);
```
O sexto `rect` deve ter um valor de `y` igual a `46`.
```js
assert($('rect').eq(5).attr('y') == h - dataset[5] * 3);
```
O sétimo `rect` deve ter um valor de `y` igual a `13`.
```js
assert($('rect').eq(6).attr('y') == h - dataset[6] * 3);
```
O oitavo `rect` deve ter um valor de `y` igual a `58`.
```js
assert($('rect').eq(7).attr('y') == h - dataset[7] * 3);
```
O nono `rect` deve ter um valor de `y` igual a `73`.
```js
assert($('rect').eq(8).attr('y') == h - dataset[8] * 3);
```
# --seed--
## --seed-contents--
```html
<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--
```html
<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>
```