00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019 #ifndef GEOS_NODING_GEOMETRYNODER_H
00020 #define GEOS_NODING_GEOMETRYNODER_H
00021
00022 #include <geos/export.h>
00023 #include <geos/noding/SegmentString.h>
00024
00025 #include <memory>
00026
00027
00028 namespace geos {
00029 namespace geom {
00030 class Geometry;
00031 }
00032 namespace noding {
00033 class Noder;
00034 }
00035 }
00036
00037 namespace geos {
00038 namespace noding {
00039
00040 class GEOS_DLL GeometryNoder
00041 {
00042 public:
00043
00044 static std::auto_ptr<geom::Geometry> node(const geom::Geometry& geom);
00045
00046 GeometryNoder(const geom::Geometry& g);
00047
00048 std::auto_ptr<geom::Geometry> getNoded();
00049
00050 private:
00051
00052 const geom::Geometry& argGeom;
00053
00054 SegmentString::NonConstVect lineList;
00055
00056 static void extractSegmentStrings(const geom::Geometry& g,
00057 SegmentString::NonConstVect& to);
00058
00059 Noder& getNoder();
00060
00061 std::auto_ptr<Noder> noder;
00062
00063 std::auto_ptr<geom::Geometry> toGeometry(SegmentString::NonConstVect& noded);
00064
00065 GeometryNoder(GeometryNoder const&);
00066 GeometryNoder& operator=(GeometryNoder const&);
00067 };
00068
00069 }
00070 }
00071
00072 #endif // GEOS_NODING_NODER_H