GEOS 3.14.0dev
ConnectedElementPointFilter.h
1/**********************************************************************
2 *
3 * GEOS - Geometry Engine Open Source
4 * http://geos.osgeo.org
5 *
6 * Copyright (C) 2006 Refractions Research Inc.
7 *
8 * This is free software; you can redistribute and/or modify it under
9 * the terms of the GNU Lesser General Public Licence as published
10 * by the Free Software Foundation.
11 * See the COPYING file for more information.
12 *
13 **********************************************************************
14 *
15 * Last port: operation/distance/ConnectedElementPointFilter.java rev. 1.7 (JTS-1.10)
16 *
17 **********************************************************************/
18
19#pragma once
20
21#include <geos/export.h>
22
23#include <geos/geom/GeometryFilter.h> // for inheritance
24
25#include <vector>
26
27// Forward declarations
28namespace geos {
29namespace geom {
30class CoordinateXY;
31class Geometry;
32}
33}
34
35
36namespace geos {
37namespace operation { // geos::operation
38namespace distance { // geos::operation::distance
39
47
48private:
49 std::vector<const geom::CoordinateXY*>* pts;
50
51public:
57 static std::vector<const geom::CoordinateXY*>* getCoordinates(const geom::Geometry* geom);
58
59 ConnectedElementPointFilter(std::vector<const geom::CoordinateXY*>* newPts)
60 :
61 pts(newPts)
62 {}
63
64 void filter_ro(const geom::Geometry* geom) override;
65
66 //void filter_rw(geom::Geometry * /*geom*/) {};
67};
68
69
70} // namespace geos::operation::distance
71} // namespace geos::operation
72} // namespace geos
73
Geometry classes support the concept of applying a Geometry filter to the Geometry.
Definition GeometryFilter.h:45
Basic implementation of Geometry, constructed and destructed by GeometryFactory.
Definition Geometry.h:197
Extracts a single point from each connected element in a Geometry (e.g. a polygon,...
Definition ConnectedElementPointFilter.h:46
static std::vector< const geom::CoordinateXY * > * getCoordinates(const geom::Geometry *geom)
Basic namespace for all GEOS functionalities.
Definition geos.h:39