ITK  6.0.0
Insight Toolkit
Public Types | Public Member Functions | Static Public Member Functions | Static Public Attributes | Protected Attributes | List of all members
itk::ImageConstIterator< TImage > Class Template Reference

#include <itkImageConstIterator.h>

Detailed Description

template<typename TImage>
class itk::ImageConstIterator< TImage >

A multi-dimensional image iterator templated over image type.

ImageConstIterator is a templated class to represent a multi-dimensional iterator. ImageConstIterator is templated over the type of the image to be iterated over.

ImageConstIterator is a base class for all the image iterators. It provides the basic construction and comparison operations. However, it does not provide mechanisms for moving the iterator. A subclass of ImageConstIterator must be used to move the iterator.

ImageConstIterator is a multi-dimensional iterator, requiring more information be specified before the iterator can be used than conventional iterators. Whereas the std::vector::iterator from the STL only needs to be passed a pointer to establish the iterator, the multi-dimensional image iterator needs a pointer, the size of the buffer, the size of the region, the start index of the buffer, and the start index of the region. To gain access to this information, ImageConstIterator holds a reference to the image over which it is traversing.

ImageConstIterator assumes a particular layout of the image data. In particular, the data is arranged in a 1D array as if it were [][][][slice][row][col] with Index[0] = col, Index[1] = row, Index[2] = slice, etc.

MORE INFORMATION
For a complete description of the ITK Image Iterators and their API, please see the Iterators chapter in the ITK Software Guide. The ITK Software Guide is available in print and as a free .pdf download from https://www.itk.org.
See also
ImageConstIterator
ConditionalConstIterator
ConstNeighborhoodIterator
ConstShapedNeighborhoodIterator
ConstSliceIterator
CorrespondenceDataStructureIterator
FloodFilledFunctionConditionalConstIterator
FloodFilledImageFunctionConditionalConstIterator
FloodFilledImageFunctionConditionalIterator
FloodFilledSpatialFunctionConditionalConstIterator
FloodFilledSpatialFunctionConditionalIterator
ImageConstIterator
ImageConstIteratorWithIndex
ImageIterator
ImageIteratorWithIndex
ImageLinearConstIteratorWithIndex
ImageLinearIteratorWithIndex
ImageRandomConstIteratorWithIndex
ImageRandomIteratorWithIndex
ImageRegionConstIterator
ImageRegionConstIteratorWithIndex
ImageRegionExclusionConstIteratorWithIndex
ImageRegionExclusionIteratorWithIndex
ImageRegionIterator
ImageRegionIteratorWithIndex
ImageRegionReverseConstIterator
ImageRegionReverseIterator
ImageReverseConstIterator
ImageReverseIterator
ImageSliceConstIteratorWithIndex
ImageSliceIteratorWithIndex
NeighborhoodIterator
PathConstIterator
PathIterator
ShapedNeighborhoodIterator
SliceIterator

Definition at line 84 of file itkImageConstIterator.h.

+ Inheritance diagram for itk::ImageConstIterator< TImage >:

Public Types

using AccessorFunctorType = typename TImage::AccessorFunctorType
 
using AccessorType = typename TImage::AccessorType
 
using ImageType = TImage
 
using IndexType = typename TImage::IndexType
 
using InternalPixelType = typename TImage::InternalPixelType
 
using OffsetType = typename TImage::OffsetType
 
using PixelContainer = typename TImage::PixelContainer
 
using PixelContainerPointer = typename PixelContainer::Pointer
 
using PixelType = typename TImage::PixelType
 
using RegionType = typename TImage::RegionType
 
using Self = ImageConstIterator
 
using SizeType = typename TImage::SizeType
 

Public Member Functions

PixelType Get () const
 
const ImageTypeGetImage () const
 
const IndexType GetIndex () const
 
virtual const char * GetNameOfClass () const
 
const RegionTypeGetRegion () const
 
void GoToBegin ()
 
void GoToEnd ()
 
 ImageConstIterator (const Self &it)
 
bool IsAtBegin () const
 
bool IsAtEnd () const
 
 ITK_UNEQUAL_OPERATOR_MEMBER_FUNCTION (Self)
 
