对于每个 json,创建一个圆圈并随机输出 x 和 y
for(var d = 0; d<json.length; d++){
circlexloc[d] = ((Math.random()*2*r)-r);
circleyloc[d] = ((Math.random()*2*r)-r);
};
声明一个圆形变量,同时设置属性和动画
var circle = svg.selectAll("circle").data(json)
circle.enter().append('circle')
动画片
circle.transition()
.duration(1000)
.attr("fill", "blue")
.attr('opacity',0.6)
.attr('r', 5)
.attr("cx", function(d, i) {return circlexloc[i] })
.attr("cy", function(d, i) {return circleyloc[i] });
circle.exit().transition().duration(1000)
.attr('opacity',0)
.attr("r",0)
.remove();
将技术附加到圈子中
var text = svg.selectAll('text')
text.data(json)
.enter().append("svg:text")
.style("font-size", "10px")
.text(function(d) { return d.TechName; })
.transition().duration(1000)
.attr('opacity', 1)
.attr("x", function (d, i) { return (circlexloc[i]+6)})
.attr("y", function (d, i) { return (circleyloc[i]+4)});
});
目前,有时它们往往会相互重叠。我怎样才能防止这种情况?建议和示例将不胜感激 - 谢谢。