File failed to load: https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.3/config/TeX-MML-AM_CHTML/MathJax.js
DGtal 2.0.0
DGtal::DefaultConstImageRange< TImage > Class Template Reference

Aim: model of CConstBidirectionalRangeFromPoint that adapts the domain of an image in order to iterate over the values associated to its domain points (in a read-only as well as a write-only manner). More...

#include <DGtal/images/DefaultConstImageRange.h>

Inheritance diagram for DGtal::DefaultConstImageRange< TImage >:
[legend]

Public Types

typedef TImage::Domain Domain
typedef TImage::Point Point
typedef TImage::Value Value
typedef ConstIteratorAdapter< typename Domain::ConstIterator, TImage, ValueConstIterator
typedef boost::reverse_iterator< ConstIteratorConstReverseIterator

Public Member Functions

 BOOST_CONCEPT_ASSERT ((concepts::CTrivialConstImage< TImage >))
 BOOST_CONCEPT_ASSERT ((concepts::CDomain< Domain >))
 constant iterator types
 DefaultConstImageRange (ConstAlias< TImage > aImage)
 DefaultConstImageRange (const DefaultConstImageRange &other)
DefaultConstImageRangeoperator= (const DefaultConstImageRange &other)
 ~DefaultConstImageRange ()
bool isValid () const
ConstIterator begin () const
ConstIterator begin (const Point &aPoint) const
ConstIterator end () const
ConstReverseIterator rbegin () const
ConstReverseIterator rbegin (const Point &aPoint) const
ConstReverseIterator rend () const

Private Attributes

const TImage * myImagePtr

Detailed Description

template<typename TImage>
class DGtal::DefaultConstImageRange< TImage >

Aim: model of CConstBidirectionalRangeFromPoint that adapts the domain of an image in order to iterate over the values associated to its domain points (in a read-only as well as a write-only manner).

Template Parameters
TImagea model of CConstImage mapping points to values

NB: the underlying image is stored as an aliasing pointer in order to avoid copies. As a consequence the pointed object must exist and must not be deleted during the use of any instance of this class.

Definition at line 77 of file DefaultConstImageRange.h.

Member Typedef Documentation

◆ ConstIterator

template<typename TImage>
typedef ConstIteratorAdapter<typename Domain::ConstIterator,TImage,Value> DGtal::DefaultConstImageRange< TImage >::ConstIterator

Definition at line 91 of file DefaultConstImageRange.h.

◆ ConstReverseIterator

template<typename TImage>
typedef boost::reverse_iterator<ConstIterator> DGtal::DefaultConstImageRange< TImage >::ConstReverseIterator

Definition at line 92 of file DefaultConstImageRange.h.

◆ Domain

template<typename TImage>
typedef TImage::Domain DGtal::DefaultConstImageRange< TImage >::Domain

Definition at line 85 of file DefaultConstImageRange.h.

◆ Point

template<typename TImage>
typedef TImage::Point DGtal::DefaultConstImageRange< TImage >::Point

Definition at line 86 of file DefaultConstImageRange.h.

◆ Value

template<typename TImage>
typedef TImage::Value DGtal::DefaultConstImageRange< TImage >::Value

Definition at line 87 of file DefaultConstImageRange.h.

Constructor & Destructor Documentation

◆ DefaultConstImageRange() [1/2]

template<typename TImage>
DGtal::DefaultConstImageRange< TImage >::DefaultConstImageRange ( ConstAlias< TImage > aImage)
inline

Standard constructor from an image.

Parameters
aImageany image.

Definition at line 101 of file DefaultConstImageRange.h.

102 : myImagePtr(&aImage) {}
Aim: model of CConstBidirectionalRangeFromPoint that adapts the domain of an image in order to iterat...

◆ DefaultConstImageRange() [2/2]

template<typename TImage>
DGtal::DefaultConstImageRange< TImage >::DefaultConstImageRange ( const DefaultConstImageRange< TImage > & other)
inline

Copy constructor.

Parameters
otherthe iterator to clone.

Definition at line 108 of file DefaultConstImageRange.h.

◆ ~DefaultConstImageRange()

template<typename TImage>
DGtal::DefaultConstImageRange< TImage >::~DefaultConstImageRange ( )
inline

