Main Page   Groups   Namespace List   Class Hierarchy   Alphabetical List   Compound List   File List   Namespace Members   Compound Members   File Members   Concepts

itkConvertPixelBuffer.h

Go to the documentation of this file.
00001 /*=========================================================================
00002 
00003   Program:   Insight Segmentation & Registration Toolkit
00004   Module:    $RCSfile: itkConvertPixelBuffer.h,v $
00005   Language:  C++
00006   Date:      $Date: 2009-08-11 12:45:11 $
00007   Version:   $Revision: 1.12 $
00008 
00009   Copyright (c) Insight Software Consortium. All rights reserved.
00010   See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.htm for details.
00011 
00012      This software is distributed WITHOUT ANY WARRANTY; without even 
00013      the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR 
00014      PURPOSE.  See the above copyright notices for more information.
00015 
00016 =========================================================================*/
00017 #ifndef __itkConvertPixelBuffer_h
00018 #define __itkConvertPixelBuffer_h
00019 
00020 #include "itkObject.h"
00021 
00022 namespace itk
00023 {
00036 template <
00037   typename InputPixelType,
00038   typename OutputPixelType,
00039   class OutputConvertTraits
00040   >
00041 class ConvertPixelBuffer
00042 {
00043 public:
00044 
00046   typedef typename OutputConvertTraits::ComponentType OutputComponentType;
00047 
00049   static void Convert(InputPixelType* inputData, 
00050                       int inputNumberOfComponents, 
00051                       OutputPixelType* outputData , size_t size);
00052   static void ConvertVectorImage(InputPixelType* inputData, 
00053                       int inputNumberOfComponents, 
00054                       OutputPixelType* outputData , size_t size);
00055 protected:
00056 
00060   static void ConvertGrayToGray(InputPixelType* inputData, 
00061                                 OutputPixelType* outputData , size_t size);
00062 
00067   static void ConvertRGBToGray(InputPixelType* inputData, 
00068                                OutputPixelType* outputData , size_t size);
00069 
00074   static void ConvertRGBAToGray(InputPixelType* inputData, 
00075                                 OutputPixelType* outputData , size_t size);
00076   static void ConvertMultiComponentToGray(InputPixelType* inputData, 
00077                                           int inputNumberOfComponents,
00078                                           OutputPixelType* outputData , 
00079                                           size_t size);
00081 
00086   static void ConvertGrayToRGB(InputPixelType* inputData, 
00087                                OutputPixelType* outputData , size_t size);
00088 
00090   static void ConvertRGBToRGB(InputPixelType* inputData, 
00091                               OutputPixelType* outputData , size_t size);
00092 
00094   static void ConvertRGBAToRGB(InputPixelType* inputData, 
00095                                OutputPixelType* outputData , size_t size);
00096 
00105   static void ConvertMultiComponentToRGB(InputPixelType* inputData, 
00106                                          int inputNumberOfComponents,
00107                                          OutputPixelType* outputData , 
00108                                          size_t size);
00109 
00111   static void ConvertGrayToRGBA(InputPixelType* inputData, 
00112                                 OutputPixelType* outputData , size_t size);
00113   static void ConvertRGBToRGBA(InputPixelType* inputData, 
00114                                OutputPixelType* outputData , size_t size);
00115   static void ConvertRGBAToRGBA(InputPixelType* inputData, 
00116                                 OutputPixelType* outputData , size_t size);
00117   static void ConvertMultiComponentToRGBA(InputPixelType* inputData, 
00118                                           int inputNumberOfComponents,
00119                                           OutputPixelType* outputData , 
00120                                           size_t size);
00122 
00126   static void ConvertTensor6ToTensor6(InputPixelType* inputData, 
00127                                OutputPixelType* outputData , size_t size);
00128   static void ConvertTensor9ToTensor6(InputPixelType* inputData, 
00129                                OutputPixelType* outputData , size_t size);
00131 
00133   static void ConvertGrayToComplex(InputPixelType * inputData,
00134                                 OutputPixelType * OutputData, size_t size);
00135   static void ConvertComplexToComplex(InputPixelType* inputData, 
00136                                 OutputPixelType* outputData , size_t size);
00137   static void ConvertMultiComponentToComplex(InputPixelType* inputData, 
00138                                 int inputNumberOfComponents,
00139                                 OutputPixelType* outputData , size_t size);
00141 
00142 private:
00143   ConvertPixelBuffer();
00144   ~ConvertPixelBuffer();
00145 };
00146 } //namespace ITK
00147 
00148 
00149 #ifndef ITK_MANUAL_INSTANTIATION
00150 #include "itkConvertPixelBuffer.txx"
00151 #endif
00152 
00153 #endif // __itkConvertPixelBuffer_h
00154 

Generated at Mon Jul 12 2010 18:08:59 for ITK by doxygen 1.7.1 written by Dimitri van Heesch, © 1997-2000