商会资讯

标题: 【 D3.js 进阶系列 — 2.0 】 力学图 + 人物关系图 [打印本页]

作者: admin    时间: 2016-10-10 18:03
标题: 【 D3.js 进阶系列 — 2.0 】 力学图 + 人物关系图
力学图(力导向图)与生活中常见的人物关系图结合,是比较有趣的。本文将以此为凭,阐述在力学图中如何插入外部图片和文字。
在【第 9.2 章】中制作了一个最简单的力学图。其后有很多朋友有疑问,主要的问题包括:
本文将对以上问题依次做出解说。其中前三点是 SVG 元素的问题,和 D3 无多大关联。
1. SVG 图片SVG 的图片元素的详细解说可看【官方文档-图片】。通常,我们只需要使用到图片元素的五个属性就够了。
[javascript] view plain copy


其中:
在 D3 中插入图片,代码形如:
[javascript] view plain copy


2. SVG 文本SVG 的文本元素和图片类似,详细属性见【官方文档-文本】。
[javascript] view plain copy


其中:
在 D3 中插入文本,代码形如:
[javascript] view plain copy


3. 源文件接下来制作力学图的源文件,本次将数据写入 JSON 文件中。
呵呵,借用一下【仙剑4】的人物,本人也是个仙剑迷,期待15年7月【仙剑6】的上市。
[html] view plain copy


如上,在 JSON 文件中添加数据,再将图片文件与 JSON 文件放于同一目录下即可(放哪都行,最主要是看程序中是如何实现的)。
4. 力学图4.1 读入文件读入 JSON 文件,这点应该很熟了吧。不然可以先看看【第 9.4 章】。
[javascript] view plain copy


4.2 定义力学图的布局力学图的 Layout(布局)如下:
[javascript] view plain copy


其中 linkDistance 是结点间的距离, charge 是定义结点间是吸引(值为正)还是互斥(值为负),值越大力越强。
4.3 绘制连接线绘制结点之间的连接线的代码如下:
[javascript] view plain copy


其中,第 1 - 6 行:绘制直线
第 8 - 15 行:绘制直线上的文字
直线上文字的样式为:
[html] view plain copy


fill-opacity 是透明度,0表示完全透明,1表示完全不透明。这里是0,表示初始状态下不显示。
4.4 绘制结点绘制结点的图片和文字:
[javascript] view plain copy


第 1 - 16 行:绘制图片
第 10 - 15 行:当鼠标移到图片上时,显示与此结点想关联的连接线上的文字。在这里只是对 d.show 进行布尔型赋值,在后面更新时会用到这个值。
第 21 - 30 行:绘制图片下方的文字
4.5 更新让力学图不断更新,使用 force.on("tick",function(){ }),表示每一步更新都调用 function 函数。
[javascript] view plain copy


5. 结果结果如下:

可点击下面的地址,右键点浏览器查看完整代码:http://www.ourd3js.com/demo/J-2.0/relationforce.html
6. 结束语在【入门系列】中,疑问最多的是【树状图】,本想先解决这个问题的,但是由于我也有些问题还没想明白,所以先写本文这个较容易的。接下来还将有几篇关于力学图的,树状图的整理要稍微拖一段时间。






欢迎光临 商会资讯 (http://smellage.com/) Powered by Discuz! X2.5