00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016 #ifndef GEOS_OP_OVERLAY_POINTBUILDER_H
00017 #define GEOS_OP_OVERLAY_POINTBUILDER_H
00018
00019 #include <geos/geom/GeometryFactory.h>
00020 #include <geos/operation/overlay/OverlayOp.h>
00021
00022 #include <vector>
00023
00024
00025 namespace geos {
00026 namespace geom {
00027 class GeometryFactory;
00028 class Point;
00029 }
00030 namespace geomgraph {
00031 class Node;
00032 }
00033 namespace algorithm {
00034 class PointLocator;
00035 }
00036 namespace operation {
00037 namespace overlay {
00038 class OverlayOp;
00039 }
00040 }
00041 }
00042
00043 namespace geos {
00044 namespace operation {
00045 namespace overlay {
00046
00050 class PointBuilder {
00051 private:
00052
00053 OverlayOp *op;
00054 const geom::GeometryFactory *geometryFactory;
00055 void extractNonCoveredResultNodes(OverlayOp::OpCode opCode);
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067
00068 void filterCoveredNodeToPoint(const geomgraph::Node *);
00069
00073 std::vector<geom::Point*> *resultPointList;
00074
00075 public:
00076
00077 PointBuilder(OverlayOp *newOp,
00078 const geom::GeometryFactory *newGeometryFactory,
00079 algorithm::PointLocator *newPtLocator=NULL)
00080 :
00081 op(newOp),
00082 geometryFactory(newGeometryFactory),
00083 resultPointList(new std::vector<geom::Point *>())
00084 {}
00085
00090 std::vector<geom::Point*>* build(OverlayOp::OpCode opCode);
00091 };
00092
00093
00094 }
00095 }
00096 }
00097
00098 #endif // ndef GEOS_OP_OVERLAY_POINTBUILDER_H
00099
00100
00101
00102
00103
00104
00105
00106
00107
00108
00109