// GNU Guix --- Functional package management for GNU // Copyright © 2016 Ricardo Wurmus // // This file is part of GNU Guix. // // GNU Guix is free software; you can redistribute it and/or modify it // under the terms of the GNU General Public License as published by // the Free Software Foundation; either version 3 of the License, or (at // your option) any later version. // // GNU Guix is distributed in the hope that it will be useful, but // WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with GNU Guix. If not, see . var outerRadius = Math.max(nodeArray.length * 15, 500) / 2, innerRadius = outerRadius - Math.min(nodeArray.length * 5, 200), width = outerRadius * 2, height = outerRadius * 2, colors = d3.scale.category20c(), matrix = []; function neig
aboutsummaryrefslogtreecommitdiff
MinYMin') .call(zoom); var zoomer = svg.append("g"); var container = zoomer.append("g") .attr("transform", "translate(" + outerRadius + "," + outerRadius + ")"); // Group for arcs and labels var g = container.selectAll(".group") .data(chord.groups) .enter().append("g") .attr("class", "group") .on("mouseout", fade(1, container)) .on("mouseover", fade(0.1, container)); // Draw one segment per package g.append("path") .style("fill", function (d) { return colors(d.index); }) .style("stroke", function (d) { return colors(d.index); }) .attr("d", arc); // Add circular labels g.append("text") .each(function (d) { d.angle = (d.startAngle + d.endAngle) / 2; }) .attr("dy", ".35em") .attr("transform", function (d) { return "rotate(" + (d.angle * 180 / Math.PI - 90) + ")" + "translate(" + (innerRadius + 26) + ")" + (d.angle > Math.PI ? "rotate(180)" : ""); }) .style("text-anchor", function (d) { return d.angle > Math.PI ? "end" : null; }) .text(function (d) { return nodeArray[d.index].label; }); // Draw chords from source to target; color by source. container.selectAll(".chord") .data(chord.chords) .enter().append("path") .attr("class", "chord") .style("stroke", function (d) { return d3.rgb(colors(d.source.index)).darker(); }) .style("fill", function (d) { return colors(d.source.index); }) .attr("d", d3.svg.chord().radius(innerRadius));
AgeCommit message (Expand)Author