GEOS 3.6.2
LocationIndexOfPoint.h
1/**********************************************************************
2 *
3 * GEOS - Geometry Engine Open Source
4 * http://geos.osgeo.org
5 *
6 * Copyright (C) 2011 Sandro Santilli <strk@keybit.net>
7 * Copyright (C) 2005-2006 Refractions Research Inc.
8 * Copyright (C) 2001-2002 Vivid Solutions Inc.
9 *
10 * This is free software; you can redistribute and/or modify it under
11 * the terms of the GNU Lesser General Public Licence as published
12 * by the Free Software Foundation.
13 * See the COPYING file for more information.
14 *
15 **********************************************************************
16 *
17 * Last port: linearref/LinearGeometryBuilder.java r466
18 *
19 **********************************************************************/
20
21#ifndef GEOS_LINEARREF_LOCATIONINDEXOFPOINT_H
22#define GEOS_LINEARREF_LOCATIONINDEXOFPOINT_H
23
24#include <geos/geom/Coordinate.h>
25#include <geos/geom/Geometry.h>
26#include <geos/linearref/LinearLocation.h>
27
28namespace geos
29{
30namespace linearref // geos::linearref
31{
32
40class LocationIndexOfPoint
41{
42
43private:
44 const geom::Geometry *linearGeom;
45
46 LinearLocation indexOfFromStart(const geom::Coordinate& inputPt, const LinearLocation* minIndex) const;
47
48public:
49 static LinearLocation indexOf(const geom::Geometry *linearGeom, const geom::Coordinate& inputPt);
50
51 static LinearLocation indexOfAfter(const geom::Geometry *linearGeom, const geom::Coordinate& inputPt, const LinearLocation* minIndex);
52
53 LocationIndexOfPoint(const geom::Geometry *linearGeom);
54
77 LinearLocation indexOfAfter(const geom::Coordinate& inputPt, const LinearLocation* minIndex) const;
78};
79}
80}
81#endif
Coordinate is the lightweight class used to store coordinates.
Definition Coordinate.h:60
Basic implementation of Geometry, constructed and destructed by GeometryFactory.
Definition Geometry.h:167
Represents a location along a LineString or MultiLineString.
Definition LinearLocation.h:44
LinearLocation indexOf(const geom::Coordinate &inputPt) const
LinearLocation indexOfAfter(const geom::Coordinate &inputPt, const LinearLocation *minIndex) const
Basic namespace for all GEOS functionalities.
Definition IndexedNestedRingTester.h:25