分为组织数据和绘图两部分:

原地址:http://www.ourd3js.com/wordpress/196/

1. 数据

初始数据如下:

节点(nodes)和连线(edges)的数组,节点是一些城市名,连线的两端是节点的序号(序号从 0 开始)。

这些数据是不能作图的,因为不知道节点和连线的坐标。这句话一说出来,就请想到布局。本章用到的布局是:d3.layout.force()

2. 布局(数据转换)

定义一个力导向图的布局如下。

然后,使力学作用生效:

如此,数组 nodes 和 edges 的数据都发生了变化。在控制台输出一下,看看发生了什么变化。

节点转换前后如下图。

d3.layout.force()---入门篇

转换后,节点对象里多了一些变量。其意义如下:

  • index:节点的索引号
  • px, py:节点上一个时刻的坐标
  • x, y:节点的当前坐标
  • weight:节点的权重

再来看看连线的变化。

d3.layout.force()---入门篇

 

可以看到,连线的两个节点序号,分别变成了对应的节点对象。

3. 绘制

有了转换后的数据,就可以作图了。分别绘制三种图形元素:

  • line,线段,表示连线。
  • circle,圆,表示节点。
  • text,文字,描述节点。

代码如下:

调用 call( force.drag ) 后节点可被拖动。force.drag() 是一个函数,将其作为 call() 的参数,相当于将当前选择的元素传到 force.drag() 函数中。

最后,还有一段最重要的代码。由于力导向图是不断运动的,每一时刻都在发生更新,因此,必须不断更新节点和连线的位置。

力导向图布局 force 有一个事件 tick,每进行到一个时刻,都要调用它,更新的内容就写在它的监听器里就好。

tick 的英文意思是钟表发出的嘀嗒嘀嗒声,想到这个大家应该很清楚了吧。每次触发时,都会调用后面的无名函数 function。

来看看最终效果图,用鼠标拖拽看看:

附件见:http://download.csdn.net/download/sdxushuxun/10194458  文件force2-1.html

相关文章:

  • 2021-12-30
  • 2022-12-23
  • 2022-12-23
  • 2021-11-05
  • 2021-12-22
  • 2022-01-02
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2021-09-25
  • 2022-12-23
  • 2022-12-23
  • 2021-11-20
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案