gpt4 book ai didi

javascript - 如何防止图表的nodeDataArray更新后所有组件的位置发生变化?

转载 作者:行者123 更新时间:2023-12-03 05:42:14 24 4
gpt4 key购买 nike

我有这个图表:

var $ = go.GraphObject.make;
var diagram = $(go.Diagram, element[0], {
initialContentAlignment: go.Spot.TopCenter,
initialScale: 1,
layout: $(go.LayeredDigraphLayout, { direction: 0 }),
isReadOnly: false,
allowLink: true,
allowClipboard: false,
animationManager.duration: 200,
undoManager.isEnabled: false
});

我创建了几个简单的元素,并使用 addNodeDataCollection 方法将它们添加到图表模型中。然后我更改元素的位置,并向 nodeDataArray 添加一个元素。我希望添加新元素后旧项目的位置不会改变,但事实并非如此。所有项目的位置均已更改,并且所有元素均中心对齐。这是正确的行为吗?我没有找到如何防止在 nodeDataArray 中添加新项目后重新计算位置。

最佳答案

通常,当您添加或删除节点或链接时,会重新进行布局。在这种情况下,您的 Diagram.layout 将再次发生,将手动调整的节点位置移回布局认为应有的位置。请阅读http://gojs.net/latest/intro/layouts.html了解更多详细信息,尤其是有关“布局无效”的部分。

就您而言,我不确定您真正想要完成什么。在您的 LayeredDigraphLayout 实例上将 Layout.isOngoing 设置为 false 可能就足够了。

关于javascript - 如何防止图表的nodeDataArray更新后所有组件的位置发生变化?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40482349/

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