bool operator< (const Self &it) const
 
bool operator<= (const Self &it) const
 
bool operator== (const Self &it) const
 
bool operator> (const Self &it) const
 
bool operator>= (const Self &it) const
 
virtual void SetIndex (const IndexType &ind)
 
virtual void SetRegion (const RegionType &region)
 
const PixelTypeValue () const
 
virtual ~ImageConstIterator ()=default
 
 ImageConstIterator ()
 
 ImageConstIterator (const ImageType *ptr, const RegionType &region)
 
Selfoperator= (const Self &it)
 

Static Public Member Functions

static unsigned int GetImageIteratorDimension ()
 

Static Public Attributes

static constexpr unsigned int ImageIteratorDimension = TImage::ImageDimension
 

Protected Attributes

OffsetValueType m_BeginOffset {}
 
const InternalPixelTypem_Buffer {}
 
OffsetValueType m_EndOffset {}
 
TImage::ConstWeakPointer m_Image {}
 
OffsetValueType m_Offset {}
 
AccessorType m_PixelAccessor {}
 
AccessorFunctorType m_PixelAccessorFunctor {}
 
RegionType m_Region {}
 

Member Typedef Documentation

◆ AccessorFunctorType

template<typename TImage>
using itk::ImageConstIterator< TImage >::AccessorFunctorType = typename TImage::AccessorFunctorType

Definition at line 129 of file itkImageConstIterator.h.

◆ AccessorType

template<typename TImage>
using itk::ImageConstIterator< TImage >::AccessorType = typename TImage::AccessorType

Accessor type that convert data between internal and external representations.

Definition at line 128 of file itkImageConstIterator.h.

◆ ImageType

template<typename TImage>
using itk::ImageConstIterator< TImage >::ImageType = TImage

Image type alias support

Definition at line 112 of file itkImageConstIterator.h.

◆ IndexType

template<typename TImage>
using itk::ImageConstIterator< TImage >::IndexType = typename TImage::IndexType

Index type alias support

Definition at line 100 of file itkImageConstIterator.h.

◆ InternalPixelType

template<typename TImage>
using itk::ImageConstIterator< TImage >::InternalPixelType = typename TImage::InternalPixelType

Internal Pixel Type

Definition at line 121 of file itkImageConstIterator.h.

◆ OffsetType

template<typename TImage>
using itk::ImageConstIterator< TImage >::OffsetType = typename TImage::OffsetType

Offset type alias support

Definition at line 106 of file itkImageConstIterator.h.

◆ PixelContainer

template<typename TImage>
using itk::ImageConstIterator< TImage >::PixelContainer = typename TImage::PixelContainer

PixelContainer type alias support. Used to refer to the container for the pixel data. While this was already typedef'ed in the superclass it needs to be redone here for this subclass to compile properly with gcc.

Definition at line 117 of file itkImageConstIterator.h.

◆ PixelContainerPointer

template<typename TImage>
using itk::ImageConstIterator< TImage >::PixelContainerPointer = typename PixelContainer::Pointer

Definition at line 118 of file itkImageConstIterator.h.

◆ PixelType

template<typename TImage>
using itk::ImageConstIterator< TImage >::PixelType = typename TImage::PixelType

External Pixel Type

Definition at line 124 of file itkImageConstIterator.h.

◆ RegionType

template<typename TImage>
using itk::ImageConstIterator< TImage >::RegionType = typename TImage::RegionType

Region type alias support

Definition at line 109 of file itkImageConstIterator.h.

◆ Self

template<typename TImage>
using itk::ImageConstIterator< TImage >::Self = ImageConstIterator

Standard class type aliases.

Definition at line 88 of file itkImageConstIterator.h.

◆ SizeType

template<typename TImage>
using itk::ImageConstIterator< TImage >::SizeType = typename TImage::SizeType

Size type alias support

Definition at line 103 of file itkImageConstIterator.h.

Constructor & Destructor Documentation

◆ ImageConstIterator() [1/3]

template<typename TImage>
itk::ImageConstIterator< TImage >::ImageConstIterator ( )
inline

Default Constructor. Need to provide a default constructor since we provide a copy constructor.

