00001 /*========================================================================= 00002 00003 Program: Insight Segmentation & Registration Toolkit 00004 Module: $RCSfile: itkRGBAPixel.h,v $ 00005 Language: C++ 00006 Date: $Date: 2003/09/10 14:29:24 $ 00007 Version: $Revision: 1.13 $ 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 __itkRGBAPixel_h 00018 #define __itkRGBAPixel_h 00019 00020 // Undefine an eventual RGBAPixel macro 00021 #ifdef RGBAPixel 00022 #undef RGBAPixel 00023 #endif 00024 00025 #include <itkIndent.h> 00026 #include <itkFixedArray.h> 00027 #include "vnl/vnl_math.h" 00028 00029 namespace itk 00030 { 00031 00051 template < typename TComponent = unsigned short > 00052 class RGBAPixel: public FixedArray<TComponent,4> 00053 { 00054 public: 00056 typedef RGBAPixel Self; 00057 typedef FixedArray<TComponent, 4> Super; 00058 00060 typedef FixedArray<TComponent, 4> BaseArray; 00061 00063 typedef TComponent ComponentType; 00064 00066 RGBAPixel() {Fill(0);} 00067 RGBAPixel (const ComponentType& r) 00068 { Fill(r) ;} 00069 00071 RGBAPixel(const Self& r): BaseArray(r) {} 00072 RGBAPixel(const ComponentType r[4]): BaseArray(r) {} 00073 00075 RGBAPixel& operator= (const Self& r); 00076 RGBAPixel& operator= (const ComponentType r[4]); 00077 00079 static int GetNumberOfComponents(){ return 4;} 00080 00082 ComponentType GetNthComponent(int c) const 00083 { return this->operator[](c); } 00084 00086 ComponentType GetScalarValue() const 00087 { 00088 return static_cast<ComponentType> (vcl_sqrt( 00089 static_cast<double>(this->operator[](0)) * static_cast<double>(this->operator[](0)) + 00090 static_cast<double>(this->operator[](1)) * static_cast<double>(this->operator[](1)) + 00091 static_cast<double>(this->operator[](2)) * static_cast<double>(this->operator[](2)))); 00092 } 00093 00095 void SetNthComponent(int c, const ComponentType& v) 00096 { this->operator[](c) = v; } 00097 00099 void SetRed( ComponentType red ) { this->operator[](0) = red;} 00100 00102 void SetGreen( ComponentType green ) {this->operator[](1) = green;} 00103 00105 void SetBlue( ComponentType blue ) {this->operator[](2) = blue;} 00106 00108 void SetAlpha( ComponentType alpha ) {this->operator[](3) = alpha;} 00109 00111 void Set( ComponentType red, ComponentType green, ComponentType blue, ComponentType alpha ) 00112 { this->operator[](0) = red; this->operator[](1) = green; this->operator[](2) = blue; this->operator[](3) = alpha;} 00113 00115 const ComponentType & GetRed( void ) const { return this->operator[](0);} 00116 00118 const ComponentType & GetGreen( void ) const { return this->operator[](1);} 00119 00121 const ComponentType & GetBlue( void ) const { return this->operator[](2);} 00122 00124 const ComponentType & GetAlpha( void ) const { return this->operator[](3);} 00125 00127 ComponentType GetLuminance( void ) const; 00128 }; 00129 00130 00131 template< typename TComponent > 00132 ITK_EXPORT std::ostream& operator<<(std::ostream& os, 00133 const RGBAPixel<TComponent> & c); 00134 00135 template< typename TComponent > 00136 ITK_EXPORT std::istream& operator>>(std::istream& is, 00137 RGBAPixel<TComponent> & c); 00138 00139 } // end namespace itk 00140 00141 #ifndef ITK_MANUAL_INSTANTIATION 00142 #include "itkRGBAPixel.txx" 00143 #endif 00144 00145 #endif