我的问题是如何创建一个网络可视化方案,使边缘和/或箭头终止在节点的边界。链接和箭头终止在D3节点的边界
我正在使用D3.js根据Curved Links基本模型绘制有向图,并添加了“标记”箭头,如other question中所述。我的可视化中的节点根据其属性改变其大小和不透明度。这引入了两个问题:(1)当节点改变尺寸时,箭头没有指向节点的边缘;(2)当边缘部分透明时,边缘的尾部通过节点出现。
对于第一个问题,有几个解决方案可用:this one声称可以正确地获得箭头偏移量,但它不会影响链接结束端点。也有解决方案here的建议,但我没有看到任何实际的完整工作代码。 This JS fiddle具有我想要的箭头形状,但代码是相当不透明的,而不是模块化的,我可以找出如何应用于我自己的情况。
正如我所说,我的链接是基于弯曲链接例子定义:
graph.links.forEach(function(link) {
var s = nodes[link.source],
t = nodes[link.target],
i = {}, // intermediate node
property1 = link.property1;
nodes.push(i);
links.push({source: s, target: i}, {source: i, target: t});
bilinks.push([s, i, t, property1]);
});
然后,如果我的D3是如何工作的松散的理解是基本正确的,链接被吸引通过下面的代码每个刻度:
force.on("tick", function() {
link.attr("d", function(d) {
if (d[0] == d[2]) {
return "M" + d[0].x + "," + d[0].y
+ "A" + "20,20 -50 1,1 " + (1.001 * d[2].x) + "," + (1.001 * d[2].y)
;
} else {
return "M" + d[0].x + "," + d[0].y
+ "S" + d[1].x + "," + d[1].y
+ " " + d[2].x + "," + d[2].y;
}
});
node.attr("transform", function(d) {
return "translate(" + d.x + "," + d.y + ")";
});
});
所以我的问题是,如何在达到通常期望的方式更改此代码(我认为正常)可视化方案使得边缘和/或箭头终止在节点的边界甚至他们改变大小。
我创建了一个JS Fiddle,其中包含查看和解决问题所需的所有位。它还包括调整箭头以匹配它们所在的链接,并且该功能需要与此问题的解决方案兼容。
我想,基本上,你需要计算节点和链接的外周之间的交点...动态。这对于直线是可以的,但对于花键路径,您需要计算控制点以获得正确的接近角度。听起来不像我有趣。 –
形状总是圆形的吗? – Ian
对于我而言,节点并不总是圆形的,但是如果我可以为圆形做它,那么我可以使用三角形和正方形或任何其他形状的边界圆。所以它不需要完全在边界上:稍微远离边界稍好一点。本质上,我只是想通过每一端节点的“大小”参数(而不是圆的“r”)来抵消链接的末端......并将箭头末端与链接的提示几乎齐平。 –