ULRE/inc/hgl/graph/ColorSpace.h

73 lines
1.9 KiB
C++

#ifndef HGL_GRAPH_COLOR_SPACE_INCLUDE
#define HGL_GRAPH_COLOR_SPACE_INCLUDE
#include<math.h>
namespace hgl
{
namespace graph
{
enum class ColorSpace
{
Linear=0,
sRGB,
YCbCr,
BEGIN_RANGE =Linear,
END_RANGE =YCbCr,
RANGE_SIZE =(END_RANGE-BEGIN_RANGE)+1
};//enum class ColorSpace
constexpr double SRGB_GAMMA =1.0f/2.2f;
constexpr double SRGB_INVERSE_GAMMA =2.2f;
constexpr double SRGB_ALPHA =0.055f;
template<typename T>
inline const T sRGB2Linear(const T &in)
{
if(in<=0.4045)
return in/12.92;
else
return pow((in+SRGB_ALPHA)/(1+SRGB_ALPHA),2.4);
}
template<typename T>
inline const T Linear2sRGB(const T &in)
{
if(in<=0.0031308f)
return in*12.92f;
else
return (1+SRGB_ALPHA)*pow(in,1.0f/2.4f)-SRGB_ALPHA;
}
template<typename T>
inline const T sRGB2LinearApprox(const T &in)
{
return pow(in,T(SRGB_INVERSE_GAMMA));
}
template<typename T>
inline const T Linear2sRGBApprox(const T &in)
{
return pow(in,SRGB_GAMMA);
}
template<typename T>
inline void sRGB2LinearFast(T &x,T &y,T &z,const T &r,const T &g,const T &b)
{
x=0.4124f*r+0.3576f*g+0.1805f*b;
y=0.2126f*r+0.7152f*g+0.0722f*b;
z=0.0193f*r+0.1192f*g+0.9505f*b;
}
template<typename T>
inline void Linear2sRGBFast(T &r,T &g,T &b,const T &x,const T &y,const T &z)
{
r= 3.2406f*x-1.5373f*y-0.4986f*z;
g=-0.9689f*x+1.8758f*y+0.0416f*z;
b= 0.0557f*x-0.2040f*y+1.0570f*z;
}
}//namespace graph
}//namespace hgl
#endif//HGL_GRAPH_COLOR_SPACE_INCLUDE