Skip to content

Instantly share code, notes, and snippets.

@tmcw
Last active December 12, 2015 01:09
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 tmcw/4689139 to your computer and use it in GitHub Desktop.
Save tmcw/4689139 to your computer and use it in GitHub Desktop.
<!DOCTYPE html>
<meta charset="utf-8">
<style>
body {
font:normal 12px/20px 'Georgia';
text-align:center;
background:url() #222;
}
path {
stroke:#15234d;
stroke-width:1.5;
fill:transparent;
}
a { display:block; }
</style>
<body>
<a href='http://geometrydaily.tumblr.com/post/31794922896/262-binary-suns-a-new-minimal-geometric'>inspired by geometrydaily</a>
<script src="http://d3js.org/d3.v3.min.js"></script>
<script>
var g = d3.select('body').append('svg')
.attr('width', 600)
.attr('height', 600)
.append('g')
.attr('transform', 'translate(300, 400)rotate(-45)');
var line = d3.svg.line()
.x(function(d) { return d[0]; })
.y(function(d) { return d[1]; });
//
// x(0,0) y(300,0)
//
// right angle
// 1 side is 1 unit
// cos = adjacent / hypot
// cos(x) = 1 / hypot
// hypot = 1 / cos(x)
// x = 1/a
// ax = 1
// a = 1/x
function unit(angle) {
return [
Math.cos(angle),
Math.sin(angle)
];
}
function mult(x, y) {
return x.map(function(_) {
return _ * y;
});
}
function gen(i) {
var r = 150;
var angle = Math.PI * 1.5 * (i / 38), l;
if (angle < Math.PI/4) {
l = (1/Math.cos(angle)) * r;
} else if (angle < Math.PI / 2) {
l = (1/Math.sin(angle)) * r;
} else if (angle < (Math.PI * 3/4)) {
l = (1/Math.sin(angle)) * r;
} else if (angle < Math.PI * 1.25) {
l = Math.abs((1/Math.cos(angle)) * r);
} else if (angle < (Math.PI * 2)) {
l = Math.abs((1/Math.sin(angle)) * r);
}
return [
[0, 0],
mult(unit(angle), l)
];
}
g.selectAll('path.a')
.data(d3.range(0, 39).map(gen))
.enter()
.append('path')
.attr('class', 'a')
.attr('d', line);
g.selectAll('path.b')
.data(d3.range(0, 39).map(gen))
.enter()
.append('path')
.attr('class', 'b')
.attr('d', line)
.attr('transform', function() {
return 'rotate(180, 0, 0)translate(-150, 0)';
});
</script>
</body>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment