Cytoscape.js 布局边长

Cytoscape.js layout edge length

您好,我正在尝试为学校项目构建网络爬虫可视化工具。我决定使用 Cytoscape.js 并且使用起来非常好。我遇到的问题是某些布局(圆形、广度优先、同心)的边长看起来太大并且图形看起来很奇怪。

当我第一次启动该应用程序时,我手动制作并加载了一个具有 100 个节点的图形(它是一棵树),在圆形布局中看起来不错:

然而,在我执行网络抓取之后,新图(这个有 44 个节点)不适合圆的视图:

有没有办法让它工作,使边不那么长,节点看起来更大?

编辑:

这是我用来更改布局的代码:

changeLayout = function(layoutName, title,  root){
                var numOfNodes = cy.filter('node').length;
                //extent changes when I repeatedly change the layout to circle, (don't understand this behavior)
                var extent = cy.extent();
                var rect = document.getElementById("cy-container").getBoundingClientRect();

                var x1 = rect.left;
                var x2 = rect.right;
                var y1 = rect.top;
                var y2 = rect.bottom;

                var height = (y2 - y1);
                var width = (x2 - x1);

                var fact = (height < width) ? (height/numOfNodes) : (width/numOfNodes);
                fact *= 5;
                var myRadius = height < width ? (height-fact) : (width-fact);

                switch(layoutName){
                        case 'circle':
                                myLayout = cy.makeLayout(
                                {       name: layoutName,
                                        radius: myRadius,
                                        boundingBox: {x1: x1, x2: x2, y1: y1, y2: y2},
                                        fit: true,
                                        avoidOverlap: false
                                });
                                break;
                        case 'concentric':
                                myLayout = cy.makeLayout(
                                {       name: layoutName,
                                        height: height,
                                        width: width,
                                        fit: false,
                                        avoidOverlap: true
                                });
                                break;
                        case 'breadthfirst':
                                myLayout = cy.makeLayout(
                                {       name: layoutName,
                                        boundingBox: {x1: x1, x2: x2, y1: y1, y2: y2},
                                        fit: true,
                                        roots: root,
                                        avoidOverlap: false
                                });
                                break;
                        default :
                                myLayout = cy.makeLayout(
                                {
                                        name: layoutName
                                });
                }

                myLayout.run();
                $('#graphTitle').text(title + " Layout");
        };

边的长度是节点位置的函数。布局设置位置,因此您必须设置布局选项以使节点靠得更近。

对于力导向(物理模拟)布局,您可以调整力。在其他布局中,您可以调整间距值或强制使用边界框来影响节点的分布方式。