机械图(力路线图)结合老百姓的关系图中的生活,这是更有趣。

本文将以此为证据,所列的如何图插入外部的图像和文字的力学。

在【第 9.2 章】中制作了一个最简单的力学图。其后有非常多朋友有疑问,基本的问题包含:

  • 怎样在小球旁插入文字
  • 怎样将小球换为别的图形
  • 怎样插入图片
  • 怎样限制小球运动的边界

本文将对以上问题依次做出讲解。当中前三点是 SVG 元素的问题。和 D3 无多大关联。

1. SVG 图片

SVG 的图片元素的具体讲解可看【官方文档-图片】。通常,我们仅仅须要使用到图片元素的五个属性就够了。

  1. <image xlink:href="image.png" x="200" y="200" width="100" height="100"></image>

当中:

  • xlink:href - 图片名称或图片网址
  • x - 图片坐上角 x 坐标
  • y - 图片坐上角 y 坐标
  • width - 图片宽度
  • height- 图片高度

在 D3 中插入图片,代码形如:

  1. svg.selectAll("image")
  2. .data(dataset)
  3. .enter()
  4. .append("image")
  5. .attr("x",200)
  6. .attr("y",200)
  7. .attr("width",100)
  8. .attr("height",100)
  9. .attr("xlink:href","image.png");

2. SVG 文本

SVG 的文本元素和图片类似,具体属性见【官方文档-文本】。

  1. <text x="250" y="150" dx="10" dy="10" font-family="Verdana" font-size="55" fill="blue" >Hello</text>

当中:

  • x - 文本 x 坐标
  • y - 文本 y 坐标
  • dx- x 轴方向的文本平移量
  • dy- y 轴方向的文本平移量
  • font-family - 字体
  • font-size - 字体大小
  • fill - 字体颜色

在 D3 中插入文本,代码形如:

  1. svg.selectAll("text")
  2. .data(dataset)
  3. .enter()
  4. .append("text")
  5. .attr("x",250)
  6. .attr("y",150)
  7. .attr("dx",10)
  8. .attr("dy",10)
  9. .text("Hello");

3. 源文件

接下来制作力学图的源文件。本次将数据写入 JSON 文件里。

呵呵。借用一下【仙剑4】的人物。本人也是个仙剑迷,期待15年7月【仙剑6】的上市。

  1. {
  2. "nodes":[
  3. { "name": "云天河" , "image" : "tianhe.png" },
  4. { "name": "韩菱纱" , "image" : "lingsha.png" },
  5. { "name": "柳梦璃" , "image" : "mengli.png" },
  6. { "name": "慕容紫英" , "image" : "ziying.png" }
  7. ],
  8. "edges":[
  9. { "source": 0 , "target": 1 , "relation":"挚友" },
  10. { "source": 0 , "target": 2 , "relation":"挚友" },
  11. { "source": 0 , "target": 3 , "relation":"挚友" }
  12. ]
  13. }

如上,在 JSON 文件里加入数据。再将图片文件与 JSON 文件放于同一文件夹下就可以(放哪都行,最主要是看程序中是怎样实现的)。

4. 力学图

4.1 读入文件

