00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 #ifndef GEOS_NODING_INTERSECTIONFINDERADDER_H
00021 #define GEOS_NODING_INTERSECTIONFINDERADDER_H
00022
00023 #include <geos/export.h>
00024
00025 #include <vector>
00026 #include <iostream>
00027
00028 #include <geos/inline.h>
00029
00030 #include <geos/geom/Coordinate.h>
00031 #include <geos/noding/SegmentIntersector.h>
00032
00033
00034 namespace geos {
00035 namespace geom {
00036 class Coordinate;
00037 }
00038 namespace noding {
00039 class SegmentString;
00040 }
00041 namespace algorithm {
00042 class LineIntersector;
00043 }
00044 }
00045
00046 namespace geos {
00047 namespace noding {
00048
00054 class GEOS_DLL IntersectionFinderAdder: public SegmentIntersector {
00055
00056 public:
00057
00065 IntersectionFinderAdder(algorithm::LineIntersector& newLi,
00066 std::vector<geom::Coordinate>& v)
00067 :
00068 li(newLi),
00069 interiorIntersections(v)
00070 {}
00071
00082 void processIntersections(
00083 SegmentString* e0, int segIndex0,
00084 SegmentString* e1, int segIndex1);
00085
00086 std::vector<geom::Coordinate>& getInteriorIntersections() {
00087 return interiorIntersections;
00088 }
00089
00095 virtual bool isDone() const {
00096 return false;
00097 }
00098
00099 private:
00100 algorithm::LineIntersector& li;
00101 std::vector<geom::Coordinate>& interiorIntersections;
00102
00103
00104 IntersectionFinderAdder(const IntersectionFinderAdder& other);
00105 IntersectionFinderAdder& operator=(const IntersectionFinderAdder& rhs);
00106 };
00107
00108 }
00109 }
00110
00111
00112
00113
00114
00115 #endif // GEOS_NODING_INTERSECTIONFINDERADDER_H
00116
00117
00118
00119
00120
00121
00122
00123
00124
00125
00126
00127
00128
00129
00130
00131
00132