/********************************************************************** * * GEOS - Geometry Engine Open Source * http://geos.osgeo.org * * Copyright (C) 2011 Sandro Santilli * Copyright (C) 2001-2002 Vivid Solutions Inc. * Copyright (C) 2005 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: geom/MultiPoint.java r320 (JTS-1.12) * **********************************************************************/ #pragma once #include #include // for inheritance #include // for Dimension::DimensionType #include // for covariant return type #include #include namespace geos { namespace geom { // geos::geom class Coordinate; } } namespace geos { namespace geom { // geos::geom #ifdef _MSC_VER #pragma warning(push) #pragma warning(disable:4250) // T1 inherits T2 via dominance #endif /** * Models a collection of Point objects. * * Any collection of Points is a valid MultiPoint. */ class GEOS_DLL MultiPoint: public GeometryCollection { public: friend class GeometryFactory; ~MultiPoint() override = default; /// Returns point dimension (0) Dimension::DimensionType getDimension() const override; bool isDimensionStrict(Dimension::DimensionType d) const override { return d == Dimension::P; } bool hasDimension(Dimension::DimensionType d) const override { return d == Dimension::P; } /// Returns Dimension::False (Point has no boundary) int getBoundaryDimension() const override; /** \brief * Gets the boundary of this geometry. * * Zero-dimensional geometries have no boundary by definition, * so an empty GeometryCollection is returned. * * @return an empty GeometryCollection * @see Geometry#getBoundary */ std::unique_ptr getBoundary() const override; const Point* getGeometryN(std::size_t n) const override; std::string getGeometryType() const override; GeometryTypeId getGeometryTypeId() const override; std::unique_ptr clone() const { return std::unique_ptr(cloneImpl()); } std::unique_ptr reverse() const { return std::unique_ptr(reverseImpl()); } protected: /** * \brief Constructs a MultiPoint. * * @param newPoints * the Points for this MultiPoint, * or null or an empty array to create the empty * geometry. * Elements may be empty Points, * but not nulls. * * Constructed object will take ownership of * the vector and its elements. * * @param newFactory * The GeometryFactory used to create this geometry * Caller must keep the factory alive for the life-time * of the constructed MultiPoint. */ MultiPoint(std::vector> && newPoints, const GeometryFactory& newFactory); MultiPoint(std::vector> && newPoints, const GeometryFactory& newFactory); MultiPoint(const MultiPoint& mp): GeometryCollection(mp) {} MultiPoint* cloneImpl() const override { return new MultiPoint(*this); } MultiPoint* reverseImpl() const override { return new MultiPoint(*this); } const CoordinateXY* getCoordinateN(std::size_t n) const; int getSortIndex() const override { return SORTINDEX_MULTIPOINT; }; }; #ifdef _MSC_VER #pragma warning(pop) #endif } // namespace geos::geom } // namespace geos