读入 JSON 文件,这点应该非常熟了吧。不然能够先看看【第 9.4 章】。

  1. d3.json("relation.json",function(error,root){
  2.  
  3. if( error ){
  4. return console.log(error);
  5. }
  6. console.log(root);
  7. }

4.2 定义力学图的布局

力学图的 Layout(布局)例如以下:

  1. var force = d3.layout.force()
  2. .nodes(root.nodes)
  3. .links(root.edges)
  4. .size([width,height])
  5. .linkDistance(200)
  6. .charge(-1500)
  7. .start();

当中 linkDistance 是结点间的距离, charge 是定义结点间是吸引(值为正)还是相互排斥(值为负),值越大力越强。

4.3 绘制连接线

绘制结点之间的连接线的代码例如以下:

  1. var edges_line = svg.selectAll("line")
  2. .data(root.edges)
  3. .enter()
  4. .append("line")
  5. .style("stroke","#ccc")
  6. .style("stroke-width",1);
  7.  
  8. var edges_text = svg.selectAll(".linetext")
  9. .data(root.edges)
  10. .enter()
  11. .append("text")
  12. .attr("class","linetext")
  13. .text(function(d){
  14. return d.relation;
  15. });

当中,第 1 - 6 行:绘制直线

第 8 - 15 行:绘制直线上的文字

直线上文字的样式为:

  1. .linetext {
  2. font-size: 12px ;
  3. font-family: SimSun;
  4. fill:#0000FF;
  5. fill-opacity:0.0;
  6. }

fill-opacity 是透明度,0表示全然透明,1表示全然不透明。这里是0。表示初始状态下不显示。

4.4 绘制结点

绘制结点的图片和文字:

  1. var nodes_img = svg.selectAll("image")
  2. .data(root.nodes)
  3. .enter()
  4. .append("image")
  5. .attr("width",img_w)
  6. .attr("height",img_h)
  7. .attr("xlink:href",function(d){
  8. return d.image;
  9. })
  10. .on("mouseover",function(d,i){
  11. d.show = true;
  12. })
  13. .on("mouseout",function(d,i){
  14. d.show = false;
  15. })
  16. .call(force.drag);
  17.  
  18. var text_dx = -20;
  19. var text_dy = 20;
  20.  
  21. var nodes_text = svg.selectAll(".nodetext")
  22. .data(root.nodes)
  23. .enter()
  24. .append("text")
  25. .attr("class","nodetext")
  26. .attr("dx",text_dx)
  27. .attr("dy",text_dy)
  28. .text(function(d){
  29. return d.name;
  30. });

第 1 - 16 行:绘制图片

第 10 - 15 行:当鼠标移到图片上时。显示与此结点想关联的连接线上的文字。在这里仅仅是对 d.show 进行布尔型赋值。在后面更新时会用到这个值。

第 21 - 30 行:绘制图片下方的文字

4.5 更新

让力学图不断更新,使用 force.on("tick",function(){ }),表示每一步更新都调用 function 函数。

  1. force.on("tick", function(){
  2.  
  3. //限制结点的边界
  4. root.nodes.forEach(function(d,i){
  5. d.x = d.x - img_w/2 < 0 ?
  6.  
  7. img_w/2 : d.x ;
  8. d.x = d.x + img_w/2 > width ? width - img_w/2 : d.x ;
  9. d.y = d.y - img_h/2 < 0 ?
  10.  
  11. img_h/2 : d.y ;
  12. d.y = d.y + img_h/2 + text_dy > height ? height - img_h/2 - text_dy : d.y ;
  13. });
  14.  
  15. //更新连接线的位置
  16. edges_line.attr("x1",function(d){ return d.source.x; });
  17. edges_line.attr("y1",function(d){ return d.source.y; });
  18. edges_line.attr("x2",function(d){ return d.target.x; });
  19. edges_line.attr("y2",function(d){ return d.target.y; });
  20.  
  21. //更新连接线上文字的位置
  22. edges_text.attr("x",function(d){ return (d.source.x + d.target.x) / 2 ; });
  23. edges_text.attr("y",function(d){ return (d.source.y + d.target.y) / 2 ; });
  24.  
  25. //是否绘制连接线上的文字
  26. edges_text.style("fill-opacity",function(d){
  27. return d.source.show || d.target.show ? 1.0 : 0.0 ;
  28. });
  29.  
  30. //更新结点图片和文字
  31. nodes_img.attr("x",function(d){ return d.x - img_w/2; });
  32. nodes_img.attr("y",function(d){ return d.y - img_h/2; });
  33.  
  34. nodes_text.attr("x",function(d){ return d.x });
  35. nodes_text.attr("y",function(d){ return d.y + img_w/2; });
  36. });

5. 结果

结果例如以下:

可点击以下的地址,右键点浏览器查看完整代码:http://www.ourd3js.com/demo/J-2.0/relationforce.html

6. 结束语

在【入门系列】中,疑问最多的是【树状图】,本想先解决问题的。可是因为我也有些问题还没想明确。所以先写本文这个较easy的。接下来还将有几篇关于力学图的,树状图的整理要略微拖一段时间。

谢谢阅读。


文档信息


【 D3.js 高级系列 — 2.0 】 机械图 + 人物关系图的更多相关文章

  1. 【 D3.js 高级系列 — 10.0 】 思维导图

    思维导图的节点具有层级关系和隶属关系,很像枝叶从树干伸展开来的形状.在前面讲解布局的时候,提到有五个布局是由层级布局扩展来的,其中的树状图(tree layout)和集群图(cluster layou ...

  2. 【 D3.js 高级系列 — 3.0 】 堆栈图

    堆栈图布局(Stack Layout)能够计算二维数组每一数据层的基线,以方便将各数据层叠加起来.本文讲解堆栈图的制作方法. 先说说什么是堆栈图. 例如,有如下情况: 某公司,销售三种产品:个人电脑. ...

  3. 【 D3.js 高级系列 — 2.0 】 捆图

    捆图(Bundle)是 D3 中比较奇特的一个布局,只有两个函数,而且需要与其它布局配合使用.本文讲述捆图的制作方法. 有关捆图的例子极少,很容易找到的是:http://bl.ocks.org/mbo ...

  4. 【 D3.js 高级系列 — 4.0 】 矩阵树图

    矩阵树图(Treemap),也是层级布局的扩展,根据数据将区域划分为矩形的集合.矩形的大小和颜色,都是数据的反映.许多门户网站都能见到类似图1,将照片以不同大小的矩形排列的情形,这正是矩阵树图的应用. ...

  5. 【 D3.js 高级系列 — 1.0 】 文本的换行

    在 SVG 中添加文本是使用 text 元素.但是,这个元素不能够自动换行,超出的部分就显示不出来了,怎么办呢? 高级系列开篇前言 从今天开始写高级系列教程.还是那句话,由于本人实力有限,不一定保证入 ...

  6. 【 D3.js 高级系列 — 9.0 】 交互式提示框

    一般来说,图表中不宜存在过多文字.但是,有时需要一些文字来描述某些图形元素.那么,可以实现一种交互:当用户鼠标滑到某图形元素时,出现一个提示框,里面写有描述文字.这是一种简单.普遍的交互式,几乎适用于 ...

  7. 【 D3.js 高级系列 — 6.0 】 值域和颜色

    在[入门 - 第 10 章]作了一张中国地图,其中各省份的颜色值都是随意赋值的.如果要将一些值反映在地图上,可以利用颜色的变化来表示值的变化. 1. 思路 例如,有值域的范围为: [10, 500] ...

  8. 【 D3.js 高级系列 — 8.0 】 标线

    有时候,需要在地图上绘制连线,表示"从某处到某处"的意思,这种时候在地图上绘制的连线,称为"标线". 1. 标线是什么 标线,是指地图上需要两个坐标以上才能表示 ...

  9. 【 D3.js 高级系列 — 7.0 】 标注地点

    有时需要告诉用户地图上的一些目标,如果该目标是只需要一个坐标就能表示的,称其为"标注". 1. 标注是什么 标注,是指地图上只需要一个坐标即可表示的元素.例如,在经纬度(116, ...

随机推荐

  1. 在Windows下搭建Apacheserver

    Apacheserver是一款基于HTTP协议的webserver.Apacheserver使用CGI开发 首先下载Apacheserver,下载地址http://download.csdn.net/ ...

  2. (转)oracle常用的数据字典

    一.oracle数据字典主要由以下几种视图构成: .user视图 以user_为前缀,用来记录用户对象的信息 .all视图 以all_为前缀,用来记录用户对象的信息及被授权访问的对象信息 .dba视图 ...

  3. 辛星解读之php中的重点函数第一节之数组函数

    这里我已经写好它的pdf版本号了,比本博客更加适合阅读.首先说一下它在百度网盘的下载地址把:百度网盘下载 ,假设左边连接跪了.能够在浏览器中输入:http://pan.baidu.com/s/1qW5 ...

  4. TCP的滑动窗口与拥塞窗口

    一.滑动窗口 滑动窗口协议是传输层进行流控的一种措施,接收方通过通告发送方自己的窗口大小,从而控制发送方的发送速度,从而达到防止发送方发送速度过快而导致自己被淹没的目的.   对ACK的再认识,ack ...

  5. 基于深度学习的人脸识别系统(Caffe+OpenCV+Dlib)【二】人脸预处理

    前言 基于深度学习的人脸识别系统,一共用到了5个开源库:OpenCV(计算机视觉库).Caffe(深度学习库).Dlib(机器学习库).libfacedetection(人脸检测库).cudnn(gp ...

  6. Microsoft Bot Framework 链接至微信公共号

    如何将 Microsoft Bot Framework 链接至微信公共号   说到 Microsoft Bot Framework 其实微软发布了已经有一段时间了,有很多朋友可能还不太了解,微软Bot ...

  7. Yii 错误页面处理

    [错误页面处理] 訪问一个错误的控制器 訪问一个错误的方法 有些控制器和方法禁止訪问   以上訪问会提示错误信息 404  403 以上错误信息是不方便给外边用户看到的. 1. 安全隐患 2. 用户体 ...

  8. PatentTips - Enhanced I/O Performance in a Multi-Processor System Via Interrupt Affinity Schemes

    BACKGROUND OF THE INVENTION This relates to Input/Output (I/O) performance in a host system having m ...

  9. ng-cli搭建angular项目框架

    原文地址 https://www.jianshu.com/p/0a8f4b0f29b3 环境准备 以下步骤都不需要事先创建文件夹,只是环境的准备过程,只有到需要搭建项目的时候才需要创建文件夹用来存放项 ...

  10. PatentTips - Highly-available OSPF routing protocol

    BACKGROUND OF THE INVENTION FIG. 1A is a simplified block diagram schematically representing a typic ...