d3/examples/dot/dot.html

100 строки
2.1 KiB
HTML
Исходник Обычный вид История

2010-09-28 22:34:52 +04:00
<html>
<head>
<title>Dot Plot</title>
<script type="text/javascript" src="../../d3.js"></script>
2010-09-28 22:34:52 +04:00
<style type="text/css">
body {
font: 10px sans-serif;
}
circle.dot {
fill: none;
stroke: steelblue;
stroke-width: 1.5px;
}
rect {
fill: none;
stroke: black;
shape-rendering: crispEdges;
}
.rule line {
stroke: #ccc;
shape-rendering: crispEdges;
}
</style>
</head>
<body>
<script type="text/javascript">
var data = d3.range(100).map(function(i) {
2010-09-28 22:34:52 +04:00
return {x: i / 99, y: Math.random()};
});
var w = 450,
h = 450,
p = 20;
var vis = d3.select("body")
2010-10-02 22:00:31 +04:00
.append("svg:svg")
2010-09-28 22:34:52 +04:00
.attr("width", w + p * 2)
.attr("height", h + p * 2)
2010-10-02 22:00:31 +04:00
.append("svg:g")
2010-09-28 22:34:52 +04:00
.attr("transform", "translate(" + p + "," + p + ")");
var rules = vis.selectAll("g.rule")
.data(d3.range(11))
.enter().append("svg:g")
2010-09-28 22:34:52 +04:00
.attr("class", "rule");
2010-10-02 22:00:31 +04:00
rules.append("svg:line")
2010-09-28 22:34:52 +04:00
.attr("x1", function(d) { return d / 10 * w; })
.attr("x2", function(d) { return d / 10 * w; })
.attr("y1", 0)
.attr("y2", h);
2010-10-02 22:00:31 +04:00
rules.append("svg:line")
2010-09-28 22:34:52 +04:00
.attr("y1", function(d) { return (1 - d / 10) * h; })
.attr("y2", function(d) { return (1 - d / 10) * h; })
.attr("x1", 0)
.attr("x2", w);
2010-10-02 22:00:31 +04:00
rules.append("svg:text")
2010-09-28 22:34:52 +04:00
.attr("x", function(d) { return d / 10 * w; })
.attr("y", h + 3)
.attr("dy", ".71em")
.attr("text-anchor", "middle")
.text(function(d) { return (d / 10).toFixed(1); });
2010-10-02 22:00:31 +04:00
rules.append("svg:text")
2010-09-28 22:34:52 +04:00
.attr("y", function(d) { return (1 - d / 10) * h; })
.attr("x", -3)
.attr("dy", ".35em")
.attr("text-anchor", "end")
.text(function(d) { return (d / 10).toFixed(1); });
2010-10-02 22:00:31 +04:00
vis.append("svg:rect")
2010-09-28 22:34:52 +04:00
.attr("width", w)
.attr("height", h);
var dots = vis.selectAll("circle.dot")
.data(data)
.enter().append("svg:circle")
2010-09-28 22:34:52 +04:00
.attr("class", "dot")
.attr("cx", function(d) { return d.x * w; })
.attr("cy", function(d) { return d.y * h; })
.attr("r", 27)
.attr("opacity", 1e-6)
2010-09-28 22:34:52 +04:00
.transition()
.delay(function(d, i) { return i * 3; })
2010-09-28 22:34:52 +04:00
.duration(750)
.attr("opacity", 1)
.attr("r", 4.5);
2010-09-28 22:34:52 +04:00
</script>
</body>
</html>