00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 #ifndef GEOS_OP_OVERLAY_FUZZYPOINTLOCATOR_H
00021 #define GEOS_OP_OVERLAY_FUZZYPOINTLOCATOR_H
00022
00023 #include <geos/algorithm/PointLocator.h>
00024 #include <geos/geom/Geometry.h>
00025 #include <geos/geom/Location.h>
00026
00027 #include <vector>
00028 #include <memory>
00029
00030
00031 namespace geos {
00032 namespace geom {
00033 class Geometry;
00034 class Coordinate;
00035 }
00036 }
00037
00038 namespace geos {
00039 namespace operation {
00040 namespace overlay {
00041 namespace validate {
00042
00053 class FuzzyPointLocator {
00054
00055 public:
00056
00057 FuzzyPointLocator(const geom::Geometry& geom, double nTolerance);
00058
00059 geom::Location::Value getLocation(const geom::Coordinate& pt);
00060
00061 private:
00062
00063 const geom::Geometry& g;
00064
00065 double tolerance;
00066
00067 algorithm::PointLocator ptLocator;
00068
00069 std::auto_ptr<geom::Geometry> linework;
00070
00071
00072 std::auto_ptr<geom::Geometry> getLineWork(const geom::Geometry& geom);
00073
00075
00078 std::auto_ptr<geom::Geometry> extractLineWork(const geom::Geometry& geom);
00079
00080
00081 FuzzyPointLocator(const FuzzyPointLocator& other);
00082 FuzzyPointLocator& operator=(const FuzzyPointLocator& rhs);
00083 };
00084
00085 }
00086 }
00087 }
00088 }
00089
00090 #endif // ndef GEOS_OP_OVERLAY_FUZZYPOINTLOCATOR_H
00091
00092
00093
00094
00095