gpt4 book ai didi

javascript - 为什么我的嵌入式 JointJS 元素重叠?

转载 作者:搜寻专家 更新时间:2023-11-01 04:40:23 27 4
gpt4 key购买 nike

我正在处理 JointJS 图,使用 DirectedGraph 来处理布局,我正在尝试实现类似于下图的效果。我需要将节点(A、B、C、D、E、F、G、H、I、J)“勾勒出轮廓”或包含在单独的节点(Foo、Bar、Hmm)中。当我将所有元素添加到图中时,所有元素都在彼此之上。但是,如果我不在区域之间添加顶点,所有元素都会正确布局,但没有连接区域的顶点。

根据下面的代码,我做错了什么?节点(A、B、C、D、E、F、G、H、I、J)是否因为未连接到图的其余部分而导致错误?

非常感谢您提供任何反馈。

enter image description here

var graph = new joint.dia.Graph;
var paper = new joint.dia.Paper({
el: $('#paper');
width: 2000,
height: 2000,
gridSize: 1,
model: graph
});

var regions = [ makeRegion('Foo'), makeRegion('Bar'), makeRegion('Hmm')];
var nodes = [
makeNode('A'),
makeNode('B'),
makeNode('C'),
makeNode('D'),
makeNode('F'),
makeNode('G'),
makeNode('H'),
makeNode('I'),
makeNode('J'),
];
regions[0].embed(nodes[0]).embed(nodes[1]).embed(nodes[2]);
regions[1].embed(nodes[3]).embed(nodes[4]).embed(nodes[5]);
regions[2].embed(nodes[6]).embed(nodes[7]).embed(nodes[8]);
var vertices = [
connect(regions[0], regions[1]),
connect(regions[1], regions[2]),
connect(regions[2], regions[0])
];
paper.addCells(regions.concat(nodes).concat(vertices));
joint.layout.DirectedGraph.layout(paper, {
rankDir: 'LR',
marginX: 30,
marginY: 30,
clusterPadding: {
top: 30,
left: 10,
right: 10,
bottom: 10
}
});

function makeNode(name) {
return new joint.shapes.basic.Rect({
size: {
width: 35,
height: 35
},
attrs: {
text: {
text: name
}
}
});
}

function connect(a, b) {
return new joint.shapes.fsa.Arrow({
source: { id: a.id },
target: { id: b.id }
});
}

function makeRegion(name) {
return new joint.shapes.basic.Rect({
size: {
width: 300,
height: 200
},
attrs: {
text: {
text: name
}
}
});
}

编辑:

虽然我从来没有找到解决这个问题的好方法,但我确实发现通过一些额外的工作,这是可以实现的。它假定您的图形不太复杂,区域之间的边很少。

如果我单独添加边,在所有节点都添加到图中后,它就可以正常工作。然而,定向布局并没有完全按预期工作。我最初使用 joint.layout.DirectedGraph.layout() 以便对齐内部节点,然后我重新定位外部区域。最后我添加了边缘,产生了与上图类似的结果。

以下是我如何实现这一目标的粗略概述:

var graph = new joint.dia.Graph;
var paper = new joint.dia.Paper({
el: $('#paper');
width: 2000,
height: 2000,
gridSize: 1,
model: graph
});

var regions = [ makeRegion('Foo'), makeRegion('Bar'), makeRegion('Hmm')];
var nodes = [
makeNode('A'),
makeNode('B'),
makeNode('C'),
makeNode('D'),
makeNode('F'),
makeNode('G'),
makeNode('H'),
makeNode('I'),
makeNode('J'),
];
regions[0].embed(nodes[0]).embed(nodes[1]).embed(nodes[2]);
regions[1].embed(nodes[3]).embed(nodes[4]).embed(nodes[5]);
regions[2].embed(nodes[6]).embed(nodes[7]).embed(nodes[8]);

paper.addCells(regions.concat(nodes));
joint.layout.DirectedGraph.layout(paper, {
rankDir: 'LR',
marginX: 30,
marginY: 30,
clusterPadding: {
top: 30,
left: 10,
right: 10,
bottom: 10
}
});

var vertices = [
connect(regions[0], regions[1]),
connect(regions[1], regions[2]),
connect(regions[2], regions[0])
];
repositionRegions();
// Add the edges after all the nodes are in their final position
graph.addCells(vertices);

function repositionRegions() {
// Move regions to where you want them
}

function makeNode(name) {
return new joint.shapes.basic.Rect({
size: {
width: 35,
height: 35
},
attrs: {
text: {
text: name
}
}
});
}

function connect(a, b) {
return new joint.shapes.fsa.Arrow({
source: { id: a.id },
target: { id: b.id }
});
}

function makeRegion(name) {
return new joint.shapes.basic.Rect({
size: {
width: 300,
height: 200
},
attrs: {
text: {
text: name
}
}
});
}

最佳答案

这是 Dagre-D3 的一个已知问题:Automatic layout does not work on hierarchical diagrams with links with parent .

作为解决方法,您可以省略区域之间的链接(在您的问题版本中建议),或者您可以做一些额外的工作,这些工作将很好地适用于任意数量的节点:

  1. 分别布局每组子节点:

    var fooChildren = [nodes[0], nodes[1], nodes[2]];
    var barChildren = [nodes[3], nodes[4], nodes[5]];
    var hmmChildren = [nodes[6], nodes[7], nodes[8]];
    var children = [fooChildren, barChildren, hmmChildren];

    for(var i = 0; i < children.length; i++)
    joint.layout.DirectedGraph.layout(children[i]);
  2. 为每个区域创建一个辅助克隆区域。

    var clones = [];
    for(var i = 0; i < regions.length; i++) {
    var clone = regions[i].clone();
    graph.addCell(clone);
    clones.push(clone);
    }
  3. 将相应的节点设置为它们的克隆区域。

    for(var i = 0; i < children.length; i ++)
    for(var k = 0; k < children[i].length; k++)
    clones[i].embed(children[i][k]);
  4. 使每个克隆区域适合其子区域的大小,并使用克隆区域的大小调整原始区域的大小。

    for(var i = 0; i < clones.length; i++) {
    clones[i].fitEmbeds(padding: { top: 30, left: 10, right: 10, bottom: 10 });
    regions[i].resize(clones[i].getBBox().width, clones[i].getBBox().height);
    }
  5. 布局图表。

    joint.layout.DirectedGraph.layout(graph, {
    rankDir: 'LR',
    marginX: 30,
    marginY: 30,
    clusterPadding: {
    top: 30,
    left: 10,
    right: 10,
    bottom: 10
    }
    });
  6. 将克隆的区域平移到其原始区域的位置(子区域将相应地平移)。

    for(var i = 0; i < clones.length; i++) {
    var dx = regions[i].getBBox().x - clones[i].getBBox().x;
    var dy = regions[i].getBBox().y - clones[i].getBBox().y;
    clones[i].translate(dx, dy);
    }
  7. 删除克隆区域并将子区域设置为原始区域。

    for(var i = 0; i < regions.length; i++) {
    clones[i].remove();

    for(var j = 0; j < children[i].length; j++)
    regions[i].embed(children[i][j]);
    }

希望这可以帮助提供替代解决方案。

关于javascript - 为什么我的嵌入式 JointJS 元素重叠?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36314398/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com