Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031 #ifndef __cmtkImageOperationThreshold_h_included_
00032 #define __cmtkImageOperationThreshold_h_included_
00033
00034 #include <cmtkconfig.h>
00035
00036 #include <Base/cmtkImageOperation.h>
00037
00038 namespace
00039 cmtk
00040 {
00041
00043 class ImageOperationThreshold
00045 : public ImageOperation
00046 {
00047 public:
00049 ImageOperationThreshold( const double threshold, const bool above = false, const bool toPadding = false, const bool binarize = false )
00050 : m_Threshold( threshold ), m_Above( above ), m_ToPadding( toPadding ), m_Binarize( binarize ) {}
00051
00053 virtual cmtk::UniformVolume::SmartPtr Apply( cmtk::UniformVolume::SmartPtr& volume );
00054
00056 static void NewBelow( const double threshold )
00057 {
00058 ImageOperation::m_ImageOperationList.push_back( SmartPtr( new ImageOperationThreshold( threshold, false, false, false ) ) );
00059 }
00060
00062 static void NewAbove( const double threshold )
00063 {
00064 ImageOperation::m_ImageOperationList.push_back( SmartPtr( new ImageOperationThreshold( threshold, true, false, false ) ) );
00065 }
00066
00068 static void NewBelowToPadding( const double threshold )
00069 {
00070 ImageOperation::m_ImageOperationList.push_back( SmartPtr( new ImageOperationThreshold( threshold, false, true, false ) ) );
00071 }
00072
00074 static void NewAboveToPadding( const double threshold )
00075 {
00076 ImageOperation::m_ImageOperationList.push_back( SmartPtr( new ImageOperationThreshold( threshold, true, true, false ) ) );
00077 }
00078
00080 static void NewBinarize( const double threshold )
00081 {
00082 ImageOperation::m_ImageOperationList.push_back( SmartPtr( new ImageOperationThreshold( threshold, false, false, true ) ) );
00083 }
00084
00085 private:
00087 double m_Threshold;
00088
00090 bool m_Above;
00091
00093 bool m_ToPadding;
00094
00096 bool m_Binarize;
00097 };
00098
00099 }
00100
00101 #endif // #ifndef __cmtkImageOperationThreshold_h_included_