Skip to content
Snippets Groups Projects
otbPolyLineParametricPathWithValue.h 4.1 KiB
Newer Older
/*=========================================================================

  Program:   ORFEO Toolbox
  Language:  C++
  Date:      $Date$
  Version:   $Revision$
  Copyright (c) Centre National d'Etudes Spatiales. All rights reserved.
  See OTBCopyright.txt for details.
     This software is distributed WITHOUT ANY WARRANTY; without even
     the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
     PURPOSE.  See the above copyright notices for more information.

=========================================================================*/
#ifndef __otbPolyLineParametricPathWithValue_h
#define __otbPolyLineParametricPathWithValue_h
#if defined(__GNUC__) || defined(__clang__)
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wunused-parameter"
#include "itkPolyLineParametricPath.h"
#pragma GCC diagnostic pop
#else
#include "itkPolyLineParametricPath.h"
#endif

#include "itkMetaDataObject.h"
#include "otbRemoteSensingRegion.h"
#include "otbMacro.h"

namespace otb
{
/** \class PolyLineParametricPathWithValue
 *  \brief This class implement a PolyLineParametricPath for which a value can be set.
 * The value is stored in the itk::MetaDataDictionary.
 * The precision of the value can be set.
 * \sa itk::PolyLineParametricPath.
 *
 * \ingroup OTBVectorDataBase
OTB Bot's avatar
OTB Bot committed
template <class TValue, unsigned int VDimension = 2>
class ITK_EXPORT PolyLineParametricPathWithValue
  : public itk::PolyLineParametricPath<VDimension>
OTB Bot's avatar
OTB Bot committed
public:
OTB Bot's avatar
OTB Bot committed
  typedef PolyLineParametricPathWithValue         Self;
  typedef itk::PolyLineParametricPath<VDimension> Superclass;
  typedef itk::SmartPointer<Self>                 Pointer;
  typedef itk::SmartPointer<const Self>           ConstPointer;
  /** Type macro */
  itkNewMacro(Self);
  /** Creation through object factory macro */
  itkTypeMacro(PolyLineParametricPath, MySuperclass);
  /** Template parameters typedefs */
  typedef TValue ValueType;

  /** Derived typedefs */
OTB Bot's avatar
OTB Bot committed
  typedef typename Superclass::VertexType          VertexType;
  typedef typename Superclass::VertexListType      VertexListType;
  typedef typename Superclass::ContinuousIndexType ContinuousIndexType;
  typedef typename VertexListType::ConstIterator   VertexListConstIteratorType;

//   typedef itk::ImageRegion<2>                       RegionType;
OTB Bot's avatar
OTB Bot committed
  typedef otb::RemoteSensingRegion<double> RegionType;
  typedef typename RegionType::SizeType    SizeType;
  typedef typename RegionType::IndexType   IndexType;
OTB Bot's avatar
OTB Bot committed
  itkGetMacro(Key, std::string);

  void SetValue(ValueType value)
  {
OTB Bot's avatar
OTB Bot committed
    itk::MetaDataDictionary& dict = this->GetMetaDataDictionary();
    itk::EncapsulateMetaData<ValueType>(dict, m_Key, value);
  }

  ValueType GetValue(void) const
  {
OTB Bot's avatar
OTB Bot committed
    ValueType                      resp(0);
    const itk::MetaDataDictionary& dict = this->GetMetaDataDictionary();
    if (dict.HasKey(m_Key))
OTB Bot's avatar
OTB Bot committed
      {
      itk::ExposeMetaData<ValueType>(dict, m_Key, resp);
      }
OTB Bot's avatar
OTB Bot committed
      {
      itkGenericExceptionMacro(<< "Key " << m_Key << " not found in metadata dictionary !");
      }
    return resp;
  }

  /**
   * Return the path length (perimeter).
   * \return The length.
   */
  virtual double GetLength() const;
OTB Bot's avatar
OTB Bot committed
  virtual void  AddVertex(const ContinuousIndexType& vertex);
OTB Bot's avatar
OTB Bot committed
  /**
 * Compute the path bounding region.
 * \return The region.
 */
  virtual RegionType GetBoundingRegion(void) const;
OTB Bot's avatar
OTB Bot committed
  virtual ~PolyLineParametricPathWithValue() {}
  /**PrintSelf method */
  virtual void PrintSelf(std::ostream& os, itk::Indent indent) const;

  virtual void ComputeLength() const;
  virtual void ComputeBoundingRegion() const;
  virtual void Modified() const;
OTB Bot's avatar
OTB Bot committed
  PolyLineParametricPathWithValue(const Self &); //purposely not implemented
  void operator =(const Self&); //purposely not implemented
  std::string        m_Key;
  mutable double     m_Length;
  mutable bool       m_LengthIsValid;
  mutable RegionType m_BoundingRegion;
OTB Bot's avatar
OTB Bot committed
  mutable bool       m_BoundingRegionIsValid;
OTB Bot's avatar
OTB Bot committed
} // End namespace otb

#ifndef OTB_MANUAL_INSTANTIATION
#include "otbPolyLineParametricPathWithValue.txx"
#endif