1.0.6 • Published 3 years ago

planar-graph-to-polyline v1.0.6

Weekly downloads
97,612
License
MIT
Repository
github
Last release
3 years ago

planar-graph-to-polyline

Converts a planar graph to a collection of nested polylines (as would be consumed in a GeoJSON/TopoJSON file for example).

Example

var graphToPolygons = require("planar-graph-to-polyline")

var edges = []
var positions = []

for(var i=1; i<=3; ++i) {
  var v0 = positions.length
  for(var j=0; j<10; ++j) {
    var theta = 2.0 * Math.PI * j / 10
    positions.push([ i * Math.cos(theta), i * Math.sin(theta) ])
    edges.push([ v0+j, v0+((j+1)%10) ])
  }
}

console.log(graphToPolygons(edges, positions))

Output:

[ [ [ 20, 29, 28, 27, 26, 25, 24, 23, 22, 21 ],
    [ 11, 12, 13, 14, 15, 16, 17, 18, 19, 10 ] ],
  [ [ 0, 9, 8, 7, 6, 5, 4, 3, 2, 1 ] ] ]

Install

npm install planar-graph-to-polyline

API

require("planar-graph-to-polyline")(edges, positions)

Converts a planar graph into a collection of nested polylines

  • edges are the edges of the graph
  • positions are the locations of the vertices in the plane

Returns A list of loops encoding the regions bounded by the graph

Credits

(c) 2014 Mikola Lysenko. MIT License