D3.js Force Layout - showing only part of a graph

ぐ巨炮叔叔 提交于 2019-12-02 01:12:43

I just uploaded a "proof of concept level" of an interactive force directed subgraph.

http://justdharma.com/d3/sub-graph/

In this example I use backbonejs under the hood. Being the first time I implement something with backbonejs, I for sure use it in a very crude manner. While this example might illuminate one way how an interactive sub-graph can be achieved it is for sure not a template how to do it - as said just a proof of concept hack ...

This isn't implemented in D3, and I'm not aware of any examples. What you would have to do is the following:

  • Set the fixed attribute of the new center node to true to prevent the force layout from changing its position.
  • Set the px and py attributes of that same node to the center position.
  • For each node in your force layout, compute the shortest path to the new center node.
  • Depending on the length of the path in each case, either remove the node or keep it.

The trickiest part here is the computation of the path from each node to the new center, but even this is a pretty standard algorithmic problem. Another thing to keep in mind is that you need to modify the data structures that contain the nodes and links of the force layout in place, i.e. you can't set new nodes and links for the force layout and expect everything to work smoothly.

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!