Skip to content

Instantly share code, notes, and snippets.

@zawarudo
Created October 21, 2013 14:23
Show Gist options
  • Save zawarudo/7084713 to your computer and use it in GitHub Desktop.
Save zawarudo/7084713 to your computer and use it in GitHub Desktop.
D3.js bar graph animates on enter.
<html>
<head>
<script type="text/javascript" src="http://mbostock.github.com/d3/d3.js"></script>
</head>
<body>
<div id="chart">
</div>
<script type="text/javascript">
initial();
function initial(){
margin = {top: 50, right: 50, bottom: 50, left: 50},
w = 960 - margin.left - margin.right,
h = 500 - margin.top - margin.bottom;
var outerSvg = d3.select("#chart")//Outer svg holding our tools and render window
.append("svg:svg")
.attr("width", w + margin.left + margin.right)
.attr("height", h + margin.top + margin.bottom)
.style("border-style", "dashed")
.style("border-width", "2px");
outerSvg.append("image") //"Refresh" Button
.attr("width", '30px')
.attr("height", '30px')
.attr("xlink:href", "")
.attr("onclick","render()");
render();
}
function render(){
d3.select('#chart svg svg').remove();
innerW = w - margin.left - margin.right,
innerH = h - margin.top - margin.bottom,
dataNum = 12,
barWidth = w/dataNum,
color = '#CC6600',
interval = 2000; //2 seconds
var svg = d3.select("#chart svg")
.append("svg:svg")
.attr("x", margin.left)
.attr("y", margin.top + margin.bottom)
.attr("width", innerW + margin.left + margin.right)
.attr("height", innerH + margin.top + margin.bottom)
.style("border-style", "dashed")
.style("border-width", "2px");
//Generate Dataset
var dataset = d3.range(dataNum).map(function(d,i) {
return {value: Math.random() * (h + margin.top + margin.bottom)/2 ,position: i};
});
var datapoints = svg.append("svg:g").attr("id", "points");
datapoints.selectAll("rect")
.data(dataset)
.enter()
.append("rect")
.attr("width", barWidth - 25)
.attr("x", function(d,i){ return (-barWidth * i+1)})
.attr("y", -h)
.style('fill', color)
.style('stroke-width','1')
.attr('transform','rotate(180)')
.attr("height", '0' )
.transition()
.attr("height", function(d){ return d.value })
.duration(interval * Math.random());
}
</script>
</body>
</html>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment