ITK 6.0.0
Insight Toolkit
 
Loading...
Searching...
No Matches
itkLabelOverlayFunctor.h
Go to the documentation of this file.
1/*=========================================================================
2 *
3 * Copyright NumFOCUS
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 * https://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 itkLabelOverlayFunctor_h
19#define itkLabelOverlayFunctor_h
20
22#include "itkMath.h"
23
24namespace itk
25{
26namespace Functor
27{
47template <typename TInputPixel, typename TLabel, typename TRGBPixel>
49{
50public:
52 {
53 // provide some default value for external use (outside
54 // LabelOverlayFunctorImageFilter) Inside LabelOverlayFunctorImageFilter,
55 // the values are always initialized
56 m_Opacity = 1.0;
57 m_BackgroundValue = TLabel{};
58 }
59
60 inline TRGBPixel
61 operator()(const TInputPixel & p1, const TLabel & p2) const
62 {
63 TRGBPixel rgbPixel;
65
66 if (p2 == m_BackgroundValue)
67 {
68 // value is background
69 // return a gray pixel with the same intensity than the input pixel
70 auto p = static_cast<typename TRGBPixel::ValueType>(p1);
71 rgbPixel[0] = p;
72 rgbPixel[1] = p;
73 rgbPixel[2] = p;
74 return rgbPixel;
75 }
76
77 // taint the input pixel with the colored one returned by
78 // the color functor.
79 TRGBPixel opaque = m_RGBFunctor(p2);
80 // the following has been unrolled due to a bug with apple's
81 // llvm-gcc-4.2 build 5658
82 const double p1_blend = p1 * (1.0 - m_Opacity);
83 rgbPixel[0] = static_cast<typename TRGBPixel::ValueType>(opaque[0] * m_Opacity + p1_blend);
84 rgbPixel[1] = static_cast<typename TRGBPixel::ValueType>(opaque[1] * m_Opacity + p1_blend);
85 rgbPixel[2] = static_cast<typename TRGBPixel::ValueType>(opaque[2] * m_Opacity + p1_blend);
86
87 return rgbPixel;
88 }
89
90 bool
91 operator==(const LabelOverlayFunctor & other) const
92 {
95 }
96
98
100
101 void
102 SetOpacity(double opacity)
103 {
104 m_Opacity = opacity;
105 }
106
107 void
109 {
111 m_RGBFunctor.SetBackgroundValue(v);
112 }
113
114 void
116 {
117 m_RGBFunctor.ResetColors();
118 }
119
120 unsigned int
122 {
123 return m_RGBFunctor.GetNumberOfColors();
124 }
125
127 using ComponentType = typename TRGBPixel::ComponentType;
128
129 void
130 AddColor(unsigned char r, unsigned char g, unsigned char b)
131 {
132 m_RGBFunctor.AddColor(r, g, b);
133 }
134
135protected:
136private:
137 double m_Opacity;
139
141};
142} // end namespace Functor
143} // end namespace itk
144
145#endif
TRGBPixel operator()(const TInputPixel &p1, const TLabel &p2) const
bool operator==(const LabelOverlayFunctor &other) const
void AddColor(unsigned char r, unsigned char g, unsigned char b)
ITK_UNEQUAL_OPERATOR_MEMBER_FUNCTION(LabelOverlayFunctor)
Functor::LabelToRGBFunctor< TLabel, TRGBPixel > m_RGBFunctor
typename TRGBPixel::ComponentType ComponentType
Functor for converting labels into RGB triplets.
static void SetLength(T &m, const unsigned int s)
bool ExactlyEquals(const TInput1 &x1, const TInput2 &x2)
Return the result of an exact comparison between two scalar values of potentially different types.
Definition itkMath.h:719
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....