diff options
| -rw-r--r-- | FL/Enumerations.H | 8 | ||||
| -rw-r--r-- | src/fl_color.cxx | 42 |
2 files changed, 28 insertions, 22 deletions
diff --git a/FL/Enumerations.H b/FL/Enumerations.H index 892ba888c..d820355b0 100644 --- a/FL/Enumerations.H +++ b/FL/Enumerations.H @@ -1,5 +1,5 @@ // -// "$Id: Enumerations.H,v 1.10 1999/01/13 15:56:22 mike Exp $" +// "$Id: Enumerations.H,v 1.11 1999/01/25 20:43:03 mike Exp $" // // Enumerations for the Fast Light Tool Kit (FLTK). // @@ -279,6 +279,10 @@ enum Fl_Color { // standard colors Fl_Color inactive(Fl_Color c); Fl_Color contrast(Fl_Color fg, Fl_Color bg); +Fl_Color fl_color_average(Fl_Color c1, Fl_Color c2, float weight); +inline Fl_Color fl_lighter(Fl_Color c) { return fl_color_average(c, FL_WHITE, .67f); } +inline Fl_Color fl_darker(Fl_Color c) { return fl_color_average(c, FL_BLACK, .67f); } + #define FL_NUM_GRAY 24 inline Fl_Color fl_gray_ramp(int i) {return (Fl_Color)(i+FL_GRAY_RAMP);} #define FL_NUM_RED 5 @@ -347,5 +351,5 @@ enum Fl_Damage { #endif // -// End of "$Id: Enumerations.H,v 1.10 1999/01/13 15:56:22 mike Exp $". +// End of "$Id: Enumerations.H,v 1.11 1999/01/25 20:43:03 mike Exp $". // diff --git a/src/fl_color.cxx b/src/fl_color.cxx index 2c1544a18..64368168f 100644 --- a/src/fl_color.cxx +++ b/src/fl_color.cxx @@ -1,5 +1,5 @@ // -// "$Id: fl_color.cxx,v 1.11 1999/01/19 19:10:39 mike Exp $" +// "$Id: fl_color.cxx,v 1.12 1999/01/25 20:43:05 mike Exp $" // // Color functions for the Fast Light Tool Kit (FLTK). // @@ -316,25 +316,27 @@ void Fl::get_color(Fl_Color i, uchar &red, uchar &green, uchar &blue) { blue = uchar(c>>8); } +Fl_Color fl_color_average(Fl_Color color1, Fl_Color color2, float weight) { + Fl_Color avg; + unsigned rgb1 = fl_cmap[color1]; + unsigned rgb2 = fl_cmap[color2]; + uchar r, g, b; + + r = (uchar)(((uchar)(rgb1>>24))*weight + ((uchar)(rgb2>>24))*(1-weight)); + g = (uchar)(((uchar)(rgb1>>16))*weight + ((uchar)(rgb2>>16))*(1-weight)); + b = (uchar)(((uchar)(rgb1>>8))*weight + ((uchar)(rgb2>>8))*(1-weight)); + + if (r == g && r == b) { // get it out of gray ramp + avg = fl_gray_ramp(r*FL_NUM_GRAY/256); + } else { // get it out of color cube: + avg = fl_color_cube(r*FL_NUM_RED/256,g*FL_NUM_GREEN/256,b*FL_NUM_BLUE/256); + } + + return avg; +} + Fl_Color inactive(Fl_Color c) { - // cache because it is like to ask for the same color a lot: - static Fl_Color cache_from = FL_GRAY; - static Fl_Color cache_to = FL_GRAY; - if (c == cache_from) return cache_to; - cache_from = c; - // do a 33% mix between this color and FL_GRAY: - unsigned rgb1 = fl_cmap[c]; - unsigned rgb2 = fl_cmap[FL_GRAY]; - uchar r = (uchar)((((uchar)(rgb1>>24)) + ((uchar)(rgb2>>24))*2)/3); - uchar g = (uchar)((((uchar)(rgb1>>16)) + ((uchar)(rgb2>>16))*2)/3); - uchar b = (uchar)((((uchar)(rgb1>> 8)) + ((uchar)(rgb2>> 8))*2)/3); - // and find the closest color in gray ramp or color cube: - if (r == g && r == b) // get it out of gray ramp - cache_to = fl_gray_ramp(r*FL_NUM_GRAY/256); - else // get it out of color cube: - cache_to = - fl_color_cube(r*FL_NUM_RED/256,g*FL_NUM_GREEN/256,b*FL_NUM_BLUE/256); - return cache_to; + return fl_color_average(c, FL_GRAY, .33f); } Fl_Color contrast(Fl_Color fg, Fl_Color bg) { @@ -349,5 +351,5 @@ Fl_Color contrast(Fl_Color fg, Fl_Color bg) { } // -// End of "$Id: fl_color.cxx,v 1.11 1999/01/19 19:10:39 mike Exp $". +// End of "$Id: fl_color.cxx,v 1.12 1999/01/25 20:43:05 mike Exp $". // |
