topical media & game development
mobile-data-circle-11.htm / htm
<script src="http://d3js.org/d3.v3.min.js"></script>
<link rel="stylesheet" type="text/css" href="mobile-data-circle-style-d3.css">
<script type="text/javascript">
data
var data = [32, 57, 112],
dataEnter = data.concat(293),
dataExit = data.slice(0, 2),
w = 360,
h = 180,
x = d3.scale.ordinal().domain([57, 32, 112]).rangePoints([0, w], 1),
y = d3.scale.ordinal().domain(data).rangePoints([0, h], 2);
</script>
<h2 id="destroying_elements">destroying elements</h2>
<p>Sometimes you have the opposite problem from creation: you have too <em>many</em> existing elements, and you want to remove them. You can select nodes and <a href="https://github.com/mbostock/d3/wiki/Selections#remove">remove</a> them, but more commonly, you’ll use the <a href="https://github.com/mbostock/d3/wiki/Selections#exit">exit</a> selection to let D3 determine which elements are exiting the stage. The exit selection is the opposite of the enter selection: it contains all elements for which there is no corresponding data.</p>
<div class="chart" id="chart-11">
<pre class="code">var circle = svg.selectAll("circle")
.data([32, 57]);
</pre>
<button>run</button>
<!--
<svg width="360" height="180"><circle class="little" cx="180" cy="45" r="12"></circle><circle class="little" cx="60" cy="90" r="12"></circle><circle class="little" cx="300" cy="135" r="12"></circle><g class="data" transform="translate(20,20)"><rect x="-10" y="-10" width="20" height="20"></rect><text dy=".35em" text-anchor="middle">32</text></g><g class="data" transform="translate(40,20)"><rect x="-10" y="-10" width="20" height="20"></rect><text dy=".35em" text-anchor="middle">57</text></g></svg>
-->
</div>
<script type="text/javascript">
script
(function() {
var svg = d3.select("#chart-11").append("svg")
.attr("width", w)
.attr("height", h);
circle
var circle = svg.selectAll(".little")
.data(data)
.enter().append("circle")
.attr("class", "little")
.attr("cx", x)
.attr("cy", y)
.attr("r", 12)
.filter(function(d, i) { return i == 2; });
select
var g = svg.selectAll(".data")
.data(dataExit)
.enter().append("g")
.attr("class", "data")
.attr("transform", function(d, i) { return "translate(" + 20 * (i + 1) + ",20)"; });
append
g.append("rect")
.attr("x", -10)
.attr("y", -10)
.attr("width", 20)
.attr("height", 20);
g.append("text")
.attr("dy", ".35em")
.attr("text-anchor", "middle")
.text(String);
button
d3.select("#chart-11 button").on("click", function() {
g
.attr("transform", function(d, i) { return "translate(" + 20 * (i + 1) + ",20)"; })
.select("rect")
.style("opacity", 1);
transition
g.transition()
.duration(750)
.attr("transform", function(d) { return "translate(" + x(d) + "," + y(d) + ")"; })
.select("rect")
.style("opacity", 1e-6);
circle
.style("fill", "#aaa")
.style("stroke", "#666")
.transition()
.duration(750)
.style("fill", "lightcoral")
.style("stroke", "red");
});
})();
</script>
(C) Æliens
04/09/2009
You may not copy or print any of this material without explicit permission of the author or the publisher.
In case of other copyright issues, contact the author.
<script src="http://www.google-analytics.com/urchin.js" type="text/javascript">
</script>
<script type="text/javascript">
_uacct = "UA-2780434-1";
urchinTracker();
</script>