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
62 lines (60 loc) • 2.63 kB
JavaScript
import LineString from '../../../geom/LineString'
import Geometry from '../../../geom/Geometry'
import Coordinate from '../../../geom/Coordinate'
import Polygon from '../../../geom/Polygon'
import LineSegment from '../../../geom/LineSegment'
import PointPairDistance from './PointPairDistance'
import GeometryCollection from '../../../geom/GeometryCollection'
export default class DistanceToPointFinder {
interfaces_ () {
return []
}
getClass () {
return DistanceToPointFinder
}
static computeDistance () {
if (arguments[2] instanceof PointPairDistance && (arguments[0] instanceof LineString && arguments[1] instanceof Coordinate)) {
const line = arguments[0]
const pt = arguments[1]
const ptDist = arguments[2]
const coords = line.getCoordinates()
const tempSegment = new LineSegment()
for (let i = 0; i < coords.length - 1; i++) {
tempSegment.setCoordinates(coords[i], coords[i + 1])
const closestPt = tempSegment.closestPoint(pt)
ptDist.setMinimum(closestPt, pt)
}
} else if (arguments[2] instanceof PointPairDistance && (arguments[0] instanceof Polygon && arguments[1] instanceof Coordinate)) {
const poly = arguments[0]
const pt = arguments[1]
const ptDist = arguments[2]
DistanceToPointFinder.computeDistance(poly.getExteriorRing(), pt, ptDist)
for (let i = 0; i < poly.getNumInteriorRing(); i++) {
DistanceToPointFinder.computeDistance(poly.getInteriorRingN(i), pt, ptDist)
}
} else if (arguments[2] instanceof PointPairDistance && (arguments[0] instanceof Geometry && arguments[1] instanceof Coordinate)) {
const geom = arguments[0]
const pt = arguments[1]
const ptDist = arguments[2]
if (geom instanceof LineString) {
DistanceToPointFinder.computeDistance(geom, pt, ptDist)
} else if (geom instanceof Polygon) {
DistanceToPointFinder.computeDistance(geom, pt, ptDist)
} else if (geom instanceof GeometryCollection) {
const gc = geom
for (let i = 0; i < gc.getNumGeometries(); i++) {
const g = gc.getGeometryN(i)
DistanceToPointFinder.computeDistance(g, pt, ptDist)
}
} else {
ptDist.setMinimum(geom.getCoordinate(), pt)
}
} else if (arguments[2] instanceof PointPairDistance && (arguments[0] instanceof LineSegment && arguments[1] instanceof Coordinate)) {
const segment = arguments[0]
const pt = arguments[1]
const ptDist = arguments[2]
const closestPt = segment.closestPoint(pt)
ptDist.setMinimum(closestPt, pt)
}
}
}