toolkit/javascript/d3/examples/brush/brush-x.html
changeset 47 c0b4a8b5a012
equal deleted inserted replaced
46:efd9c589177a 47:c0b4a8b5a012
       
     1 <!DOCTYPE html>
       
     2 <html>
       
     3   <head>
       
     4     <meta http-equiv="Content-Type" content="text/html;charset=utf-8"/>
       
     5     <title>Brush</title>
       
     6     <script type="text/javascript" src="../../d3.js"></script>
       
     7     <style type="text/css">
       
     8 
       
     9 svg {
       
    10   font: 10px sans-serif;
       
    11 }
       
    12 
       
    13 circle {
       
    14   -webkit-transition: fill-opacity 250ms linear;
       
    15 }
       
    16 
       
    17 .selecting circle {
       
    18   fill-opacity: .2;
       
    19 }
       
    20 
       
    21 .selecting circle.selected {
       
    22   stroke: #f00;
       
    23 }
       
    24 
       
    25 .axis path, .axis line {
       
    26   fill: none;
       
    27   stroke: #000;
       
    28   shape-rendering: crispEdges;
       
    29 }
       
    30 
       
    31 .brush .extent {
       
    32   stroke: #fff;
       
    33   fill-opacity: .125;
       
    34   shape-rendering: crispEdges;
       
    35 }
       
    36 
       
    37     </style>
       
    38   </head>
       
    39   <body>
       
    40     <script type="text/javascript">
       
    41 
       
    42 var data = d3.range(800).map(Math.random);
       
    43 
       
    44 var m = [10, 10, 20, 10],
       
    45     w = 960 - m[1] - m[3],
       
    46     h = 100 - m[0] - m[2];
       
    47 
       
    48 var x = d3.scale.linear().range([0, w]),
       
    49     y = d3.random.normal(h / 2, h / 8);
       
    50 
       
    51 var svg = d3.select("body").append("svg:svg")
       
    52     .attr("width", w + m[1] + m[3])
       
    53     .attr("height", h + m[0] + m[2])
       
    54   .append("svg:g")
       
    55     .attr("transform", "translate(" + m[3] + "," + m[0] + ")");
       
    56 
       
    57 svg.append("svg:g")
       
    58     .attr("class", "x axis")
       
    59     .attr("transform", "translate(0," + h + ")")
       
    60     .call(d3.svg.axis().scale(x).orient("bottom"));
       
    61 
       
    62 var circle = svg.selectAll("circle")
       
    63     .data(data)
       
    64   .enter().append("svg:circle")
       
    65     .attr("transform", function(d) { return "translate(" + x(d) + "," + y() + ")"; })
       
    66     .attr("r", 3.5);
       
    67 
       
    68 svg.append("svg:g")
       
    69     .attr("class", "brush")
       
    70     .call(d3.svg.brush().x(x)
       
    71     .on("brushstart", brushstart)
       
    72     .on("brush", brush)
       
    73     .on("brushend", brushend))
       
    74   .selectAll("rect")
       
    75     .attr("height", h);
       
    76 
       
    77 function brushstart() {
       
    78   svg.classed("selecting", true);
       
    79 }
       
    80 
       
    81 function brush() {
       
    82   var s = d3.event.target.extent();
       
    83   circle.classed("selected", function(d) { return s[0] <= d && d < s[1]; });
       
    84 }
       
    85 
       
    86 function brushend() {
       
    87   svg.classed("selecting", !d3.event.target.empty());
       
    88 }
       
    89 
       
    90     </script>
       
    91   </body>
       
    92 </html>