UNPKG

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

31 lines (30 loc) 1.28 kB
import hasInterface from '../../../../../hasInterface' import SegmentStringUtil from '../../noding/SegmentStringUtil' import Polygonal from '../Polygonal' import PreparedPolygonPredicate from './PreparedPolygonPredicate' export default class PreparedPolygonContainsProperly extends PreparedPolygonPredicate { constructor() { super() PreparedPolygonContainsProperly.constructor_.apply(this, arguments) } static constructor_() { const prepPoly = arguments[0] PreparedPolygonPredicate.constructor_.call(this, prepPoly) } static containsProperly(prep, geom) { const polyInt = new PreparedPolygonContainsProperly(prep) return polyInt.containsProperly(geom) } containsProperly(geom) { const isAllInPrepGeomAreaInterior = this.isAllTestComponentsInTargetInterior(geom) if (!isAllInPrepGeomAreaInterior) return false const lineSegStr = SegmentStringUtil.extractSegmentStrings(geom) const segsIntersect = this._prepPoly.getIntersectionFinder().intersects(lineSegStr) if (segsIntersect) return false if (hasInterface(geom, Polygonal)) { const isTargetGeomInTestArea = this.isAnyTargetComponentInAreaTest(geom, this._prepPoly.getRepresentativePoints()) if (isTargetGeomInTestArea) return false } return true } }