この例を変更すると、https://bl.ocks.org/mbostock/1667139は行の代わりにパスを使用しますが、動作しません。 イムは、このように自分のダニの機能を使用してみてください。D3.jsスタティックフォースレイアウトがパスで動作しませんか?
function tick() {
link.attr("d", function(d) {
var x1 = d.source.x,
y1 = d.source.y,
x2 = d.target.x,
y2 = d.target.y,
dx = x2 - x1,
dy = y2 - y1,
dr = Math.sqrt(dx * dx + dy * dy),
// z uzla do ineho uzla
drx = dr,
dry = dr,
xRotation = 0,
largeArc = 0,
sweep = 1;
//do sameho seba
if (x1 === x2 && y1 === y2) {
xRotation = -45;
largeArc = 1;
drx = 30;
dry = 30;
x2 = x2 + 1;
y2 = y2 + 1;
}
return "M" + x1 + "," + y1 + "A" + drx + "," + dry + " " + xRotation + "," + largeArc + "," + sweep + " " + x2 + "," + y2;
});
}
私はちょうどカント使用パス何かまたは静的な力のレイアウトを欠落している場合は、知りません。パスは、docs(太字鉱山)からnormaly
Rex thx、can私はもう一つあなたに尋ねますか?どのサークルにテキストを追加するのですか?静的ではない静的なレイアウトは、単にvar circle.append( "g")を作成してからappend( "circle")を追加してテキストを追加しますが、ここでは機能しません。私の試行はhttps://jsfiddle.net/f7e20crm/です。そのテキストは、円とテキスト要素の場合、g要素の一部ではない別の要素です。 – Martin
@Martin、更新の回答を参照してください。そして更新されたフィドル[ここ](https://jsfiddle.net/f7e20crm/6/)。 – Mark