Destructor. Does nothing.

Definition at line 128 of file DefaultConstImageRange.h.

128{}

Member Function Documentation

◆ begin() [1/2]

template<typename TImage>
ConstIterator DGtal::DefaultConstImageRange< TImage >::begin ( ) const
inline

Iterator service.

Returns
begin iterator

Definition at line 152 of file DefaultConstImageRange.h.

152 {
153 Domain d = myImagePtr->domain();
154 return ConstIterator( d.begin(), *myImagePtr );
155 }
ConstIteratorAdapter< typename Domain::ConstIterator, TImage, Value > ConstIterator

Referenced by DGtal::DefaultConstImageRange< Self >::rend().

◆ begin() [2/2]

template<typename TImage>
ConstIterator DGtal::DefaultConstImageRange< TImage >::begin ( const Point & aPoint) const
inline

Iterator service.

Parameters
aPointany point
Returns
begin iterator

Definition at line 162 of file DefaultConstImageRange.h.

162 {
163 Domain d = myImagePtr->domain();
165 }

◆ BOOST_CONCEPT_ASSERT() [1/2]

template<typename TImage>
DGtal::DefaultConstImageRange< TImage >::BOOST_CONCEPT_ASSERT ( (concepts::CDomain< Domain >) )

constant iterator types

◆ BOOST_CONCEPT_ASSERT() [2/2]

template<typename TImage>
DGtal::DefaultConstImageRange< TImage >::BOOST_CONCEPT_ASSERT ( (concepts::CTrivialConstImage< TImage >) )

◆ end()

template<typename TImage>
ConstIterator DGtal::DefaultConstImageRange< TImage >::end ( ) const
inline

Iterator service.

Returns
end iterator

Definition at line 171 of file DefaultConstImageRange.h.

171 {
172 Domain d = myImagePtr->domain();
173 return ConstIterator( d.end(), *myImagePtr );
174 }

Referenced by DGtal::DefaultConstImageRange< Self >::rbegin().

◆ isValid()

template<typename TImage>
bool DGtal::DefaultConstImageRange< TImage >::isValid ( ) const
inline

Checks the validity/consistency of the object.

Returns
'true' if the object is valid, 'false' otherwise.

Definition at line 134 of file DefaultConstImageRange.h.

134{ return true; }

◆ operator=()

template<typename TImage>
DefaultConstImageRange & DGtal::DefaultConstImageRange< TImage >::operator= ( const DefaultConstImageRange< TImage > & other)
inline

Assignment.

Parameters
otherthe iterator to copy.
Returns
a reference on 'this'.

Definition at line 116 of file DefaultConstImageRange.h.

117 {
118 if ( this != &other )
119 {
121 }
122 return *this;
123 }

◆ rbegin() [1/2]

template<typename TImage>
ConstReverseIterator DGtal::DefaultConstImageRange< TImage >::rbegin ( ) const
inline

Iterator service.

Returns
rbegin iterator

Definition at line 180 of file DefaultConstImageRange.h.

180 {
181 return ConstReverseIterator(this->end());
182 }
boost::reverse_iterator< ConstIterator > ConstReverseIterator

◆ rbegin() [2/2]

template<typename TImage>
ConstReverseIterator DGtal::DefaultConstImageRange< TImage >::rbegin ( const Point & aPoint) const
inline

Iterator service.

Parameters
aPointany point
Returns
rbegin iterator

Definition at line 189 of file DefaultConstImageRange.h.

189 {
190 Domain d = myImagePtr->domain();
192 if ( itOnPts != d.end() ) ++itOnPts;
195 }

◆ rend()

template<typename TImage>
ConstReverseIterator DGtal::DefaultConstImageRange< TImage >::rend ( ) const
inline

Iterator service.

Returns
rend iterator

Definition at line 201 of file DefaultConstImageRange.h.

201 {
202 return ConstReverseIterator(this->begin());
203 }

Field Documentation

◆ myImagePtr

template<typename TImage>
const TImage* DGtal::DefaultConstImageRange< TImage >::myImagePtr
private

Aliasing pointer on the underlying image

Definition at line 143 of file DefaultConstImageRange.h.

Referenced by DGtal::DefaultConstImageRange< Self >::operator=().


The documentation for this class was generated from the following file: