All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
PointZM.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/PointZM.cpp
22 
23  \brief A point with a z-coordinate value and an associated measurement.
24 */
25 
26 // TerraLib
27 #include "Exception.h"
28 #include "PointZM.h"
29 
30 // STL
31 #include <cassert>
32 
33 te::gm::PointZM::PointZM(const double& x, const double& y, const double& z, const double& m, int srid, Envelope* mbr)
34  : Point(PointZMType, srid, mbr, x, y),
35  m_z(z),
36  m_m(m)
37 {
38 }
39 
41  : Point(PointZMType, srid, mbr),
42  m_z(sm_notNumber),
43  m_m(sm_notNumber)
44 {
45 }
46 
48  : Point(rhs),
49  m_z(rhs.m_z),
50  m_m(rhs.m_m)
51 {
52 }
53 
55 {
56  if(this != &rhs)
57  {
58  Point::operator=(rhs);
59 
60  m_z = rhs.m_z;
61  m_m = rhs.m_m;
62  }
63 
64  return *this;
65 }
66 
68 {
69  return new PointZM(*this);
70 }
71 
72 te::gm::Geometry* te::gm::PointZM::locateBetween(const double& /*mStart*/, const double& /*mEnd*/) const throw(Exception)
73 {
74  return 0;
75 }
76 
77 
78 
PointZM & operator=(const PointZM &rhs)
Assignment operator.
Definition: PointZM.cpp:54
te::dt::AbstractData * clone() const
It clones the point.
Definition: PointZM.cpp:67
Geometry * locateBetween(const double &mStart, const double &mEnd) const
It returns a derived geometry collection value according to the range of coordinate values inclusivel...
Definition: PointZM.cpp:72
A point with a z-coordinate value and an associated measurement.
Definition: PointZM.h:51
virtual Point & operator=(const Point &rhs)
Assignment operator.
Definition: Point.cpp:58
PointZM(const double &x, const double &y, const double &z, const double &m, int srid=0, Envelope *mbr=0)
It initializes the point with the specified spatial reference system id and envelope.
Definition: PointZM.cpp:33
A point with x and y coordinate values.
Definition: Point.h:50
An Envelope defines a 2D rectangular region.
Definition: Envelope.h:51
A base class for values that can be retrieved from the data access module.
Definition: AbstractData.h:57
Geometry is the root class of the geometries hierarchy, it follows OGC and ISO standards.
Definition: Geometry.h:73
An exception class for the Geometry module.
double m_z
The Point z-coordinate value.
Definition: PointZM.h:185
A point with a z-coordinate value and an associated measurement.
double m_m
The Point m-coordinate value.
Definition: PointZM.h:186