javascript - How to make the distance from nodes in d3.js force layout larger? -


i trying represent data d3js force layout. have following code:

<script>  var svg = d3.select("svg"),       width = +svg.attr("width"),       height = +svg.attr("height");  var color = d3.scaleordinal(d3.schemecategory20);   var simulation = d3.forcesimulation()       .force("link", d3.forcelink().id(function(d) { return d.id; }))       .force("charge", d3.forcemanybody())       .force("center", d3.forcecenter(width / 2, height / 2));   var jsondata = json.parse(data);  var totalamount=jsondata.total;  d3.json("mydata.json", function(error, graph) {  if (error) throw error;  var nodes = json.nodes;  var link = svg.append("g")         .attr("class", "links")         .selectall("line")         .data(graph.links)         .enter().append("line")         //.attr("stroke-width", function(d) { return math.sqrt(d.value); });         .attr("stroke-width",4)  var node = svg.append("g")         .attr("class", "nodes")         .selectall("circle")         .data(graph.nodes)         .enter().append("circle")         .attr("r", 5)         .attr("fill", function(d) { return color(d.group); })         .call(d3.drag()                 .on("start", dragstarted)                 .on("drag", dragged)                 .on("end", dragended));  node.append("title")         .text(function(d) { return d.id; });  simulation         .nodes(graph.nodes)         .on("tick", ticked);  simulation.force("link")         .links(graph.links);  function ticked() {   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; });     }   });    function dragstarted(d) {      if (!d3.event.active) simulation.alphatarget(0.3).restart();      d.fx = d.x;       d.fy = d.y;   }     function dragged(d) {       d.fx = d3.event.x;       d.fy = d3.event.y;    }     function dragended(d) {       if (!d3.event.active) simulation.alphatarget(0);       d.fx = null;       d.fy = null;    } 

however, in output, nodes close each others in photo: my result

i checked links correct (basically have 1 source , many target nodes.)

how can make larger distance between nodes? help.

try this

simulation = d3.forcesimulation()         .force("link", d3.forcelink().distance(value).id(function(d) { return d.id; })) ... 

where value number


Comments

Popular posts from this blog

delphi - Disable and change color of node in Treeview -

unity3d - Rotate an object to face an opposite direction -

elasticsearch python client - work with many nodes - how to work with sniffer -