Skip to content

Instantly share code, notes, and snippets.

@atul-github
Last active August 29, 2015 14:23
Show Gist options
  • Save atul-github/f3dc48348b0dfeb79618 to your computer and use it in GitHub Desktop.
Save atul-github/f3dc48348b0dfeb79618 to your computer and use it in GitHub Desktop.
Rotating Pie - Rainbow / Newton Disc in D3.js - by Atul
<!--
Author : Atul Pandit
Email : [email protected] / [email protected]
-->
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Rotating Pie - Rainbow / Newton Disc in D3.js</title>
<script src="http://d3js.org/d3.v3.min.js"></script>
</head>
<body>
<script>
function colors(i) {
var rainbowcolors = ['#9400D3', '#4B0082', '#0000FF', '#00FF00', '#FFFF00', '#FF7F00', '#FF0000', '#FF0000', '#FF0000'];
return rainbowcolors[i];
}
// Drawing Pie without using pie layout.
function DrawPie(svg, data, cx, cy, r, startAngle) {
var arcs = svg.selectAll('.arc')
.data(data);
arcs.enter()
.append('path')
.attr('id', function (d, i) {
return 'arc' + (i).toString();
})
.attr('class', 'arc')
.style('stroke', function (d, i) {
return colors(i);
})
.style('fill', function (d, i) {
return colors(i);
})
;
//RotatePie(svg, startAngle);
arcs.attr('d', function (d, i) {
var rad = ((d.angle1 + startAngle) * Math.PI) / 180.0;
var x1 = d.cx + d.r * Math.cos(rad);
var y1 = d.cy + d.r * Math.sin(rad);
var rad = ((d.angle2 + startAngle) * Math.PI) / 180.0;
var x2 = d.cx + d.r * Math.cos(rad);
var y2 = d.cy + d.r * Math.sin(rad);
pathString = 'M' + x1 + ',' + y1 + ' ' + 'A' + d.r + ',' + d.r + ' 0 0,1 ' + x2 + ',' + y2 + ' L ' + d.cx + ',' + d.cy + ' Z ';
return pathString;
});
}
function RotatePie(svg, startAngle) {
var arcs = svg.selectAll('.arc');
var arcs = svg.selectAll('.arc');
arcs.attr('transform', function (d, i) {
var rotate = 'rotate(' + startAngle + ', ' + d.cx + ', ' + d.cy + ')';
return rotate;
});
}
var gContainerId, gCanvasId, gTopGroupId;
var svg;
function Initialize(containerId, cx, cy, r, piedata) {
var height = document.getElementById(containerId).clientHeight;
var width = document.getElementById(containerId).clientWidth;
gContainerId = containerId;
gCanvasId = containerId + '_canvas';
gTopGroupId = containerId + '_topGroup';
svg = d3.select("#" + containerId).append("svg")
.attr({ "id": gCanvasId, "width": width, "height": height })
.append("g")
.attr({ "id": gTopGroupId, 'x': 0, 'y': 0, "width": width, "height": height })
;
var startAngle = 0;
svg.append('circle')
.attr({ 'cx': cx, 'cy': cy, 'r': 2 })
.style('fill', 'red');
startAngle = 0;
var svg = svg;
var total = d3.sum(piedata);
var data = [];
var startAngle = 0;
for (var i = 0; i < piedata.length; ++i) {
var percent = (100 * piedata[i]) / total;
var a1 = startAngle;
var a2 = startAngle + (percent * 360) / 100
data.push({ cx: cx, cy: cy, r: r, percent: percent, angle1: a1, angle2: a2 });
startAngle += (percent * 360) / 100;
}
svg = d3.select('#' + gCanvasId);
DrawPie(svg, data, cx, cy, r, 0);
}
var startStopFlag = null;
var startAngle = 1;
var speed = 1;
function StartStopGame() {
if (startStopFlag == null) {
d3.timer(function () {
svg = d3.select('#' + gCanvasId);
RotatePie(svg, startAngle);
startAngle += parseInt(speed);
if (startStopFlag == null)
return true;
else
return false;
}, 500);
startStopFlag = 1;
document.getElementById('startStop').innerHTML = 'Stop';
}
else {
startStopFlag = null;
document.getElementById('startStop').innerHTML = 'Start';
}
}
function OnSpeedChange() {
var o = document.getElementById('speed');
speed = o.options[o.selectedIndex].value;
}
</script>
<div id="mainDiv" style="width:960px; height:470px">
<div id="drawAreaOuter" style="width:100%; height:100%; float:left; ">
<div id="menuTop">
<a id="startStop" href="javascript:StartStopGame()">Start</a> |
Speed :
<select id='speed' onchange="OnSpeedChange()">
<option value="1" selected="selected">Normal</option>
<option value="5">Fast</option>
<option value="10">Faster</option>
<option value="30">Fastest</option>
</select>
</div>
<div id="drawArea" style="width:100%; height:100%;">
</div>
</div>
</div>
<script>
var piedata = [100, 100, 100, 100, 100, 100, 100];
var svg = Initialize('drawArea', 450, 250, 200, piedata);
StartStopGame();
</script>
</body>
</html>

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment