小编iAM*_*ent的帖子

动态添加节点到 Cytoscape

我的公司正在为聊天机器人构建一个图形视图编辑器。我们正在使用 Cytoscape 和cytoscape-cola扩展来实现这一点。我们面临的问题之一是动态地向图中添加新节点,而不会将它们与图上的现有节点重叠。

我已经查看了以前的类似问题(如下所列),但无济于事:

Cytoscape - 处理锁定的节点

我在那里尝试了解决方案,即仅在新添加的节点上应用布局,但它们一直堆积在屏幕中央。

Cytoscape - 忽略锁定的节点

我尝试了此处提到的解决方案,但无论是一次性锁定节点还是cy.nodes().lock()单独cy.nodes().forEach(node => node.lock())锁定节点,锁定节点仍会继续移动。这里要注意的另一个有趣的事情是,当单独锁定节点时,无论我是否在上面的调用中锁定,新添加的节点也会被锁定。

Cytoscape - 动态添加节点而不移动其他节点

我也尝试过这个解决方案,但锁定的节点仍然会移动,并且整个布局发生了变化——有时完全改变,有时只是一点点。

代码

这是我目前用来构建图表的内容:

const layoutConfig = {
    name: "cola",
    handleDisconnected: true,
    animate: true,
    avoidOverlap: true,
    infinite: false,
    unconstrIter: 1,
    userConstIter: 0,
    allConstIter: 1,
    ready: e => {
        e.cy.fit()
        e.cy.center()
    }
}
this.graph = Cytoscape({ ... })

this.layout = this.grapg.makeLayout(layoutConfig)

this.layout.run();
Run Code Online (Sandbox Code Playgroud)

这是我用来向图中添加新节点的内容:

const addElements = (elements: ElementSingular | ElementMultiple) => {
    this.graph.nodes().forEach(node => {
        node.lock();
    })

    this.graph.add(elements)

    this.layout …
Run Code Online (Sandbox Code Playgroud)

javascript cytoscape.js webcola

6
推荐指数
1
解决办法
624
查看次数

标签 统计

cytoscape.js ×1

javascript ×1

webcola ×1