最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - How do I tell D3 to make the dendrogram vertical (top down) instead of left to right? - Stack Overflow

programmeradmin0浏览0评论

I'm looking at this example that uses cluster layout to assign the X and Y coordinates to nodes on a dendrogram. How can I tell cluster to layout vertically, top down, instead of the default left to right?

I'm looking at this example that uses cluster layout to assign the X and Y coordinates to nodes on a dendrogram. How can I tell cluster to layout vertically, top down, instead of the default left to right?

Share Improve this question edited Jul 22, 2012 at 0:01 Brant Olsen 5,6645 gold badges39 silver badges53 bronze badges asked Jul 14, 2012 at 1:12 joshuapoehlsjoshuapoehls 35.4k11 gold badges53 silver badges61 bronze badges
Add a ment  | 

1 Answer 1

Reset to default 12

For the example you link, just flip the use of the X and Y coordinates. This can be done by changing

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

and

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

to

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

and

var node = vis.selectAll("g.node")
   .data(nodes)
 .enter().append("g")
  .attr("class", "node")
  // Flip the values here.
  .attr("transform", function(d) { return "translate(" + d.x + "," + d.y + ")"; })

Here is a JSFiddle showing the above changes in action.

与本文相关的文章

发布评论

评论列表(0)

  1. 暂无评论