1

D3のクラスターデンドグラムの例に非常によく似たツリー構造のレンダリングに取り組んでいます。

親ノードが右側に、子が左側になるように、グラフを水平方向に反転する必要があります。ラベルのテキストを反転することはできません。どのD3メソッドがこれに関与していますか?

例のコード:

var width = 960,
height = 2200;

var cluster = d3.layout.cluster()
    .size([height, width - 160]);

var diagonal = d3.svg.diagonal()
    .projection(function(d) { return [d.y, d.x]; });

var svg = d3.select("body").append("svg")
    .attr("width", width)
    .attr("height", height)
  .append("g")
    .attr("transform", "translate(40,0)");

d3.json("flare.json", function(error, root) {
    var nodes = cluster.nodes(root),
        links = cluster.links(nodes);

    var link = svg.selectAll(".link")
        .data(links)
      .enter().append("path")
        .attr("class", "link")
        .attr("d", diagonal);

    var node = svg.selectAll(".node")
        .data(nodes)
      .enter().append("g")
        .attr("class", "node")
        .attr("transform", function(d) { return "translate(" + d.y + "," + d.x + ")"; })

    node.append("circle")
        .attr("r", 4.5);

    node.append("text")
        .attr("dx", function(d) { return d.children ? -8 : 8; })
        .attr("dy", 3)
        .style("text-anchor", function(d) { return d.children ? "end" : "start"; })
        .text(function(d) { return d.name; });
});
4

1 に答える 1

1

この場合、座標はクラスターレイアウトから取得されます。レイアウトを変更するか、コードで.xレイアウトの幅から差し引くことができますwidth - 160text-anchor属性値を調整することもできます。

于 2012-11-14T17:54:49.667 に答える