/********************************************************************** * * GEOS - Geometry Engine Open Source * http://geos.osgeo.org * * Copyright (C) 2006 Refractions Research Inc. * * This is free software; you can redistribute and/or modify it under * the terms of the GNU Lesser General Public Licence as published * by the Free Software Foundation. * See the COPYING file for more information. * **********************************************************************/ #ifndef GEOS_NODING_NODER_H #define GEOS_NODING_NODER_H #include #include #include #include // Forward declarations namespace geos { namespace noding { class SegmentString; } } namespace geos { namespace noding { // geos.noding /** \brief * Computes all intersections between segments in a set of SegmentString. * * Intersections found are represented as {@link SegmentNode}s and added to the * {@link SegmentString}s in which they occur. * As a final step in the noding a new set of segment strings split * at the nodes may be returned. * * Last port: noding/Noder.java rev. 1.8 (JTS-1.7) * * TODO: this was really an interface, we should avoid making it a Base class * */ class GEOS_DLL Noder { public: /** \brief * Computes the noding for a collection of {@link SegmentString}s. * * Some Noders may add all these nodes to the input SegmentStrings; * others may only add some or none at all. * * @param segStrings a collection of {@link SegmentString}s to node */ virtual void computeNodes(std::vector* segStrings)=0; /** \brief * Returns a {@link Collection} of fully noded {@link SegmentStrings}. * The SegmentStrings have the same context as their parent. * * @return a newly allocated std::vector of const SegmentStrings. * Caller is responsible to delete container and elements. */ virtual std::vector* getNodedSubstrings() const=0; virtual ~Noder() {} protected: Noder(){} }; } // namespace geos.noding } // namespace geos //#ifdef GEOS_INLINE //# include "geos/noding/Noder.inl" //#endif #endif // GEOS_NODING_NODER_H