力学图的布局中有非常多參数。本文将逐个说明。

D3 中的力学图布局是使用韦尔莱积分法计算的。这是一种用于求解牛顿运动方程的数值方法,被广泛应用于分子动力学模拟以及视频游戏中。

定义布局的代码例如以下:

var force = d3.layout.force()

就可以。D3 中提供了 17 个函数用于设定其參数和事件。在全部布局中是最多的,以下将对其进行说明。

size()

用于设定力学图的作用范围。用法为 force.size( [ x , y ] ),这个函数用于指定两件事:

  • 重力的重心位置为 ( x/2 , y/2 )
  • 全部节点的初始位置限定为 [ 0 , x ] 和 [ 0 , y ] 之间(但并不是之后也是如此)

假设不指定,默觉得 [ 1 , 1 ] 。

linkDistance()

指定结点连接线的距离,默觉得20。假设距离是一个常数。那么各连接线的长度总是固定的;假设是一个函数。那么这个函数是作用于各连接线( source , target )的。

linkStrength()

指定连接线的坚硬度。值的范围为[ 0 , 1 ]。值越大越坚硬。

其直观感受是:

  • 值为1。则拖动一个顶点A。与之相连的顶点会与A保持linkDistance设定的距离运动
  • 值为0,则拖动一个顶点A,与之相连的顶点不会运动。连接线会被拉长

friction()

定义摩擦系数的函数。值的范围为[ 0 , 1 ]。默觉得0.9。可是这个值事实上并不是物理意义上的摩擦,事实上其意义更接近速度随时间产生的损耗,这个损耗是针对每个顶点的。

  • 值为1,则没有速度的损耗。
  • 值为0。则速度的损耗最大。

charge()

设定引力,是排斥还是吸引,默认值为-30。

  • 值为+,则相互吸引。绝对值越大吸引力越大。
  • 值为-。则互斥,绝对值越大排斥力越大。

chargeDistance()

设定引力的作用距离,超过这个距离,则没有引力的作用。

默认值为无穷大。

gravity()

以 size 函数设定的中心产生重力,各顶点都会向中心运动。默认值为0.1。也能够设定为0。则没有重力的作用。

theta()

顶点数假设过多,计算的时间就会加大(O(n log n))。theta 就是为了限制这个计算而存在的。默认值为0.8。这个值越小,就能把计算限制得越紧。

alpha()

设定动画运动的时间,超过时间后运动就会停止。

事实上

  • force.start() 即 alpha(0.1)
  • force.stop() 即 alpha(0)

谢谢阅读。

文档信息

