ITK  4.0.0
Insight Segmentation and Registration Toolkit
itkMeshToMeshFilter.h
Go to the documentation of this file.
00001 /*=========================================================================
00002  *
00003  *  Copyright Insight Software Consortium
00004  *
00005  *  Licensed under the Apache License, Version 2.0 (the "License");
00006  *  you may not use this file except in compliance with the License.
00007  *  You may obtain a copy of the License at
00008  *
00009  *         http://www.apache.org/licenses/LICENSE-2.0.txt
00010  *
00011  *  Unless required by applicable law or agreed to in writing, software
00012  *  distributed under the License is distributed on an "AS IS" BASIS,
00013  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
00014  *  See the License for the specific language governing permissions and
00015  *  limitations under the License.
00016  *
00017  *=========================================================================*/
00018 /*=========================================================================
00019  *
00020  *  Portions of this file are subject to the VTK Toolkit Version 3 copyright.
00021  *
00022  *  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
00023  *
00024  *  For complete copyright, license and disclaimer of warranty information
00025  *  please refer to the NOTICE file at the top of the ITK source tree.
00026  *
00027  *=========================================================================*/
00028 #ifndef __itkMeshToMeshFilter_h
00029 #define __itkMeshToMeshFilter_h
00030 
00031 #include "itkMeshSource.h"
00032 
00033 namespace itk
00034 {
00046 template< class TInputMesh, class TOutputMesh >
00047 class ITK_EXPORT MeshToMeshFilter:public MeshSource< TOutputMesh >
00048 {
00049 public:
00051   typedef MeshToMeshFilter           Self;
00052   typedef MeshSource< TOutputMesh >  Superclass;
00053   typedef SmartPointer< Self >       Pointer;
00054   typedef SmartPointer< const Self > ConstPointer;
00055 
00057   itkNewMacro(Self);
00058 
00060   itkTypeMacro(MeshToMeshFilter, MeshSource);
00061 
00063   typedef TInputMesh                       InputMeshType;
00064   typedef typename InputMeshType::Pointer  InputMeshPointer;
00065   typedef TOutputMesh                      OutputMeshType;
00066   typedef typename OutputMeshType::Pointer OutputMeshPointer;
00067 
00069   using Superclass::SetInput;
00070   void SetInput(const InputMeshType *input);
00071 
00073   const InputMeshType * GetInput(void) const;
00074 
00075   const InputMeshType * GetInput(unsigned int idx) const;
00076 
00077 protected:
00078   MeshToMeshFilter();
00079   ~MeshToMeshFilter() {}
00080 
00081   void CopyInputMeshToOutputMeshPoints();
00082 
00083   void CopyInputMeshToOutputMeshPointData();
00084 
00085   void CopyInputMeshToOutputMeshCellLinks();
00086 
00087   void CopyInputMeshToOutputMeshCells();
00088 
00089   void CopyInputMeshToOutputMeshCellData();
00090 
00091 private:
00092   MeshToMeshFilter(const Self &); //purposely not implemented
00093   void operator=(const Self &);   //purposely not implemented
00094 };
00095 } // end namespace itk
00096 
00097 #ifndef ITK_MANUAL_INSTANTIATION
00098 #include "itkMeshToMeshFilter.hxx"
00099 #endif
00100 
00101 #endif
00102