X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=otk%2Frendercolor.cc;h=be9521bf5fded0bd44c9f8b95e8897a15b9d0967;hb=41a03629c9f166f7a1b427ed1634b44c6c38da6e;hp=99dd3341bd25c606416e6c5e5f189bb780712bd1;hpb=0348a2f3abd2334f5f5812c5fb45c1b4fffb46a5;p=chaz%2Fopenbox diff --git a/otk/rendercolor.cc b/otk/rendercolor.cc index 99dd3341..be9521bf 100644 --- a/otk/rendercolor.cc +++ b/otk/rendercolor.cc @@ -8,6 +8,12 @@ #include "display.hh" #include "screeninfo.hh" +extern "C" { +#ifdef HAVE_STDIO_H +# include +#endif +} + namespace otk { std::map *RenderColor::_cache = 0; @@ -29,6 +35,21 @@ RenderColor::RenderColor(int screen, unsigned char red, _green(green), _blue(blue), _gc(0) +{ + create(); +} + +RenderColor::RenderColor(int screen, RGB rgb) + : _screen(screen), + _red(rgb.r), + _green(rgb.g), + _blue(rgb.b), + _gc(0) +{ + create(); +} + +void RenderColor::create() { unsigned long color = _blue | _green << 8 | _red << 16; @@ -37,6 +58,7 @@ RenderColor::RenderColor(int screen, unsigned char red, if (item) { _gc = item->gc; + _pixel = item->pixel; ++item->count; } else { XGCValues gcv; @@ -56,19 +78,24 @@ RenderColor::RenderColor(int screen, unsigned char red, xcol.pixel = 0; } - gcv.foreground = xcol.pixel; - _gc = XCreateGC(**display, info->rootWindow(), GCForeground, &gcv); + _pixel = xcol.pixel; + gcv.foreground = _pixel; + gcv.cap_style = CapProjecting; + _gc = XCreateGC(**display, info->rootWindow(), + GCForeground | GCCapStyle, &gcv); assert(_gc); // insert into the cache - _cache[_screen][color] = new CacheItem(_gc); + item = new CacheItem(_gc, _pixel); + _cache[_screen][color] = item; + ++item->count; } } RenderColor::~RenderColor() { unsigned long color = _blue | _green << 8 | _red << 16; - + CacheItem *item = _cache[_screen][color]; assert(item); // it better be in the cache ...