All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
VectorizerPolygonStructure.cpp
Go to the documentation of this file.
1 /* Copyright (C) 2008-2013 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/raster/VectorizerPolygonStructure.cpp
22 
23  \brief A polygon container node class.
24 */
25 
26 // TerraLib
27 #include "TileIndexer.h"
29 
30 // STL
31 #include <iostream>
32 
34  : m_polygon(0, te::gm::PolygonType)
35 {
36  init();
37 }
38 
40  : m_polygon(0, te::gm::PolygonType)
41 {
42  init();
43 
44  reset(rhs.m_polygon, rhs.m_value, rhs.m_tileIndexerDY);
45 }
46 
48  : m_polygon(0, te::gm::PolygonType)
49 {
50  init();
51 
52  reset(p, v, tidy);
53 }
54 
56 {
57  clear();
58 }
59 
61 {
62  m_value = 0;
63  m_tileIndexerDY = 1.0;
64  m_indexer = 0;
65 }
66 
68 {
69  if(m_indexer)
70  delete m_indexer;
71 
72  init();
73 }
74 
75 void te::rst::VectorizerPolygonStructure::reset(const te::gm::Polygon& p, const int& v, const double& tidy)
76 {
77  clear();
78 
79  m_polygon = p;
80  m_value = v;
81  m_tileIndexerDY = tidy;
82 
83  m_indexer = new te::rst::TileIndexer(m_polygon, m_tileIndexerDY);
84 }
85 
87 {
88  reset(rhs.m_polygon, rhs.m_value, rhs.m_tileIndexerDY);
89 
90  return *this;
91 }
double m_tileIndexerDY
The polygon tile indexer Y Axis resolution.
Polygon tile indexing class for optmized geometrical relational tests.
Definition: TileIndexer.h:55
VectorizerPolygonStructure & operator=(const VectorizerPolygonStructure &rhs)
Assignment operator.
te::gm::Polygon m_polygon
The stored polygon instance.
A polygon container node class.
Polygon tile indexing class for optmized geometrical relational tests.
int m_value
The value (color) related to a polygon.
void reset(const te::gm::Polygon &p, const int &v, const double &tidy)
Reset the current instance.
Polygon is a subclass of CurvePolygon whose rings are defined by linear rings.
Definition: Polygon.h:50
A polygon container node class.