antvis/G6

The issue has been closed
dagre布局,combo内多个节点的间距和设置的nodesep不一致 #4265
LiXinS319070033 posted onGitHub
问题描述
画布中先展示左侧的combo(亮绿色),通过某个触发机制,画布中添加了右侧的combo(蓝紫色),但右侧combo中的节点的间距明显比layout中设置的nodesep大很多,请问右侧combo内的节点间距怎么和和左侧combo的节点间距保持一致?万分感谢
重现链接
https://g6.antv.antgroup.com/examples/net/dagreFlow/#dagreCombo
重现步骤
无
预期行为
右侧combo内的节点间距和左侧combo的节点间距保持一致
平台
- 操作系统: [macOS, Windows, Linux, React Native ...]
- 网页浏览器: [Google Chrome, Safari, Firefox]
- G6 版本: [4.5.1 ... ]
屏幕截图或视频(可选)
补充说明(可选)
import G6 from '@antv/g6';
const data = {
nodes: [
{
id: '0',
label: '0',
},
{
id: '1',
label: '1',
},
{
id: '2',
label: '2',
},
{
id: '3',
label: '3',
},
{
id: '4',
label: '4',
comboId: 'A',
},
{
id: '5',
label: '5',
comboId: 'B',
},
{
id: '6',
label: '6',
comboId: 'A',
},
{
id: '7',
label: '7',
comboId: 'C',
},
{
id: '8',
label: '8',
comboId: 'C',
},
{
id: '9',
label: '9',
comboId: 'A',
},
{
id: '10',
label: '10',
comboId: 'B',
},
{
id: '11',
label: '11',
comboId: 'B',
},
{
id: '12',
label: '12',
comboId: 'D',
},
{
id: '13',
label: '13',
comboId: 'D',
},
],
edges: [
{
source: '0',
target: '1',
},
{
source: '0',
target: '2',
},
{
source: '1',
target: 'A',
},
{
source: '0',
target: '3',
},
{
source: '2',
target: 'B',
}, {
source: '3',
target: 'C',
}, {
source: '9',
target: 'D',
}, {
source: '7',
target: 'D',
}
],
combos: [
{
id: 'A',
label: 'combo A',
style: {
fill: '#C4E3B2',
stroke: '#C4E3B2',
},
},
{
id: 'B',
label: 'combo B',
style: {
stroke: '#99C0ED',
fill: '#99C0ED',
},
},
{
id: 'C',
label: 'combo C',
style: {
stroke: '#eee',
fill: '#eee',
},
}, {
id: 'D',
label: 'combo D',
style: {
stroke: '#eee',
fill: '#eee',
},
},
],
};
data.nodes.forEach((node) => {
switch (node.ComboId) {
case 'A':
node.style = {
fill: '#C4E3B2',
stroke: '#aaa',
};
break;
case 'B':
node.style = {
fill: '#99C0ED',
stroke: '#aaa',
};
break;
case 'C':
node.style = {
fill: '#eee',
stroke: '#aaa',
};
break;
default:
node.style = {
fill: '#FDE1CE',
stroke: '#aaa',
};
break;
}
});
let sortByCombo = false;
const descriptionDiv = document.createElement('button');
descriptionDiv.innerHTML = 'Enable sortByCombo';
const container = document.getElementById('container');
container.appendChild(descriptionDiv);
descriptionDiv.addEventListener('click', (e) => {
sortByCombo = !sortByCombo;
descriptionDiv.innerHTML = sortByCombo ? 'Disable sortByCombo' : 'Enable sortByCombo';
graph.updateLayout({
sortByCombo,
});
});
const width = container.scrollWidth;
const height = (container.scrollHeight || 500) - 30;
const graph = new G6.Graph({
container: 'container',
width,
height: height - 50,
fitView: true,
fitViewPadding: 30,
animate: true,
groupByTypes: false,
modes: {
default: [
'drag-combo',
'drag-node',
'drag-canvas',
{
type: 'collapse-expand-combo',
relayout: false,
},
],
},
layout: {
type: 'dagre',
rankdir: "LR",
sortByCombo: true,
ranksep: 20,
nodesep: 1,
},
defaultNode: {
size: [60, 30],
type: 'rect',
// anchorPoints: [[0.5, 0], [0.5, 1]]
},
defaultEdge: {
type: 'line',
},
defaultCombo: {
type: 'rect',
style: {
fillOpacity: 0.1,
fixSize: 20
},
},
});
graph.data(data);
graph.render();
console.log('comboTrees', graph.get('comboTrees'))
if (typeof window !== 'undefined')
window.onresize = () => {
if (!graph || graph.get('destroyed')) return;
if (!container || !container.scrollWidth || !container.scrollHeight) return;
graph.changeSize(container.scrollWidth, container.scrollHeight - 30);
};