Experimenting with transitions using a pack layout.
forked from matt81m's block: Pack Layout with Transitions
forked from matt81m's block: Pack Layout with Transitions
Experimenting with transitions using a pack layout.
forked from matt81m's block: Pack Layout with Transitions
forked from matt81m's block: Pack Layout with Transitions
| <!DOCTYPE html> | |
| <head> | |
| <meta charset="utf-8"> | |
| <script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.5.5/d3.min.js"></script> | |
| <style> | |
| body { | |
| background-color: #e9e9e9; | |
| margin:0; | |
| padding:0; | |
| position:fixed; | |
| top:0; | |
| right:0; | |
| bottom:0; | |
| left:0; | |
| } | |
| figure { margin-top: 45px; height: 100%; } | |
| svg { width:100%; height: 100% } | |
| .flex-container { | |
| display: flex; | |
| flex-flow: row wrap; | |
| width: 100%; | |
| height: 30px; | |
| } | |
| h3 { | |
| margin: 0; | |
| flex: 1; | |
| height: 100%; | |
| cursor: pointer; | |
| font-family: 'Helvetica'; | |
| padding-top:15px; | |
| padding-bottom: 10px; | |
| background-color: white; | |
| color: #666666; | |
| letter-spacing: 0.5; | |
| box-shadow: 0 0 3px rgba(0,0,0,0.2); | |
| text-align:center; | |
| } | |
| h3:hover { | |
| color: #F06060; | |
| background-color: #f5f5f5; | |
| } | |
| </style> | |
| </head> | |
| <body> | |
| <div class="flex-container"> | |
| <h3 class="state">State</h3> | |
| <h3 class="national">National</h3> | |
| </div> | |
| <figure></figure> | |
| <script> | |
| var margin = {top: 20, right: 20, bottom: 20, left: 20}; | |
| var svg = d3.select("figure").append("svg"); | |
| var svgNode = d3.select('svg').node(); | |
| var g = svg.append('g') | |
| .attr('transform', 'translate(' + (svgNode.clientWidth/2 - 200) + ',0)') | |
| var ease = 'cubic'; | |
| var diameter = 400; | |
| var pack = d3.layout.pack() | |
| .sort(function(a, b) { return a.category < b.category; }) | |
| .size([diameter, diameter]) | |
| .padding(20); | |
| var color = d3.scale.ordinal() | |
| .range(['#5C4B51', '#8CBEB2', '#F3B562', '#F06060']); | |
| var fontSize = d3.scale.linear() | |
| .domain([1, 10]) | |
| .range([12, 50]); | |
| d3.json('packData.json', function(err, data) { | |
| var nested = d3.nest() | |
| .key(function(v) { return v.region; }) | |
| .entries(data) | |
| .map(function(v) { | |
| return { | |
| region: v['key'], | |
| children: v['values'] | |
| } | |
| }); | |
| update(nested[0]); | |
| d3.select('.state').on('click', function() { | |
| update(nested[0]) | |
| }); | |
| d3.select('.national').on('click', function() { | |
| update(nested[1]); | |
| }); | |
| }); | |
| function update(data) { | |
| var node = g.selectAll('.node') | |
| .data(pack.nodes(data), function(d) { return d.category; }); | |
| var enterNodes = node.enter().append('g') | |
| .classed('node', true); | |
| enterNodes.append('circle') | |
| .classed('circle', true) | |
| .attr('fill', function(d) { return color(d.category); }) | |
| .each(function(d, i) { | |
| if (i === 0) { | |
| d3.select(this).attr('fill', 'white'); | |
| } | |
| }); | |
| enterNodes.append('text') | |
| .text(function(d) { return d.category ? d.category.toUpperCase() : ''; }) | |
| .attr({ | |
| fill: 'white', | |
| 'font-weight': 'bold', | |
| 'text-anchor': 'middle', | |
| 'font-family': 'sans-serif' | |
| }); | |
| node.transition().attr('transform', function(d) { | |
| return 'translate(' + d.x + ',' + d.y + ')'; | |
| }); | |
| node.select('.circle') | |
| .transition() | |
| .duration(600) | |
| .ease(ease) | |
| .attr('r', function(d) { return d.r; }); | |
| node.select('text') | |
| .transition() | |
| .duration(600) | |
| .ease(ease) | |
| .attr('font-size', function(d) { return fontSize(d.value); }) | |
| .attr('transform', function(d) { | |
| return 'translate(0,' + (fontSize(d.value) / 3) + ')'; | |
| }); | |
| } | |
| </script> | |
| </body> |
| [ | |
| { | |
| "category": "walk", | |
| "region": "national", | |
| "value": "3.08392" | |
| }, | |
| { | |
| "category": "walk", | |
| "region": "state", | |
| "value": "8.56503" | |
| }, | |
| { | |
| "category": "bike", | |
| "region": "national", | |
| "value": "8.65901" | |
| }, | |
| { | |
| "category": "bike", | |
| "region": "state", | |
| "value": "3.41099" | |
| }, | |
| { | |
| "category": "run", | |
| "region": "national", | |
| "value": "1.51538" | |
| }, | |
| { | |
| "category": "run", | |
| "region": "state", | |
| "value": "7.79517" | |
| }, | |
| { | |
| "category": "swim", | |
| "region": "national", | |
| "value": "8.16451" | |
| }, | |
| { | |
| "category": "swim", | |
| "region": "state", | |
| "value": "4.41115" | |
| } | |
| ] |