我看到了D3.js的例子 - Voronoi Tessellation。但我想在每个多边形中放一些文字而不是圆圈,这是我的js代码:
var width = 600, height = 400;
var vertices = d3.range(20).map(function(d){
return [Math.random() * width, Math.random() * height]
});
var voronoi = d3.geom.voronoi();
var svg = d3.select("body").append("svg")
.attr("width", width)
.attr("height", height);
path = svg.append("g").selectAll("path");
svg.selectAll("info")
.data(vertices.slice(1))
.enter().append("text")
.attr("transform", function(d) {
return "translate(" + d + ")";
})
.text("someText")
.attr("shape-rendering","crispEdges")
.style("text-anchor","middle");
redraw();
function redraw(){
path = path
.data(voronoi(vertices), polygon);
path.exit().remove();
path.enter().append("path")
.attr("class", function(d, i) {return "q" + (i % 9) + "-9";})
.attr("d", polygon);
path.order();
}
function polygon(d){
return "M" + d.join("L") + "Z";
}
我在这里有一个基本示例的JSFiddle: my voronoi code
现在,我希望每个多边形的文本位于多边形的中心,并且不要与多边形的边界交叉。如果多边形没有足够的空间来包含所有文本,只需包含它的第一部分! 请告诉我,如果有什么办法可以解决这个问题,谢谢!
PS:我对我的英语很抱歉,是的,它太可怕了! :)答案 0 :(得分:4)
看一下这个例子http://bl.ocks.org/mbostock/6909318,您可能希望将文本放在多边形质心处,而不是用于确定voronoi曲面细分的种子(点)。
这应该可以解决大多数布局问题。
自动缩放文本以适应更难一点,如果您愿意缩放和旋转文本,您可以使用类似于以下的技术来确定该点的行长度:
https://mathoverflow.net/questions/116418/find-longest-segment-through-centroid-of-2d-convex-polygon
然后你需要确定线的角度。我有一个应该有帮助的插件: http://bl.ocks.org/stephen101/7640188/3ffe0c5dbb040f785b91687640a893bae07e36c3
最后,您需要缩放和旋转文字以适应。要确定文本的宽度,请在文本元素上使用getBBox():
var text = svg.append("svg:text")
.attr("x", 480)
.attr("y", 250)
.attr("dy", ".35em")
.attr("text-anchor", "middle")
.style("font", "300 128px Helvetica Neue")
.text("Hello, getBBox!");
var bbox = text.node().getBBox();
然后使用您之前计算的角度来缩放和旋转文本:
text.attr("transform", "rotate(40) scale(7)")
我想提供一个完整的例子,但要做到这一点,这是相当多的工作。
还有其他选项可以达到相同的效果,但没有一个是简单的(即你可以退回布局,类似于d3对Sankey布局的方式)