Definition at line 133 of file itkImageConstIterator.h.

◆ ~ImageConstIterator()

template<typename TImage>
virtual itk::ImageConstIterator< TImage >::~ImageConstIterator ( )
virtualdefault

Default Destructor.

◆ ImageConstIterator() [2/3]

template<typename TImage>
itk::ImageConstIterator< TImage >::ImageConstIterator ( const Self it)
inline

Copy Constructor. The copy constructor is provided to make sure the handle to the image is properly reference counted.

Definition at line 152 of file itkImageConstIterator.h.

◆ ImageConstIterator() [3/3]

template<typename TImage>
itk::ImageConstIterator< TImage >::ImageConstIterator ( const ImageType ptr,
const RegionType region 
)
inline

Constructor establishes an iterator to walk a particular image and a particular region of that image. Initializes the iterator at the begin of the region.

Definition at line 169 of file itkImageConstIterator.h.

Member Function Documentation

◆ Get()

template<typename TImage>
PixelType itk::ImageConstIterator< TImage >::Get ( ) const
inline

◆ GetImage()

template<typename TImage>
const ImageType* itk::ImageConstIterator< TImage >::GetImage ( ) const
inline

◆ GetImageIteratorDimension()

template<typename TImage>
static unsigned int itk::ImageConstIterator< TImage >::GetImageIteratorDimension ( )
inlinestatic

Get the dimension (size) of the index.

Definition at line 245 of file itkImageConstIterator.h.

◆ GetIndex()

template<typename TImage>
const IndexType itk::ImageConstIterator< TImage >::GetIndex ( ) const
inline

Get the index. This provides a read only reference to the index. This causes the index to be calculated from pointer arithmetic and is therefore an expensive operation.

See also
SetIndex

Definition at line 306 of file itkImageConstIterator.h.

Referenced by itk::ImageReverseConstIterator< TImage >::ImageReverseConstIterator(), and itk::ImageReverseConstIterator< TImage >::operator=().

◆ GetNameOfClass()

template<typename TImage>
virtual const char* itk::ImageConstIterator< TImage >::GetNameOfClass ( ) const
virtual

◆ GetRegion()

template<typename TImage>
const RegionType& itk::ImageConstIterator< TImage >::GetRegion ( ) const
inline

Get the region that this iterator walks. ImageConstIterators know the beginning and the end of the region of the image to iterate over.

Definition at line 322 of file itkImageConstIterator.h.

Referenced by itk::ImageReverseConstIterator< TImage >::ImageReverseConstIterator(), and itk::ImageReverseConstIterator< TImage >::operator=().

◆ GoToBegin()

template<typename TImage>
void itk::ImageConstIterator< TImage >::GoToBegin ( )
inline

Move an iterator to the beginning of the region. "Begin" is defined as the first pixel in the region.

Definition at line 353 of file itkImageConstIterator.h.

◆ GoToEnd()

template<typename TImage>
void itk::ImageConstIterator< TImage >::GoToEnd ( )
inline

Move an iterator to the end of the region. "End" is defined as one pixel past the last pixel of the region.

Definition at line 361 of file itkImageConstIterator.h.

◆ IsAtBegin()

template<typename TImage>
bool itk::ImageConstIterator< TImage >::IsAtBegin ( ) const
inline

Is the iterator at the beginning of the region? "Begin" is defined as the first pixel in the region.

Definition at line 369 of file itkImageConstIterator.h.

◆ IsAtEnd()

template<typename TImage>
bool itk::ImageConstIterator< TImage >::IsAtEnd ( ) const
inline

Is the iterator at the end of the region? "End" is defined as one pixel past the last pixel of the region.

Definition at line 377 of file itkImageConstIterator.h.

◆ ITK_UNEQUAL_OPERATOR_MEMBER_FUNCTION()

template<typename TImage>
itk::ImageConstIterator< TImage >::ITK_UNEQUAL_OPERATOR_MEMBER_FUNCTION ( Self  )

◆ operator<()

template<typename TImage>
bool itk::ImageConstIterator< TImage >::operator< ( const Self it) const
inline

Comparison operator. An iterator is "less than" another if it "points to" a lower memory location.

