-/* This file is part of
- * ======================================================
- *
- * LyX, The Document Processor
- *
- * Copyright 1995 Matthias Ettrich
- * Copyright 1995-2001 The LyX Team.
+/**
+ * \file Color.C
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
*
- *======================================================*/
+ * \author Angus Leeming
+ *
+ * Full author contact details are available in file CREDITS
+ */
#include <config.h>
+
+#include "Color.h"
#include <algorithm> // max
#include <cmath> // floor
-
#include FORMS_H_LOCATION
-#ifdef __GNUG_
-#pragma implementation
+#ifndef CXX_GLOBAL_CSTD
+using std::floor;
#endif
-#include "Color.h"
-
using std::max;
using std::min;
} // namespace anon
+
+bool getRGBColor(LColor::color col,
+ unsigned int & r, unsigned int & g, unsigned int & b)
+{
+ string const name = lcolor.getX11Name(col);
+ Display * const display = fl_get_display();
+ Colormap const cmap = fl_state[fl_get_vclass()].colormap;
+ XColor xcol, ccol;
+
+ if (XLookupColor(display, cmap, name.c_str(), &xcol, &ccol) == 0) {
+ r = 0;
+ g = 0;
+ b = 0;
+ return false;
+ }
+
+ r = xcol.red / 256;
+ g = xcol.green / 256;
+ b = xcol.blue / 256;
+ return true;
+}
+
+
RGBColor::RGBColor(HSVColor const & hsv)
{
double h = hsv.h;
double const s = hsv.s;
double const v = hsv.v;
-
+
double rd, gd, bd;
-
+
if (h == nohue || s == 0.0) {
rd = gd = bd = v;
} else {
h /= 60.0;
int const j = max(0, static_cast<int>(::floor(h)));
- //if( j < 0 ) j = 0;
+ //if (j < 0) j = 0;
double const f = h - j;
double const p = v * (1.0 - s);
}
}
- r = static_cast<int>( ::floor((rd * 255.0) + 0.5) );
- g = static_cast<int>( ::floor((gd * 255.0) + 0.5) );
- b = static_cast<int>( ::floor((bd * 255.0) + 0.5) );
+ r = static_cast<int>(::floor((rd * 255.0) + 0.5));
+ g = static_cast<int>(::floor((gd * 255.0) + 0.5));
+ b = static_cast<int>(::floor((bd * 255.0) + 0.5));
}
double const g = rgb.g / 255.0;
double const b = rgb.b / 255.0;
- double const maxval = max( max( r, g ), b );
- double const minval = min( min( r, g ), b );
+ double const maxval = max(max(r, g), b);
+ double const minval = min(min(r, g), b);
v = maxval;