d3.js 中的自定义布局?

Custom layout in d3.js?

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

任何链接或示例都会有所帮助

我不想使用 d3 的标准布局,想自己编写。

布局函数可以是一个简单的函数,它将坐标(以及绘图的任何附加数据,如 startAngle、endAngle 等)分配给您的数据,然后 return 一个数组用于列表节点。一个简单的例子:

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 自己的代码结构,布局将 return 一个与上面相同的功能,但有额外的功能来配置它:

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);
...