Definition at line 274 of file itkImageConstIterator.h.

◆ operator<=()

template<typename TImage>
bool itk::ImageConstIterator< TImage >::operator<= ( const Self it) const
inline

Comparison operator. An iterator is "less than" another if it "points to" a lower memory location.

Definition at line 264 of file itkImageConstIterator.h.

◆ operator=()

template<typename TImage>
Self& itk::ImageConstIterator< TImage >::operator= ( const Self it)
inline

operator= is provided to make sure the handle to the image is properly reference counted.

Definition at line 185 of file itkImageConstIterator.h.

Referenced by itk::ImageRegionConstIterator< ImageType >::ImageRegionConstIterator(), and itk::ImageScanlineConstIterator< TImage >::ImageScanlineConstIterator().

◆ operator==()

template<typename TImage>
bool itk::ImageConstIterator< TImage >::operator== ( const Self it) const
inline

Comparison operator. Two iterators are the same if they "point to" the same memory location

Definition at line 253 of file itkImageConstIterator.h.

◆ operator>()

template<typename TImage>
bool itk::ImageConstIterator< TImage >::operator> ( const Self it) const
inline

Comparison operator. An iterator is "greater than" another if it "points to" a higher location.

Definition at line 294 of file itkImageConstIterator.h.

◆ operator>=()

template<typename TImage>
bool itk::ImageConstIterator< TImage >::operator>= ( const Self it) const
inline

Comparison operator. An iterator is "greater than" another if it "points to" a higher location.

Definition at line 284 of file itkImageConstIterator.h.

◆ SetIndex()

template<typename TImage>
virtual void itk::ImageConstIterator< TImage >::SetIndex ( const IndexType ind)
inlinevirtual

Set the index. No bounds checking is performed.

See also
GetIndex

Reimplemented in itk::ImageRegionConstIterator< TImage >, itk::ImageRegionConstIterator< ImageType >, and itk::ImageScanlineConstIterator< TImage >.

Definition at line 314 of file itkImageConstIterator.h.

◆ SetRegion()

template<typename TImage>
virtual void itk::ImageConstIterator< TImage >::SetRegion ( const RegionType region)
inlinevirtual

Set the region of the image to iterate over.

Definition at line 206 of file itkImageConstIterator.h.

◆ Value()

template<typename TImage>
const PixelType& itk::ImageConstIterator< TImage >::Value ( ) const
inline

Return a const reference to the pixel This method will provide the fastest access to pixel data, but it will NOT support ImageAdaptors.

Definition at line 345 of file itkImageConstIterator.h.

Member Data Documentation

◆ ImageIteratorDimension

template<typename TImage>
constexpr unsigned int itk::ImageConstIterator< TImage >::ImageIteratorDimension = TImage::ImageDimension
staticconstexpr

Dimension of the image the iterator walks. This constant is needed so functions that are templated over image iterator type (as opposed to being templated over pixel type and dimension) can have compile time access to the dimension of the image that the iterator walks.

Definition at line 94 of file itkImageConstIterator.h.

◆ m_BeginOffset

template<typename TImage>
OffsetValueType itk::ImageConstIterator< TImage >::m_BeginOffset {}
protected

◆ m_Buffer

template<typename TImage>
const InternalPixelType* itk::ImageConstIterator< TImage >::m_Buffer {}
protected

◆ m_EndOffset

template<typename TImage>
OffsetValueType itk::ImageConstIterator< TImage >::m_EndOffset {}
protected

◆ m_Image

template<typename TImage>
TImage::ConstWeakPointer itk::ImageConstIterator< TImage >::m_Image {}
protected

◆ m_Offset

template<typename TImage>
OffsetValueType itk::ImageConstIterator< TImage >::m_Offset {}
protected

◆ m_PixelAccessor

template<typename TImage>
AccessorType itk::ImageConstIterator< TImage >::m_PixelAccessor {}
protected

◆ m_PixelAccessorFunctor

template<typename TImage>
AccessorFunctorType itk::ImageConstIterator< TImage >::m_PixelAccessorFunctor {}
protected

◆ m_Region

template<typename TImage>
RegionType itk::ImageConstIterator< TImage >::m_Region {}
protected

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