【 D3.js 进阶系列 — 2.2 】 力学图的參数的更多相关文章

  1. 【 D3.js 进阶系列 】 进阶总结

    进阶系列的文章从去年10月开始写的,晃眼又是4个多月了,想在年前总结一下. 首先恭祝大家新年快乐.今年是羊年吧.前段时间和朋友聊天,聊到十二生肖里为什么没猫,我张口就道:不是因为十二生肖开会的时候猫迟 ...

  2. 【 D3.js 进阶系列 — 4.0 】 绘制箭头

    转自:http://www.ourd3js.com/wordpress/?p=660 [ D3.js 进阶系列 — 4.0 ] 绘制箭头 发表于2014/12/08 在 SVG 绘制区域中作图,在绘制 ...

  3. 【 D3.js 进阶系列 — 2.1 】 力学图的事件 + 顶点的固定

    本章讨论在力学图中经常使用到的事件( Event ),然后对[p=555">进阶 - 第 2.0 章]的人物关系图进行改进.使用户可以固定拖拽的对象. 在[入门 - 第 9.2 章]和 ...

  4. 【 D3.js 进阶系列 — 6.2 】 饼状图的拖拽

    本文讲解稍微复杂一些的拖拽应用,即拖拽饼图的各部分. 在[入门 - 第 9.1 章]讲解了如何制作饼状图.饼状图的各部分是用具有宽度的弧线来表示的.在与用户进行交互的时候,如果每一部分都能拖拽,是很有 ...

  5. 【 D3.js 进阶系列 — 1.1 】 其它表格文件的读取

    CSV 表格文件是以逗号作为单元分隔符的,其他还有以制表符 Tab 作为单元分隔符的 TSV 文件,还有人为定义的其他分隔符的表格文件.本文将说明在 D3 中怎样读取它们. 1. TSV 表格文件是什 ...

  6. 【 D3.js 进阶系列 — 1.2 】 读取 CSV 文件时乱码的解决方法

    在 D3 中使用 d3.csv 读取 CSV 文件时,有时会出现乱码问题. 怎么解决呢? 1. 乱码问题 使用 d3.csv 读取 xxx.csv 文件时.假设 xxx.csv 文件使用的是 UTF- ...

  7. 【 D3.js 进阶系列 — 6.1 】 缩放的应用(Zoom)

    缩放(Zoom)是另一种重要的可视化操作,主要是使用鼠标的滚轮进行. 1. zoom 的定义 缩放是由 d3.behavior.zoom() 定义的. var zoom = d3.behavior.z ...

  8. 【 D3.js 进阶系列 — 5.0 】 直方图

    直方图用于描写叙述概率分布,D3 提供了直方图的布局 Histogram 用于转换数据. 假设有数组 a = [10, 11, 11.5, 12.5, 13, 15, 19, 20 ],如今把10~2 ...

  9. 【 D3.js 进阶系列 — 1.0 】 CSV 表格文件的读取

    在入门系列的教程中.我们经常使用 d3.json() 函数来读取 json 格式的文件.json 格式非常强大.但对于普通用户可能不太适合,普通用户更喜欢的是用 Microsoft Excel 或 O ...

随机推荐

  1. mysql数据库存储的引擎和数据类型

    一.查看支持的存储引擎 SHOW ENGINES \G; 或者 SHOW VARIABLES LIKE 'have%'; 二.安装版mysql的默认引擎是InnoDB,免安装版默认引擎是MyISAM ...

  2. [转]sed常用命令总结

    转自:http://blog.chinaunix.net/uid-26963748-id-3249732.html 一.Sed简介 Sed:Stream Editor  流式编辑器 又称行编辑器,每次 ...

  3. Json解析与Gson解析

    本文主要介绍json最原始的解析与google提供的gson工具类解析 ①json解析 /** * 普通的json解析 * @param s * @throws JSONException */ pr ...

  4. SQL基本操作——DROP撤销索引、表以及数据库

    DROP撤销索引.表以及数据库 --DROP INDEX 命令删除表格中的索引 DROP INDEX table_name.index_name --DROP TABLE 语句删除表(表的结构.属性以 ...

  5. ZipMarket数字内容/素材交易网站源码项目

    ZipMarket程序仿自Envato旗下网站,对于想创建数字内容/素材交易平台的站长来说,ZipMarket是一个十分独特和极具创新的解决方案,用户在你的网站注册并购买或出售数字内容/素材作品时,你 ...

  6. 调用.NET Serviced Component引发的性能问题及其解决

    在企业用户环境里,.NET Serviced Component使用广泛.它比较好的把传统COM+封装和.NET应用逻辑衔接了起来,在服务器端应用起到重要作用..NET Serviced Compon ...

  7. Caffe FCN:可视化featureMaps和Weights(C++)、获取FCN结果

    为何不使用C++版本FCN获取最后的分割掩模,何必要使用python呢!因此需要获取网络最后层的featureMaps,featureMaps的结果直接对应了segmentation的最终结果,可以直 ...

  8. CAD动态绘制样条线(com接口)

    主要用到函数说明: _DMxDrawX::SendStringToExecuteFun 把命令当着函数执行,可以传参数.详细说明如下: 参数 说明 IDispatch* pParam 命令参数,IMx ...

  9. windows设置右键菜单

    1. 打开注册表,(win + R,输入regedit) 2. 在 HKEY_CLASSES_ROOT\Directory\Background\shell 中,新建项:如(cmder),在 cmde ...

  10. CF176E Archaeology(set用法提示)

    题目大意: 给一棵树,每次激活或熄灭一个点,每次问这些点都联通起来所需的最小总边权 分析: 若根据dfs序给所有点排序,为$v1,v2,v3....vk$,那么答案就是$(dis(v1,v2)+dis ...