Skip to content

Instantly share code, notes, and snippets.

@ptvans
Created July 21, 2012 10:19
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 ptvans/3155369 to your computer and use it in GitHub Desktop.
Save ptvans/3155369 to your computer and use it in GitHub Desktop.
just another inlet to tributary
var txt;
var n = 67;
var tfactor = -18.6425*-71;
var afactor = 43.3475*16;
var sfactor = 3;
var colors = ["#8B3333", "#49143C"];
var size = 3.27814;
var percent = 0.81804;
var data = _.map(d3.range(n), function(d,i) {
size *= percent;
return size;
});
tributary.loop = "pingpong";
tributary.init = function(g) {
g.append("rect")
.attr("width", "100%")
.attr("height", "100%");
var squares = g.selectAll("g.square")
.data(data)
.enter().append("svg:g")
.classed("square", true)
.attr("transform", "translate(" + [0,0] + ")");
squares.append("svg:rect")
//.attr("rx", 6)
//.attr("ry", 6)
.attr("x", -12.5)
.attr("y", -12.5)
.attr("width", 24)
.attr("height", 25)
.attr("transform", function(d, i) { return "scale(" + (d) * 20 + ")"; })
.style("opacity", 0.13709)
.style("fill", function(d,i) {
return colors[i%2];
});
squares.map(function(d) {
return {center: [tributary.sw/2.4,tributary.sh/2.1], angle: 0};
});
};
tributary.run = function(g,t) {
var squares = g.selectAll("g.square")
squares.attr("transform", function(d, i) {
//d.center[0] += (mouse[0] - d.center[0]) / (i + 5);
//d.center[1] += (mouse[1] - d.center[1]) / (i + 5);
//shoudl be more elegant way to reset this
d.angle += Math.sin((t*tfactor + i) / afactor) * sfactor;
return "translate(" + d.center + ")rotate(" + d.angle + ")";
});
};
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment