2021-06-15 07:49:18 +00:00
---
id: 587d7fab367417b2b2512bd7
2021-07-26 14:39:21 +00:00
title: Criar um diagrama de dispersão com círculos do SVG
2021-06-15 07:49:18 +00:00
challengeType: 6
forumTopicId: 301484
dashedName: create-a-scatterplot-with-svg-circles
---
# --description--
2021-07-26 14:39:21 +00:00
Um diagrama de dispersão é outro tipo de visualização. Ele geralmente usa círculos para mapear pontos de dados, que têm dois valores cada. Esses valores estão relacionados aos eixos `x` e `y` , sendo usados para posicionar o círculo na visualização.
2021-06-15 07:49:18 +00:00
2021-07-26 14:39:21 +00:00
O SVG tem uma tag `circle` para criar a forma do círculo. Funciona muito parecido com os elementos `rect` que você usou para o gráfico de barras.
2021-06-15 07:49:18 +00:00
# --instructions--
2021-07-26 14:39:21 +00:00
Use os métodos `data()` , `enter()` e `append()` para associar o `dataset` aos novos elementos de `circle` que são incluídos no canvas do SVG.
2021-06-15 07:49:18 +00:00
2021-07-26 14:39:21 +00:00
**Observação:** os círculos não serão visíveis porque ainda não definimos seus atributos. Faremos isso no próximo desafio.
2021-06-15 07:49:18 +00:00
# --hints--
2021-07-26 14:39:21 +00:00
O código deve ter 10 elementos `circle` .
2021-06-15 07:49:18 +00:00
```js
assert($('circle').length == 10);
```
# --seed--
## --seed-contents--
```html
< body >
< script >
const dataset = [
[ 34, 78 ],
[ 109, 280 ],
[ 310, 120 ],
[ 79, 411 ],
[ 420, 220 ],
[ 233, 145 ],
[ 333, 96 ],
[ 222, 333 ],
[ 78, 320 ],
[ 21, 123 ]
];
const w = 500;
const h = 500;
const svg = d3.select("body")
.append("svg")
.attr("width", w)
.attr("height", h);
svg.selectAll("circle")
// Add your code below this line
// Add your code above this line
< / script >
< / body >
```
# --solutions--
```html
< body >
< script >
const dataset = [
[ 34, 78 ],
[ 109, 280 ],
[ 310, 120 ],
[ 79, 411 ],
[ 420, 220 ],
[ 233, 145 ],
[ 333, 96 ],
[ 222, 333 ],
[ 78, 320 ],
[ 21, 123 ]
];
const w = 500;
const h = 500;
const svg = d3.select("body")
.append("svg")
.attr("width", w)
.attr("height", h);
svg.selectAll("circle")
.data(dataset)
.enter()
.append("circle")
< / script >
< / body >
```