2015-01-23 7 views
20

Come è possibile creare un grafico di base connesso (due nodi e un collegamento che li collega, ad esempio) che non utilizza un layout force()? Voglio solo essere in grado di trascinare un nodo e avere il collegamento regolare per rimanere connesso mentre un nodo viene trascinato. Non desidero nessuna delle funzionalità di carica o di posizionamento di force(). In sostanza, voglio che ogni nodo sia "appiccicoso". I nodi si sposteranno solo quando vengono trascinati.Grafico semplice di nodi e collegamenti senza utilizzare il layout della forza

Ma c'è un modo semplice per farlo? Ogni esempio che ho visto è costruito attorno a un grafico orientato alla forza.

Ho esaminato questo esempio, http://bl.ocks.org/mbostock/3750558, ma inizia con un grafico forzato e quindi rende i nodi appiccicosi. Questo approccio sembra al contrario per quello che voglio.

Esiste un esempio di base da qualche parte?

risposta

36

Ho creato un piccolo snippet di codice. Spero che questo sia utile.

var data = { 
 
    nodes: [{ 
 
    name: "A", 
 
    x: 200, 
 
    y: 150 
 
    }, { 
 
    name: "B", 
 
    x: 140, 
 
    y: 300 
 
    }, { 
 
    name: "C", 
 
    x: 300, 
 
    y: 300 
 
    }, { 
 
    name: "D", 
 
    x: 300, 
 
    y: 180 
 
    }], 
 
    links: [{ 
 
    source: 0, 
 
    target: 1 
 
    }, { 
 
    source: 1, 
 
    target: 2 
 
    }, { 
 
    source: 2, 
 
    target: 3 
 
    }, ] 
 
}; 
 

 
var c10 = d3.scale.category10(); 
 
var svg = d3.select("body") 
 
    .append("svg") 
 
    .attr("width", 1200) 
 
    .attr("height", 800); 
 

 
var drag = d3.behavior.drag() 
 
    .on("drag", function(d, i) { 
 
    d.x += d3.event.dx 
 
    d.y += d3.event.dy 
 
    d3.select(this).attr("cx", d.x).attr("cy", d.y); 
 
    links.each(function(l, li) { 
 
     if (l.source == i) { 
 
     d3.select(this).attr("x1", d.x).attr("y1", d.y); 
 
     } else if (l.target == i) { 
 
     d3.select(this).attr("x2", d.x).attr("y2", d.y); 
 
     } 
 
    }); 
 
    }); 
 

 
var links = svg.selectAll("link") 
 
    .data(data.links) 
 
    .enter() 
 
    .append("line") 
 
    .attr("class", "link") 
 
    .attr("x1", function(l) { 
 
    var sourceNode = data.nodes.filter(function(d, i) { 
 
     return i == l.source 
 
    })[0]; 
 
    d3.select(this).attr("y1", sourceNode.y); 
 
    return sourceNode.x 
 
    }) 
 
    .attr("x2", function(l) { 
 
    var targetNode = data.nodes.filter(function(d, i) { 
 
     return i == l.target 
 
    })[0]; 
 
    d3.select(this).attr("y2", targetNode.y); 
 
    return targetNode.x 
 
    }) 
 
    .attr("fill", "none") 
 
    .attr("stroke", "white"); 
 

 
var nodes = svg.selectAll("node") 
 
    .data(data.nodes) 
 
    .enter() 
 
    .append("circle") 
 
    .attr("class", "node") 
 
    .attr("cx", function(d) { 
 
    return d.x 
 
    }) 
 
    .attr("cy", function(d) { 
 
    return d.y 
 
    }) 
 
    .attr("r", 15) 
 
    .attr("fill", function(d, i) { 
 
    return c10(i); 
 
    }) 
 
    .call(drag);
svg { 
 
    background-color: grey; 
 
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.4.11/d3.min.js"></script>

+4

Tu sei un mago! –