geometry/MultiPolygon.cpp
Go to the documentation of this file.
1 /* Copyright (C) 2008 National Institute For Space Research (INPE) - Brazil.
2 
3  This file is part of the TerraLib - a Framework for building GIS enabled applications.
4 
5  TerraLib is free software: you can redistribute it and/or modify
6  it under the terms of the GNU Lesser General Public License as published by
7  the Free Software Foundation, either version 3 of the License,
8  or (at your option) any later version.
9 
10  TerraLib is distributed in the hope that it will be useful,
11  but WITHOUT ANY WARRANTY; without even the implied warranty of
12  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  GNU Lesser General Public License for more details.
14 
15  You should have received a copy of the GNU Lesser General Public License
16  along with TerraLib. See COPYING. If not, write to
17  TerraLib Team at <terralib-team@terralib.org>.
18  */
19 
20 /*!
21  \file terralib/geometry/MultiPolygon.cpp
22 
23  \brief MultiPolygon is a MultiSurface whose elements are Polygons.
24 */
25 
26 // TerraLib
27 #include "../core/translator/Translator.h"
28 #include "GEOSWriter.h"
29 #include "MultiPolygon.h"
30 #include "Point.h"
31 
32 #ifdef TERRALIB_GEOS_ENABLED
33 // GEOS
34 #include <geos/algorithm/CentroidArea.h>
35 #include <geos/geom/MultiPolygon.h>
36 #endif
37 
38 // STL
39 #include <cassert>
40 
41 const std::string te::gm::MultiPolygon::sm_typeName("MultiPolygon");
42 
43 te::gm::MultiPolygon::MultiPolygon(std::size_t nGeom, GeomType t, int srid, Envelope* mbr)
44  : MultiSurface(nGeom, t, srid, mbr)
45 {
46  assert(t == MultiPolygonType || t == MultiPolygonZType || t == MultiPolygonMType || t == MultiPolygonZMType);
47 }
48 
50 
51  = default;
52 
54 {
55 #ifdef TERRALIB_GEOS_ENABLED
56  std::unique_ptr<geos::geom::Geometry> thisGeom(GEOSWriter::write(this));
57 
58  geos::algorithm::CentroidArea c;
59 
60  c.add(thisGeom.get());
61 
62  geos::geom::Coordinate coord;
63 
64  if(c.getCentroid(coord))
65  {
66  Point* pt = new Point(coord.x, coord.y, m_srid);
67 
68  return pt;
69  }
70 
71  return nullptr;
72 
73 #else
74  throw te::common::Exception(TE_TR("getCentroid routine is supported by GEOS! Please, enable the GEOS support."));
75 #endif
76 }
77 
79 {
81 
82  if(p)
83  {
84  te::gm::Coord2D* coord = new te::gm::Coord2D(p->getX(), p->getY());
85 
86  delete p;
87 
88  return coord;
89  }
90 
91  return nullptr;
92 }
93 
95  default;
96 
98 {
99  return new MultiPolygon(*this);
100 }
101 
102 const std::string& te::gm::MultiPolygon::getGeometryType() const throw()
103 {
104  return sm_typeName;
105 }
106 
MultiPolygon is a MultiSurface whose elements are Polygons.
Definition: MultiPolygon.h:50
GeomType
Each enumerated type is compatible with a Well-known Binary (WKB) type code.
int m_srid
The Spatial Reference System code associated to the Geometry.
MultiPolygon(std::size_t nGeom, GeomType t, int srid=0, Envelope *mbr=0)
It initializes the Geometry with the specified spatial reference system id and envelope.
A point with x and y coordinate values.
An utility struct for representing 2D coordinates.
Definition: Coord2D.h:40
#define TE_TR(message)
It marks a string in order to get translated.
Definition: Translator.h:242
static const std::string sm_typeName
Geometry type name for MultiPolygon.
Definition: MultiPolygon.h:146
const std::string & getGeometryType() const
The name of the Geometry subtype is: MultiPolygon.
const double & getY() const
It returns the Point y-coordinate value.
Definition: Point.h:152
A point with x and y coordinate values.
Definition: Point.h:50
An Envelope defines a 2D rectangular region.
te::gm::Polygon * p
MultiPolygon is a MultiSurface whose elements are Polygons.
A base class for values that can be retrieved from the data access module.
Definition: AbstractData.h:57
static geos::geom::Geometry * write(const Geometry *teGeom)
It reads a TerraLib geometry and make a GEOS geometry.
This class is designed to declare objects to be thrown as exceptions by TerraLib. ...
A class that converts a TerraLib geometry to a GEOS geometry.
te::dt::AbstractData * clone() const
It clones the multi polygon.
MultiSurface is a class that represents a 2-dimensional GeometryCollection whose elements are surface...
Definition: MultiSurface.h:54
MultiPolygon & operator=(const MultiPolygon &rhs)
Assignment operator.
const double & getX() const
It returns the Point x-coordinate value.
Definition: Point.h:138
Coord2D * getCentroidCoord() const