目录
当前位置: 首页 > 文档资料 > D3.js 帮助文档 >

d3-quadtree

优质
小牛编辑
135浏览
2023-12-01

quadtree 将二维平面递归的划分为正方形,并且可以进一步将正方形划分为四个等大小的正方形。每一个单独的点都放置在一个单独的 Installing

NPM 安装: npm install d3-quadtree. 此外还可以下载 latest release. 可以直接从 d3js.orgstandalone library(单独标准库) 或作为 D3 4.0 的一部分载入。支持 AMD, CommonJS 以及基本的标签引入形式. 如果使用标签引入会暴露 d3 全局变量:

<script src="https://d3js.org/d3-quadtree.v1.min.js"></script>
<script>

var quadtree = d3.quadtree();

</script>

在浏览器中测试 d3-quadtree

API Reference

d3.quadtree([data[, x, y]]) <源码>

使用空的 extent 和默认的 x- 和 y- 访问器创建一个新的、空的四叉树。如果指定了 data 则将指定的数组 adds 到四叉树中。等价于:

var tree = d3.quadtree()
    .addAll(data);

如果同时指定了 xy 则会在将数据添加到四叉树之前设置 x- 和 y- 访问器为指定的函数, 等价于:

var tree = d3.quadtree()
    .x(x)
    .y(y)
    .addAll(data);

quadtree.x([x]) <源码>

如果指定了 x 则将当前 x-坐标的访问器设置为指定的值并返回当前四叉树。如果没有指定则返回当前 x 访问器,默认为:

function x(d) {
  return d[0];
}

x 访问器用来在将数据 adding 到四叉树或者从四叉树中 removing 时读取 x 坐标的值。在 finding 插入到树中的坐标时也会使用到。因此 xy 访问器必须在相同的条件下返回确定的值。

quadtree.y([y]) <源码>

如果指定了 y 则将当前 y-坐标的访问器设置为指定的值并返回当前四叉树。如果没有指定则返回当前 y 访问器,默认为:

function y(d) {
  return d[1];
}

y 访问器用来在将数据 adding 到四叉树或者从四叉树中 removing 时读取 y 坐标的值。在 finding 插入到树中的坐标时也会使用到。因此 xy 访问器必须在相同的条件下返回确定的值。

quadtree.extent([extent]) <源码>

如果指定了 extent 则扩展四叉树的范围以 cover(覆盖) 指定的点 [[x0, y0], [x1, y1]] 并返回四叉树。如果没有指定 extent 则返回当前的区间 [[x0, y0], [x1, y1]],其中 x0y0 表示区间的下界而 x1y1 表示区间的上界,如果之前没有指定区间则会返回 undefined。扩展四叉树的区间必须使用 quadtree.cover 或 quadtree.add 方法。

quadtree.cover(x, y) <源码>

扩展四叉树的区间使其覆盖指定的点 ⟨x,y⟩ 并返回四叉树。如果四叉树的区间已经覆盖了指定的点则什么都不做。如果当前四叉树的区间没有覆盖指定的点则会重复加倍以覆盖指定的点。如果四叉树为空,则区间会被初始化为 [[⌊x⌋, ⌊y⌋], [⌈x⌉, ⌈y⌉]]。(四舍五入是必要的,这样的话如果区间在之后扩展翻倍时,不会因为浮点数而出现误差)。

quadtree.add(datum) <源码>

将指定的数据 datum 添加到四叉树中,并使用当前 x- 和 y- 访问器计算出坐标 ⟨x,y⟩,返回四叉树。如果新的点在当前 extent 之外,则会自动调用 cover 方法以覆盖新添加的点。

quadtree.addAll(data) <源码>

将指定点数组 data 添加到四叉树中,并使用当前 x- 和 y- 访问器为每个元素计算 ⟨x,y⟩ 坐标,返回四叉树。这是一种重复使用 quadtree.add 添加多个点的快捷方式:

for (var i = 0, n = data.length; i < n; ++i) {
  quadtree.add(data[i]);
}

但是,这种方法会产生更紧凑的四叉树,因为数据的区间是在添加数据之前计算的。

quadtree.remove(datum) <源码>

移除四叉树中指定的数据 datum,使用 x- 和 y- 访问器计算数据的坐标 ⟨x,y⟩。如果指定的 datum 不在当前四叉树中则什么都不做。

quadtree.removeAll(data) <源码>

… 清空四叉树

quadtree.copy()

返回四叉树的拷贝。返回的四叉树中所有的 nodes 都会拷贝当前四叉树中所有的节点。但是四叉树中的数据是引用共享的,而不是拷贝的。

quadtree.root() <源码>

返回当前四叉树的根 node

quadtree.data() <源码>

返回当前四叉树中所有的数据数组。

quadtree.size() <源码>

返回当前四叉树中所有的数据个数。

