如何在d3.js中创建自定义布局?
任何链接或示例都有帮助
我不想要d3使用的标准版面,想写我自己的。
答案 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);
...