topical media & game development 
  
 
 
 
 
  
    
    
  
 mobile-data-circle-07.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="creating_elements">creating elements</h2>
  
  <p>But what if we had <em>four</em> numbers to display, rather than three? We wouldn’t have enough circles to display all the numbers. When joining data to elements, D3 stores the leftover data in the <a href="https://github.com/mbostock/d3/wiki/Selections#enter">enter</a> selection. (The terms enter and exit are adopted from stage terminology.) Here, the fourth number 293 remains in the enter selection, because we only have three circle elements:</p>
  <div class="chart" id="chart-7">
  <pre class="code">var circle = svg.selectAll("circle")
      .data([32, 57, 112, 293]);
  </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><g class="data" transform="translate(60,20)"><rect x="-10" y="-10" width="20" height="20"></rect><text dy=".35em" text-anchor="middle">112</text></g><g class="data" transform="translate(80,20)"><rect x="-10" y="-10" width="20" height="20"></rect><text dy=".35em" text-anchor="middle">293</text></g></svg>
-->
</div>
<script type="text/javascript">
  
  
  script
  
  (function() {
    var svg = d3.select("#chart-7").append("svg")
        .attr("width", w)
        .attr("height", h);
  
  
  
  circle
  
    svg.selectAll(".little")
        .data(data)
      .enter().append("circle")
        .attr("class", "little")
        .attr("cx", x)
        .attr("cy", y)
        .attr("r", 12);
  
  
  
  select
  
    var g = svg.selectAll(".data")
        .data(dataEnter)
      .enter().append("g")
        .attr("class", "data")
        .attr("transform", function(d, i) { return "translate(" + 20 * (i + 1) + ",20)"; });
  
    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-7 button").on("click", function() {
      g.attr("transform", function(d, i) { return "translate(" + 20 * (i + 1) + ",20)"; })
        .select("rect")
          .style("opacity", 1);
  
  
  
  filter
  
      g.filter(function(d, i) { return i != 3; }).transition()
          .duration(750)
          .attr("transform", function(d) { return "translate(" + x(d) + "," + y(d) + ")"; })
        .select("rect")
          .style("opacity", 1e-6);
  
  
  
  transition
  
      g.select("rect").filter(function(d, i) { return i == 3; })
          .style("fill", "#eee")
          .style("stroke", "#ccc")
        .transition()
          .duration(750)
          .style("fill", "lightgreen")
          .style("stroke", "green");
    });
  })();
  
  </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>