quadtree.find(x, y[, radius]) <源码>

返回距离指定点 ⟨x,y⟩ 最近的数据,可以指定搜索半径 radius. 如果没有指定 radius 则默认为无穷大。如果在指定的搜索区域内没有找到数据则返回 undefined.

quadtree.visit(callback) <源码>

以前序遍历的方式遍历所有的 node,并传入参数 node, x0, y0, x1, y1 调用指定的 callback,其中 node 为当前被遍历到的节点,⟨x0, y0⟩ 是当前节点的下界而 ⟨x1, y1⟩ 是当前节点的上界,返回四叉树。(假设 x 正方向为右,y 正方向为下,在 CanvasSVG 中 ⟨x0, y0⟩ 为左上角坐标,⟨x1, y1⟩ 为右下角坐标,但是坐标系统也可以是其他形式,所以更一般的情况应该为 x0 <= x1 并且 y0 <= y1

如果 callback 返回真值,则当前节点的子节点将不会被遍历,否则当前节点的子节点都会被遍历到。这在遍历四叉树中的部分分区时很有用,例如 Barnes–Hut approximation。请注意,子象限总是按照兄弟节点的顺序遍历: 左上角、右上角、左下角、右下角。在 search 等情形下,按照指定的顺序遍历兄弟节点可能会更快。

quadtree.visitAfter(callback) <源码>

以后序遍历的方式遍历所有的 Nodes

四叉树的内部节点以从左到右、从上到下的顺序表示为四个元素数组:

  • 0 - 左上象限,如果有.
  • 1 - 右上象限,如果有.
  • 2 - 左下象限,如果有.
  • 3 - 右下象限,如果有.

如果子象限是空的,则它可能是未定义的。

叶节点表示为具有以下属性的对象:

  • data - 与当前点关联的数据,也就是传递给 quadtree.add 的数据
  • next - 当前叶节点的下一个数据,如果有的话.

length 属性可以用来区分叶节点和内部节点:如果是叶节点则为 undefined,如果是 4 则为内部节点。例如获取所有的叶节点的数据:

if (!node.length) do console.log(node.data); while (node = node.next);

四叉树中的点的 x- 和 y-坐标 必须不能修改。更新一个点的位置需要首先 remove 点然后使用新的位置重新 add 到四叉树中。或者,可以完全丢弃现有的四叉树,重新创建一个新的四叉树,如果大多数点的位置改变,则重新创建可能会更高效。

最后更新:

类似资料

  • quadtree 将二维平面递归的划分为正方形,并且可以进一步将正方形划分为四个等大小的正方形。每一个单独的点都放置在一个单独的 Installing NPM 安装: npm install d3-quadtree. 此外还可以下载 latest release. 可以直接从 d3js.org 以 standalone library(单独标准库) 或作为 D3 4.0 的一部分载入。支持 AMD

  • 视图移动以及缩放是一种将用户注意力聚焦在感兴趣区域的一种流行的交互技术。操作直接,容易理解: 点击并拖拽平移,使用滚轮进行缩放,当然也可以通过触摸进行。平移和缩放被广泛的应用在地图中,但是也可被应用到其他的可视化比如时间序列以及散点图中。 缩放行为通过 d3-zoom 模块实现,能方便且灵活到 selections 上。它处理了许多 Installing NPM 安装: npm install d

  • 这个模块实现了用来计算一组二维点 Voronoi diagram(泰森多边形) 或 Delaunay triangulation(德劳内三角剖分) 的 Steven J. Fortune’s algorithm 算法。这个模块的实现大多是基于 Raymond Hill 的工作。 泰森多边形不仅仅在视觉上具有吸引力,在交互方面也非常实用,比如在散点图中增加点的目标面积。参考 “Strikeouts

  • transition 是一个类 selection 的接口,用来对 DOM 进行动画修改。这种修改不是立即修改,而是在规定的事件内平滑过渡到目标状态。 应用过渡,首先要选中元素,然后调用 selection.transition,并且设置期望的改变,例如: d3.select("body") .transition() .style("background-color", "red")

  • 这个模块提供了一个高效的队列,能管理上千并发动画同时保证与并发或分段动画一致的同步时序。在内部使用 requestAnimationFrame 进行 fluid animation(如果支持的话),否则切换使用 setTimeout来实现。 Installing NPM 安装: npm install d3-timer. 此外还可以下载 latest release。也可以直接从 d3js.org

  • 在可视化时间序列数据、分析时间模式或处理一般时间时,常规时间单位的不规则性很快就变得明显起来。在 Gregorian calendar(公历) 中,大多数月份有 31 天但是有些月份只有 28 或者 29、30 天。大多数年份有 365 天但是 leap years(闰年) 有 366 天。在 daylight saving(夏令时) 中一天可能有 23 25 小时。更复杂的是世界各地的夏时制不同