You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
110 lines
2.9 KiB
C
110 lines
2.9 KiB
C
|
1 month ago
|
/**********************************************************************
|
||
|
|
*
|
||
|
|
* 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.
|
||
|
|
*
|
||
|
|
***********************************************************************
|
||
|
|
*
|
||
|
|
* Last port: operation/overlay/PointBuilder.java rev. 1.16 (JTS-1.10)
|
||
|
|
*
|
||
|
|
**********************************************************************/
|
||
|
|
|
||
|
|
#ifndef GEOS_OP_OVERLAY_POINTBUILDER_H
|
||
|
|
#define GEOS_OP_OVERLAY_POINTBUILDER_H
|
||
|
|
|
||
|
|
#include <geos/export.h>
|
||
|
|
|
||
|
|
#include <geos/geom/GeometryFactory.h> // for inlines
|
||
|
|
#include <geos/operation/overlay/OverlayOp.h> // for OpCode enum
|
||
|
|
#include <geos/util.h>
|
||
|
|
|
||
|
|
#include <vector>
|
||
|
|
|
||
|
|
// Forward declarations
|
||
|
|
namespace geos {
|
||
|
|
namespace geom {
|
||
|
|
class GeometryFactory;
|
||
|
|
class Point;
|
||
|
|
}
|
||
|
|
namespace geomgraph {
|
||
|
|
class Node;
|
||
|
|
}
|
||
|
|
namespace algorithm {
|
||
|
|
class PointLocator;
|
||
|
|
}
|
||
|
|
namespace operation {
|
||
|
|
namespace overlay {
|
||
|
|
class OverlayOp;
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
namespace geos {
|
||
|
|
namespace operation { // geos::operation
|
||
|
|
namespace overlay { // geos::operation::overlay
|
||
|
|
|
||
|
|
/** \brief
|
||
|
|
* Constructs geom::Point s from the nodes of an overlay graph.
|
||
|
|
*/
|
||
|
|
class GEOS_DLL PointBuilder {
|
||
|
|
private:
|
||
|
|
|
||
|
|
OverlayOp* op;
|
||
|
|
const geom::GeometryFactory* geometryFactory;
|
||
|
|
void extractNonCoveredResultNodes(OverlayOp::OpCode opCode);
|
||
|
|
|
||
|
|
/*
|
||
|
|
* Converts non-covered nodes to Point objects and adds them to
|
||
|
|
* the result.
|
||
|
|
*
|
||
|
|
* A node is covered if it is contained in another element Geometry
|
||
|
|
* with higher dimension (e.g. a node point might be contained in
|
||
|
|
* a polygon, in which case the point can be eliminated from
|
||
|
|
* the result).
|
||
|
|
*
|
||
|
|
* @param n the node to test
|
||
|
|
*/
|
||
|
|
void filterCoveredNodeToPoint(const geomgraph::Node*);
|
||
|
|
|
||
|
|
/// Allocated a construction time, but not owned.
|
||
|
|
/// Make sure you take ownership of it, getting
|
||
|
|
/// it from build()
|
||
|
|
std::vector<geom::Point*>* resultPointList;
|
||
|
|
|
||
|
|
PointBuilder(const PointBuilder&) = delete;
|
||
|
|
PointBuilder& operator=(const PointBuilder&) = delete;
|
||
|
|
|
||
|
|
public:
|
||
|
|
|
||
|
|
PointBuilder(OverlayOp* newOp,
|
||
|
|
const geom::GeometryFactory* newGeometryFactory,
|
||
|
|
algorithm::PointLocator* newPtLocator = nullptr)
|
||
|
|
:
|
||
|
|
op(newOp),
|
||
|
|
geometryFactory(newGeometryFactory),
|
||
|
|
resultPointList(new std::vector<geom::Point *>())
|
||
|
|
{
|
||
|
|
::geos::ignore_unused_variable_warning(newPtLocator);
|
||
|
|
}
|
||
|
|
|
||
|
|
/**
|
||
|
|
* @return a list of the Points in the result of the specified
|
||
|
|
* overlay operation
|
||
|
|
*/
|
||
|
|
std::vector<geom::Point*>* build(OverlayOp::OpCode opCode);
|
||
|
|
};
|
||
|
|
|
||
|
|
|
||
|
|
} // namespace geos::operation::overlay
|
||
|
|
} // namespace geos::operation
|
||
|
|
} // namespace geos
|
||
|
|
|
||
|
|
#endif // ndef GEOS_OP_OVERLAY_POINTBUILDER_H
|