Feature.h
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/edit/Feature.h
22 
23  \brief This class represents a geographic feature.
24 */
25 
26 #ifndef __TERRALIB_EDIT_INTERNAL_FEATURE_H
27 #define __TERRALIB_EDIT_INTERNAL_FEATURE_H
28 
29 // TerraLib
30 #include "Config.h"
31 #include "Utils.h"
32 
33 // STL
34 #include <map>
35 
36 namespace te
37 {
38 // Forward declarations
39  namespace da
40  {
41  class ObjectId;
42  }
43 
44  namespace dt
45  {
46  class AbstractData;
47  }
48 
49  namespace gm
50  {
51  class Geometry;
52  }
53 
54  namespace edit
55  {
57  {
58  public:
59 
60  Feature();
61 
63 
65 
66  ~Feature();
67 
68  void set(te::da::ObjectId* id, te::gm::Geometry* geom, OperationType operation);
69 
70  void setId(te::da::ObjectId* id);
71 
72  void setGeometry(te::gm::Geometry* geom);
73 
74  void setData(const std::map<std::size_t, te::dt::AbstractData*>& data);
75 
76  void setOperation(OperationType operation);
77 
78  te::da::ObjectId* getId() const;
79 
80  te::gm::Geometry* getGeometry() const;
81 
82  const std::map<std::size_t, te::dt::AbstractData*>& getData() const;
83 
84  OperationType getOperationType() const;
85 
86  bool isEquals(te::da::ObjectId* id);
87 
88  Feature* clone() const;
89 
90  private:
91 
94  std::map<std::size_t, te::dt::AbstractData*> m_data;
96 
97  };
98 
99  } // end namespace edit
100 } // end namespace te
101 
102 #endif // __TERRALIB_EDIT_INTERNAL_FEATURE_H
OperationType m_operationType
Definition: Feature.h:95
te::gm::Geometry * m_geom
Definition: Feature.h:93
#define TEEDITEXPORT
You can use this macro in order to export/import classes and functions from this module.
Definition: Config.h:64
std::map< std::size_t, te::dt::AbstractData * > m_data
Definition: Feature.h:94
This class represents an unique id for a data set element.
Definition: ObjectId.h:47
URI C++ Library.
Configuration flags for the TerraLib Edit module.
Utility functions for TerraLib Edit module.
Geometry is the root class of the geometries hierarchy, it follows OGC and ISO standards.
Definition: Geometry.h:73
OperationType
Definition: Utils.h:88
te::da::ObjectId * m_id
Definition: Feature.h:92