gpt4 book ai didi

javascript - 添加文本标签以强制 d3.js 中的定向图链接

转载 作者:行者123 更新时间:2023-11-28 19:21:17 25 4
gpt4 key购买 nike

我在向连接以下 D3JS 连接节点图中的节点的链接添加文本时遇到问题:http://jsfiddle.net/rqa0nvv2/1/

有人可以向我解释一下添加它们的过程是什么吗?

  var link = svg.selectAll(".link")
.data(links)
.enter().append("line")
.attr("class", function(d) { if(d.value == "visible") {return "link";} else return "" })
.style("stroke-width", function(d) { return Math.sqrt(d.stroke); });

link.append("svg:title").text(function(d) { return "Unit: " + ", Formula: ";});

谢谢!

最佳答案

只需进行一些更改即可将文本附加到边缘。

首先,您当前方法的问题是您正在推 <text>里面<line> 。这在 SVG 中无法完成,因此您需要创建一个 <g> (组)包含行和文本:

var link = svg.selectAll(".link")
.data(links)
.enter()
.append("g")
.attr("class", "link-group")
.append("line")
.attr("class", function(d) { return d.value == "visible" ? "link" : ""; })
.style("stroke-width", function(d) { return Math.sqrt(d.stroke); });

好吧,仅仅添加这个不会在视觉上改变任何东西,但它确实创建了我们需要的组。所以我们需要添加如下文本:

var linkText = svg.selectAll(".link-group")
.append("text")
.data(force.links())
.text(function(d) { return d.value == "visible" ? "edge" : ""; })
.attr("x", function(d) { return (d.source.x + (d.target.x - d.source.x) * 0.5); })
.attr("y", function(d) { return (d.source.y + (d.target.y - d.source.y) * 0.5); })
.attr("dy", ".25em")
.attr("text-anchor", "middle");

这将添加文本并对其进行初始定位。请随意(请!)设置文本样式并根据您想要的外观更改内容。最后,我们需要让它随着力导向图移动:

force.on("tick", function() {
link
.attr("x1", function(d) { return d.source.x; })
.attr("y1", function(d) { return d.source.y; })
.attr("x2", function(d) { return d.target.x; })
.attr("y2", function(d) { return d.target.y; });

node
.attr("cx", function(d) { return d.x; })
.attr("cy", function(d) { return d.y; });

linkText
.attr("x", function(d) { return (d.source.x + (d.target.x - d.source.x) * 0.5); })
.attr("y", function(d) { return (d.source.y + (d.target.y - d.source.y) * 0.5); });
});

这当然很简单,因为它与我们已经做过的事情相同!

关于javascript - 添加文本标签以强制 d3.js 中的定向图链接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28847443/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com