d3.js中的自定义布局?

时间:2015-02-13 08:51:29

标签: layout d3.js

如何在d3.js中创建自定义布局?

任何链接或示例都有帮助

我不想要d3使用的标准版面,想写我自己的。

1 个答案:

答案 0 :(得分:9)

布局函数可以是一个简单的函数,它为您的数据分配坐标(以及绘图的任何其他数据,如startAngle,endAngle,...),然后返回节点列表的数组。一个简单的例子:

function myLayout(data) {
   var nodes = [];   // or reuse data directly depending on layout
   // for each element of data, assign a x,y coordinate)
   return nodes;
}

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

这是基本的裸骨方法。如果你想遵循d3自己的代码结构,布局会返回一个与上面相同的函数,但是还有其他功能来配置它:

function myLayout() {
   var space = 1;
   function compute(data) {
       // same as before
   }
   compute.space = function(s) {
       if (!arguments.length) return space;
       space = s;
       return this;   // chaining
   }
   return compute;
}
var layout = myLayout().space(10);
var nodes = layout(myData);
...