Get List Of Faces Around A Given Vertex

Synopsis

Get the list of faces around a given vertex.

Results

Results:

79
1961
2036
1960
1

These faces are visualized in the figures below.

Selected faces.

The selected faces around the given vertex are highlighted in pink.

Interactive view of the selected faces

Code

C++

#include "itkMeshFileReader.h"
#include "itkQuadEdgeMesh.h"

int
main(int argc, char * argv[])
{
  if (argc != 3)
  {
    std::cerr << "Usage: " << std::endl;
    std::cerr << argv[0];
    std::cerr << " <InputFileName> <VertexId>";
    std::cerr << std::endl;
    return EXIT_FAILURE;
  }

  constexpr unsigned int Dimension = 3;

  using PixelType = double;
  using MeshType = itk::QuadEdgeMesh<PixelType, Dimension>;

  using ReaderType = itk::MeshFileReader<MeshType>;
  ReaderType::Pointer reader = ReaderType::New();
  reader->SetFileName(argv[1]);
  try
  {
    reader->Update();
  }
  catch (itk::ExceptionObject & e)
  {
    std::cerr << e.what() << std::endl;
    return EXIT_FAILURE;
  }

  MeshType::Pointer mesh = reader->GetOutput();

  MeshType::PointIdentifier id = std::stoi(argv[2]);

  MeshType::QEType * qe = mesh->FindEdge(id);

  MeshType::QEType * temp = qe;
  do
  {
    std::cout << temp->GetLeft() << std::endl;
    temp = temp->GetOnext();
  } while (qe != temp);

  return EXIT_SUCCESS;
}

Classes demonstrated