Skip to content

Instantly share code, notes, and snippets.

@trinary
Created November 4, 2013 00:40
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save trinary/7296497 to your computer and use it in GitHub Desktop.
Save trinary/7296497 to your computer and use it in GitHub Desktop.
Tributary inlet
{"description":"Tributary inlet","endpoint":"","display":"svg","public":true,"require":[],"fileconfigs":{"inlet.js":{"default":true,"vim":false,"emacs":false,"fontSize":12},"_.md":{"default":true,"vim":false,"emacs":false,"fontSize":12},"config.json":{"default":true,"vim":false,"emacs":false,"fontSize":12},"style.css":{"default":true,"vim":false,"emacs":false,"fontSize":12}},"fullscreen":false,"play":false,"loop":false,"restart":false,"autoinit":true,"pause":true,"loop_type":"pingpong","bv":false,"nclones":15,"clone_opacity":0.4,"duration":3000,"ease":"linear","dt":0.01,"thumbnail":"http://i.imgur.com/wvYsXKE.png"}
var w = 500;
var h = 300;
var margin = {left: 20, right: 20, top: 20, bottom: 60};
var width = w - margin.left - margin.right;
var height = h - margin.top - margin.bottom;
//Original data
var dataset = [
[
{ y: 5 },
{ y: 4 },
{ y: 2 },
{ y: 7 },
{ y: 23 }
],
[
{ y: 10 },
{ y: 12 },
{ y: 19 },
{ y: 23 },
{ y: 17 }
],
[
{ y: 22 },
{ y: 28 },
{ y: 32 },
{ y: 35 },
{ y: 43 }
]
];
//Set up stack method
var stack = d3.layout.stack();
//Data, stacked
stack(dataset);
//Set up scales
var xScale = d3.scale.ordinal()
.domain(d3.range(dataset[0].length))
.rangeRoundBands([0, width], 0.05);
var yScale = d3.scale.linear()
.domain([0,
d3.max(dataset, function(d) {
return d3.max(d, function(d) {
return d.y0 + d.y;
});
})
])
.range([height, 0]);
var xAxis = d3.svg.axis()
.scale(xScale)
.orient("bottom")
//Easy colors accessible via a 10-step ordinal scale
var colors = d3.scale.category10();
// Names for the categories
var categories = ["Apples", "Bananas", "Grapes"];
//Create SVG element
var svg = d3.select("svg")
.attr("width", w)
.attr("height", h);
// Add a group for each row of data
var groups = svg.selectAll("g")
.data(dataset)
.enter()
.append("g")
.attr("transform","translate(" + [margin.left, margin.top] + ")")
.style("fill", function(d, i) {
return colors(i);
});
// Add a rect for each data value
var rects = groups.selectAll("rect")
.data(function(d) { return d; })
.enter()
.append("rect")
.attr("x", function(d, i) {
return xScale(i);
})
.attr("y", function(d) {
return yScale(d.y0 + d.y);
})
.attr("height", function(d) {
return height - yScale(d.y);
})
.attr("width", xScale.rangeBand());
// Add the x axis
svg.append("g").attr({
"class": "x axis",
"transform": "translate(" + [margin.left, height + margin.top] + ")"
}).call(xAxis);
var legend = svg.append("g").attr({
"class": "legend",
"transform": "translate(" + [margin.left, height + margin.top + 10] + ")"
});
dataset.forEach(function(d,i) {
legend.append("rect").attr({
"transform": "translate(" + [ 10 + (i * 140), 20] + ")",
"x": 0,
"y": 0,
"width": 14,
"height":14,
"fill": colors(i)
});
legend.append("text").attr({
"transform": "translate(" + [ 30 + (i * 140), 33] + ")",
"fill": colors(i)
}).text(categories[i]);
});
body {
font-family: "Helvetica Neue", Helvetica, sans-serif;
}
.axis {
stroke: #666666;
stroke-width: 1px;
fill: none;
}
text {
stroke: none;
fill: #666666;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment