ITK  5.0.0
Insight Segmentation and Registration Toolkit
WikiExamples/Iterators/ImageBoundaryFacesCalculator.cxx
#include "itkImage.h"
using ImageType = itk::Image<unsigned char, 2>;
static void CreateImage(ImageType::Pointer image);
int main(int, char*[])
{
ImageType::Pointer image = ImageType::New();
CreateImage(image);
radius.Fill(1);
using FaceCalculatorType = itk::NeighborhoodAlgorithm
FaceCalculatorType faceCalculator;
FaceCalculatorType::FaceListType faceList;
faceList = faceCalculator(image, image->GetLargestPossibleRegion(),
radius);
FaceCalculatorType::FaceListType::iterator faceListIterator;
for ( faceListIterator=faceList.begin(); faceListIterator != faceList.end(); ++faceListIterator)
{
IteratorType iterator(image,*faceListIterator);
while(!iterator.IsAtEnd())
{
std::cout << iterator.GetIndex() << " ";
++iterator;
}
std::cout << std::endl;
}
return EXIT_SUCCESS;
}
void CreateImage(ImageType::Pointer image)
{
start[0] = 0;
start[1] = 0;
size[0] = 5;
size[1] = 5;
region.SetSize(size);
region.SetIndex(start);
image->SetRegions(region);
image->Allocate();
itk::ImageRegionIterator<ImageType> imageIterator(image,region);
while(!imageIterator.IsAtEnd())
{
imageIterator.Set(2);
++imageIterator;
}
}