Center force directed layout after tick using root node (return to center)

前端 未结 2 602
遥遥无期
遥遥无期 2021-01-05 18:27

I am experimenting with force directed layout using D3.js. What I need is center the layout by root (or other selected node) and return this node to the svg (e.g. canvas) ce

相关标签:
2条回答
  • 2021-01-05 19:12

    Actually I solved this like this(similar to previous but more sophisticated):

    force.on("tick", function(e) {
    
         node.attr("transform", function(d) { 
             //TODO move these constants to the header section
            //center the center (root) node when graph is cooling down
            if(d.index==0){
                damper = 0.1;
                d.x = d.x + (w/2 - d.x) * (damper + 0.71) * e.alpha;
                d.y = d.y + (h/2 - d.y) * (damper + 0.71) * e.alpha;
            }
            //start is initiated when importing nodes from XML
            if(d.start === true){
                d.x = w/2;
                d.y = h/2;
                d.start = false;
            }
    
            r = d.name.length;
            //these setting are used for bounding box, see [http://blockses.appspot.com/1129492][1]
            d.x = Math.max(r, Math.min(w - r, d.x));
            d.y = Math.max(r, Math.min(h - r, d.y));
    
                return "translate("+d.x+","+d.y+")";            
    
         }
        );
    
         });   
    
    0 讨论(0)
  • 2021-01-05 19:17

    Try to change the force event handler like this:

    force.on("tick", function(e) {
    nodes[0].x = w / 2;
    nodes[0].y = h / 2;
    
    var k = 0.05 * e.alpha;
              nodes.forEach(function(o, i) {
                o.y += (nodes[0].y - o.y) * k;
                o.x += (nodes[0].x - o.x) * k;
              });
    
    link.attr("x1", function(d) { return d.source.x; })
        .attr("y1", function(d) { return d.source.y; })
        .attr("x2", function(d) { return d.target.x; })
        .attr("y2", function(d) { return d.target.y; });
    
    node.attr("cx", function(d) { return d.x; })
        .attr("cy", function(d) { return d.y; });
     });
    
    0 讨论(0)
提交回复
热议问题