summaryrefslogtreecommitdiffstats
path: root/libdimensionxx/dimensionxx/color.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'libdimensionxx/dimensionxx/color.hpp')
-rw-r--r--libdimensionxx/dimensionxx/color.hpp173
1 files changed, 172 insertions, 1 deletions
diff --git a/libdimensionxx/dimensionxx/color.hpp b/libdimensionxx/dimensionxx/color.hpp
index 114485f..5db041a 100644
--- a/libdimensionxx/dimensionxx/color.hpp
+++ b/libdimensionxx/dimensionxx/color.hpp
@@ -21,8 +21,179 @@
#ifndef DIMENSIONXX_COLOR_HPP
#define DIMENSIONXX_COLOR_HPP
-namespace dimension
+namespace Dimension
{
+ class CIE_XYZ;
+ class CIE_xyY;
+ class CIE_Lab;
+ class CIE_Luv;
+ class sRGB;
+
+ extern const CIE_XYZ whitepoint;
+
+ class Color
+ {
+ public:
+ Color() { }
+ inline Color(const CIE_XYZ& XYZ);
+ inline Color(const CIE_xyY& xyY);
+ inline Color(const CIE_Lab& Lab, const CIE_XYZ& white = whitepoint);
+ inline Color(const CIE_Luv& Luv, const CIE_XYZ& white = whitepoint);
+ inline Color(const sRGB& RGB);
+ explicit Color(dmnsn_color c) : m_color(c) { }
+ // Color(const Color& c);
+ // ~Color();
+
+ double filter() const { return m_color.filter; }
+ double trans() const { return m_color.trans; }
+
+ double filter(double f) { m_color.filter = f; }
+ double trans(double t) { m_color.trans = t; }
+
+ // Color& operator=(const Color& c);
+
+ dmnsn_color dmnsn() const { return m_color; }
+
+ private:
+ dmnsn_color m_color;
+ };
+
+ class CIE_XYZ
+ {
+ public:
+ CIE_XYZ(double X, double Y, double Z)
+ { m_XYZ.X = X; m_XYZ.Y = Y; m_XYZ.Z = Z; }
+ CIE_XYZ(const Color& c) : m_XYZ(dmnsn_XYZ_from_color(c.dmnsn())) { }
+ explicit CIE_XYZ(dmnsn_CIE_XYZ XYZ) : m_XYZ(XYZ) { }
+ // CIE_XYZ(const CIE_XYZ& XYZ);
+ // ~CIE_XYZ();
+
+ double X() const { return m_XYZ.X; }
+ double Y() const { return m_XYZ.Y; }
+ double Z() const { return m_XYZ.Z; }
+
+ // CIE_XYZ& operator=(const CIE_XYZ& XYZ);
+ CIE_XYZ& operator=(const Color& c)
+ { m_XYZ = dmnsn_XYZ_from_color(c.dmnsn()); }
+
+ dmnsn_CIE_XYZ dmnsn() const { return m_XYZ; }
+
+ private:
+ dmnsn_CIE_XYZ m_XYZ;
+ };
+
+ class CIE_xyY
+ {
+ public:
+ CIE_xyY(double x, double y, double Y)
+ { m_xyY.x = x; m_xyY.y = y; m_xyY.Y = Y; }
+ CIE_xyY(const Color& c) : m_xyY(dmnsn_xyY_from_color(c.dmnsn())) { }
+ explicit CIE_xyY(dmnsn_CIE_xyY xyY) : m_xyY(xyY) { }
+ // CIE_xyY(const CIE_xyY& xyY);
+ // ~CIE_xyY();
+
+ double x() const { return m_xyY.x; }
+ double y() const { return m_xyY.y; }
+ double Y() const { return m_xyY.Y; }
+
+ // CIE_xyY& operator=(const CIE_xyY& xyY);
+ CIE_xyY& operator=(const Color& c)
+ { m_xyY = dmnsn_xyY_from_color(c.dmnsn()); }
+
+ dmnsn_CIE_xyY dmnsn() const { return m_xyY; }
+
+ private:
+ dmnsn_CIE_xyY m_xyY;
+ };
+
+ class CIE_Lab
+ {
+ public:
+ CIE_Lab(double L, double a, double b)
+ { m_Lab.L = L; m_Lab.a = a; m_Lab.b = b; }
+ CIE_Lab(const Color& c, const CIE_XYZ& white = whitepoint)
+ : m_Lab(dmnsn_Lab_from_color(c.dmnsn(), white.dmnsn())) { }
+ explicit CIE_Lab(dmnsn_CIE_Lab Lab) : m_Lab(Lab) { }
+ // CIE_Lab(const CIE_Lab& Lab);
+ // ~CIE_Lab();
+
+ double L() const { return m_Lab.L; }
+ double a() const { return m_Lab.a; }
+ double b() const { return m_Lab.b; }
+
+ // CIE_Lab& operator=(const CIE_Lab& Lab);
+ CIE_Lab& operator=(const Color& c)
+ { m_Lab = dmnsn_Lab_from_color(c.dmnsn(), whitepoint.dmnsn()); }
+
+ dmnsn_CIE_Lab dmnsn() const { return m_Lab; }
+
+ private:
+ dmnsn_CIE_Lab m_Lab;
+ };
+
+ class CIE_Luv
+ {
+ public:
+ CIE_Luv(double L, double u, double v)
+ { m_Luv.L = L; m_Luv.u = u; m_Luv.v = v; }
+ CIE_Luv(const Color& c, const CIE_XYZ& white = whitepoint)
+ : m_Luv(dmnsn_Luv_from_color(c.dmnsn(), white.dmnsn())) { }
+ explicit CIE_Luv(dmnsn_CIE_Luv Luv) : m_Luv(Luv) { }
+ // CIE_Luv(const CIE_Luv& Luv);
+ // ~CIE_Luv();
+
+ double L() const { return m_Luv.L; }
+ double u() const { return m_Luv.u; }
+ double v() const { return m_Luv.v; }
+
+ // CIE_Luv& operator=(const CIE_Luv& Luv);
+ CIE_Luv& operator=(const Color& c)
+ { m_Luv = dmnsn_Luv_from_color(c.dmnsn(), whitepoint.dmnsn()); }
+
+ dmnsn_CIE_Luv dmnsn() const { return m_Luv; }
+
+ private:
+ dmnsn_CIE_Luv m_Luv;
+ };
+
+ class sRGB
+ {
+ public:
+ sRGB(double R, double G, double B)
+ { m_RGB.R = R; m_RGB.G = G; m_RGB.B = B; }
+ sRGB(const Color& c) : m_RGB(dmnsn_sRGB_from_color(c.dmnsn())) { }
+ explicit sRGB(dmnsn_sRGB RGB) : m_RGB(RGB) { }
+ // sRGB(const sRGB& RGB);
+ // ~sRGB();
+
+ double R() const { return m_RGB.R; }
+ double G() const { return m_RGB.G; }
+ double B() const { return m_RGB.B; }
+
+ // sRGB& operator=(const sRGB& RGB);
+ sRGB& operator=(const Color& c)
+ { m_RGB = dmnsn_sRGB_from_color(c.dmnsn()); }
+
+ dmnsn_sRGB dmnsn() const { return m_RGB; }
+
+ private:
+ dmnsn_sRGB m_RGB;
+ };
+
+ inline Color::Color(const CIE_XYZ& XYZ)
+ : m_color(dmnsn_color_from_XYZ(XYZ.dmnsn())) { }
+
+ inline Color::Color(const CIE_xyY& xyY)
+ : m_color(dmnsn_color_from_xyY(xyY.dmnsn())) { }
+
+ inline Color::Color(const CIE_Lab& Lab, const CIE_XYZ& white)
+ : m_color(dmnsn_color_from_Lab(Lab.dmnsn(), white.dmnsn())) { }
+
+ inline Color::Color(const CIE_Luv& Luv, const CIE_XYZ& white)
+ : m_color(dmnsn_color_from_Luv(Luv.dmnsn(), white.dmnsn())) { }
+
+ inline Color::Color(const sRGB& RGB)
+ : m_color(dmnsn_color_from_sRGB(RGB.dmnsn())) { }
}
#endif /* DIMENSIONXX_COLOR_HPP */