ITK  4.2.0
Insight Segmentation and Registration Toolkit
itkCustomColormapFunction.h
Go to the documentation of this file.
1 /*=========================================================================
2  *
3  * Copyright Insight Software Consortium
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  * http://www.apache.org/licenses/LICENSE-2.0.txt
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  *
17  *=========================================================================*/
18 #ifndef __itkCustomColormapFunction_h
19 #define __itkCustomColormapFunction_h
20 
21 #include "itkColormapFunction.h"
22 
23 #include <vector>
24 
25 namespace itk
26 {
27 namespace Function
28 {
44 template< class TScalar, class TRGBPixel >
45 class ITK_EXPORT CustomColormapFunction:
46  public ColormapFunction< TScalar, TRGBPixel >
47 {
48 public:
49 
54 
56  itkNewMacro(Self);
57 
58  typedef typename Superclass::RGBPixelType RGBPixelType;
59  typedef typename Superclass::ScalarType ScalarType;
60  typedef typename Superclass::RealType RealType;
61 
62  typedef std::vector< RealType > ChannelType;
63 
64  virtual RGBPixelType operator()(const TScalar &) const;
65 
66  void SetRedChannel(ChannelType red)
67  {
68  m_RedChannel = red;
69  }
70 
71  ChannelType GetRedChannel() const
72  {
73  return m_RedChannel;
74  }
75 
76  void SetGreenChannel(ChannelType green)
77  {
78  m_GreenChannel = green;
79  }
80 
81  ChannelType GetGreenChannel() const
82  {
83  return m_GreenChannel;
84  }
85 
86  void SetBlueChannel(ChannelType blue)
87  {
88  m_BlueChannel = blue;
89  }
90 
91  ChannelType GetBlueChannel() const
92  {
93  return m_BlueChannel;
94  }
95 
96 protected:
99 private:
100  CustomColormapFunction(const Self &); //purposely not implemented
101  void operator=(const Self &); //purposely not implemented
102 
106 };
107 } // end namespace functor
108 } // end namespace itk
109 
110 #ifndef ITK_MANUAL_INSTANTIATION
111 #include "itkCustomColormapFunction.hxx"
112 #endif
113 
114 #endif
115