【问题标题】:D3.js Flip Graph HorizontallyD3.js 水平翻转图
【发布时间】:2012-11-03 06:05:36
【问题描述】:

我正在渲染一个与 D3 的Cluster Dendogram Example 非常相似的树结构。

我需要水平翻转图形,使父节点在右侧,子节点在左侧。标签上的文字不能翻转。哪些 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; });
});

【问题讨论】:

标签: javascript canvas d3.js


【解决方案1】:

在这种情况下,坐标来自集群布局。您可以修改布局或在代码中从布局宽度中减去.x,即width - 160。您可能还想调整text-anchor 属性值。

【讨论】:

  • 其实坐标并没有在 JSON 中编码。您可以在此处查看 JSON:bl.ocks.org/d/4063570/flare.json
  • 啊,你当然是对的。坐标来自布局。我已经编辑了答案——其余的仍然有效。
猜你喜欢
  • 1970-01-01
  • 2011-12-08
  • 1970-01-01
  • 2021-10-04
  • 1970-01-01
  • 2019-11-26
  • 2011-06-09
  • 1970-01-01
相关资源
最近更新 更多