Zastanawiasz się, czy można zrobić coś takiego z d3?Wykres kołowy D3.js ... czy można przesuwać wycinek koła po wybraniu?
Jeżeli po kliknięciu na pewien wycinek ruchy plaster na kliknięcie?
Mają ciasto stworzone do tej pory po prostu zastanawiasz się, czy mogę dodać tę funkcję
<!DOCTYPE html>
<meta charset="utf-8">
<style>
body {
font: 10px sans-serif;
}
.arc path {
stroke: #fff;
}
</style>
<body>
<script src="http://d3js.org/d3.v3.min.js"></script>
<script>
var width = 960,
height = 500,
radius = Math.min(width, height)/2;
var color = d3.scale.ordinal()
.range(["#98abc5", "#8a89a6", "#7b6888", "#6b486b", "#a05d56", "#d0743c", "#ff8c00"]);
var arc = d3.svg.arc()
.outerRadius(radius - 10)
.innerRadius(0);
var pie = d3.layout.pie()
.sort(null)
.value(function(d) { return d.population; });
var svg = d3.select("body").append("svg")
.attr("width", width)
.attr("height", height)
.append("g")
.attr("transform", "translate(" + width/2 + "," + height/2 + ")");
d3.csv("data.csv", function(error, data) {
data.forEach(function(d) {
d.population = +d.population;
});
var g = svg.selectAll(".arc")
.data(pie(data))
.enter().append("g")
.attr("class", "arc");
g.append("path")
.attr("d", arc)
.style("fill", function(d) { return color(d.data.age); });
g.append("text")
.attr("transform", function(d) { return "translate(" + arc.centroid(d) + ")"; })
.attr("dy", ".35em")
.style("text-anchor", "middle")
.text(function(d) { return d.data.age; });
});
</script>
danych pochodzi z pliku csv.
Dzięki
Dzięki, dokładnie to, co chciałem – jayfah
@Gilsha może być w stanie mi pomóc z bardzo podobnym pytaniem http://stackoverflow.com/questions/37031238/using-d3-js-to-modify-c3 -js-chart – user1010101