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>