All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
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 "../common/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  : MultiSurface(rhs)
51 {
52 }
53 
55 {
56 #ifdef TERRALIB_GEOS_ENABLED
57  std::auto_ptr<geos::geom::Geometry> thisGeom(GEOSWriter::write(this));
58 
59  geos::algorithm::CentroidArea c;
60 
61  c.add(thisGeom.get());
62 
63  geos::geom::Coordinate coord;
64 
65  if(c.getCentroid(coord))
66  {
67  Point* pt = new Point(coord.x, coord.y, m_srid, 0);
68 
69  return pt;
70  }
71 
72  return 0;
73 
74 #else
75  throw te::common::Exception(TE_TR("getCentroid routine is supported by GEOS! Please, enable the GEOS support."));
76 #endif
77 }
78 
80 {
81  te::gm::Point * p = getCentroid();
82 
83  if(p)
84  {
85  te::gm::Coord2D* coord = new te::gm::Coord2D(p->getX(), p->getY());
86 
87  delete p;
88 
89  return coord;
90  }
91 
92  return 0;
93 }
94 
96 {
98 
99  return *this;
100 }
101 
103 {
104  return new MultiPolygon(*this);
105 }
106 
107 const std::string& te::gm::MultiPolygon::getGeometryType() const throw()
108 {
109  return sm_typeName;
110 }
111 
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.
Definition: Enums.h:41
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:347
static const std::string sm_typeName
Geometry type name for MultiPolygon.
Definition: MultiPolygon.h:146
virtual MultiSurface & operator=(const MultiSurface &rhs)
Assignment operator.
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:150
A point with x and y coordinate values.
Definition: Point.h:50
An Envelope defines a 2D rectangular region.
Definition: Envelope.h:51
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
This class is designed to declare objects to be thrown as exceptions by TerraLib. ...
Definition: Exception.h:58
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
Point * getCentroid() const
MultiPolygon & operator=(const MultiPolygon &rhs)
Assignment operator.
const double & getX() const
It returns the Point x-coordinate value.
Definition: Point.h:136
Coord2D * getCentroidCoord() const