00001 
00002 
00003 
00004 
00005 
00006 
00007 
00008 
00009 
00010 
00011 
00012 
00013 
00014 
00015 
00016 
00017 #ifndef GEOS_GEOMGRAPH_INDEX_SIMPLEEDGESETINTERSECTOR_H
00018 #define GEOS_GEOMGRAPH_INDEX_SIMPLEEDGESETINTERSECTOR_H
00019 
00020 #include <vector>
00021 
00022 #include <geos/geomgraph/index/EdgeSetIntersector.h> 
00023 
00024 
00025 namespace geos {
00026         namespace geomgraph {
00027                 class Edge;
00028                 namespace index {
00029                         class SegmentIntersector;
00030                 }
00031         }
00032 }
00033 
00034 namespace geos {
00035 namespace geomgraph { 
00036 namespace index { 
00037 
00038 class SimpleEdgeSetIntersector: public EdgeSetIntersector {
00039 
00040 public:
00041 
00042         SimpleEdgeSetIntersector();
00043 
00044         void computeIntersections(std::vector<Edge*> *edges,
00045                         SegmentIntersector *si, bool testAllSegments);
00046 
00047         void computeIntersections(std::vector<Edge*> *edges0,
00048                         std::vector<Edge*> *edges1, SegmentIntersector *si);
00049 
00050 private:
00051 
00052         int nOverlaps;
00053 
00054         void computeIntersects(Edge *e0, Edge *e1, SegmentIntersector *si);
00055 };
00056 
00057 } 
00058 } 
00059 } 
00060 
00061 #endif // GEOS_GEOMGRAPH_INDEX_SIMPLEEDGESETINTERSECTOR_H
00062 
00063 
00064 
00065 
00066 
00067 
00068 
00069