node-red-contrib-tak-registration
Version:
A Node-RED node to register to TAK and to help wrap files as datapackages to send to TAK
214 lines (137 loc) • 4.77 kB
Markdown
# GeoJSON RBush
[](https://travis-ci.org/DenisCarriere/geojson-rbush)
[](https://badge.fury.io/js/geojson-rbush)
[](https://raw.githubusercontent.com/DenisCarriere/geojson-rbush/master/LICENSE)
GeoJSON implementation of [RBush](https://github.com/mourner/rbush) — a high-performance JavaScript R-tree-based 2D spatial index for points and rectangles.
## Install
**npm**
```bash
$ npm install --save geojson-rbush
```
## API
<!-- Generated by documentation.js. Update this documentation by updating the source code. -->
#### Table of Contents
- [rbush](#rbush)
- [insert](#insert)
- [load](#load)
- [remove](#remove)
- [clear](#clear)
- [search](#search)
- [collides](#collides)
- [all](#all)
- [toJSON](#tojson)
- [fromJSON](#fromjson)
### rbush
GeoJSON implementation of [RBush](https://github.com/mourner/rbush#rbush) spatial index.
**Parameters**
- `maxEntries` **[number](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number)** defines the maximum number of entries in a tree node. 9 (used by default) is a
reasonable choice for most applications. Higher value means faster insertion and slower search, and vice versa. (optional, default `9`)
**Examples**
```javascript
var geojsonRbush = require('geojson-rbush').default;
var tree = geojsonRbush();
```
Returns **RBush** GeoJSON RBush
### insert
[insert](https://github.com/mourner/rbush#data-format)
**Parameters**
- `feature` **Feature** insert single GeoJSON Feature
**Examples**
```javascript
var poly = turf.polygon([[[-78, 41], [-67, 41], [-67, 48], [-78, 48], [-78, 41]]]);
tree.insert(poly)
```
Returns **RBush** GeoJSON RBush
### load
[load](https://github.com/mourner/rbush#bulk-inserting-data)
**Parameters**
- `features` **(FeatureCollection | [Array](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array)<Feature>)** load entire GeoJSON FeatureCollection
**Examples**
```javascript
var polys = turf.polygons([
[[[-78, 41], [-67, 41], [-67, 48], [-78, 48], [-78, 41]]],
[[[-93, 32], [-83, 32], [-83, 39], [-93, 39], [-93, 32]]]
]);
tree.load(polys);
```
Returns **RBush** GeoJSON RBush
### remove
[remove](https://github.com/mourner/rbush#removing-data)
**Parameters**
- `feature` **Feature** remove single GeoJSON Feature
- `equals` **[Function](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Statements/function)** Pass a custom equals function to compare by value for removal.
**Examples**
```javascript
var poly = turf.polygon([[[-78, 41], [-67, 41], [-67, 48], [-78, 48], [-78, 41]]]);
tree.remove(poly);
```
Returns **RBush** GeoJSON RBush
### clear
[clear](https://github.com/mourner/rbush#removing-data)
**Examples**
```javascript
tree.clear()
```
Returns **RBush** GeoJSON Rbush
### search
[search](https://github.com/mourner/rbush#search)
**Parameters**
- `geojson` **(BBox | FeatureCollection | Feature)** search with GeoJSON
**Examples**
```javascript
var poly = turf.polygon([[[-78, 41], [-67, 41], [-67, 48], [-78, 48], [-78, 41]]]);
tree.search(poly);
```
Returns **FeatureCollection** all features that intersects with the given GeoJSON.
### collides
[collides](https://github.com/mourner/rbush#collisions)
**Parameters**
- `geojson` **(BBox | FeatureCollection | Feature)** collides with GeoJSON
**Examples**
```javascript
var poly = turf.polygon([[[-78, 41], [-67, 41], [-67, 48], [-78, 48], [-78, 41]]]);
tree.collides(poly);
```
Returns **[boolean](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean)** true if there are any items intersecting the given GeoJSON, otherwise false.
### all
[all](https://github.com/mourner/rbush#search)
**Examples**
```javascript
tree.all()
```
Returns **FeatureCollection** all the features in RBush
### toJSON
[toJSON](https://github.com/mourner/rbush#export-and-import)
**Examples**
```javascript
var exported = tree.toJSON()
```
Returns **any** export data as JSON object
### fromJSON
[fromJSON](https://github.com/mourner/rbush#export-and-import)
**Parameters**
- `json` **any** import previously exported data
**Examples**
```javascript
var exported = {
"children": [
{
"type": "Feature",
"geometry": {
"type": "Point",
"coordinates": [110, 50]
},
"properties": {},
"bbox": [110, 50, 110, 50]
}
],
"height": 1,
"leaf": true,
"minX": 110,
"minY": 50,
"maxX": 110,
"maxY": 50
}
tree.fromJSON(exported)
```
Returns **RBush** GeoJSON RBush