From 312db4ca9ac0b3b488236404230e13e24d01d40a Mon Sep 17 00:00:00 2001 From: Derek Foreman Date: Thu, 23 Jan 2003 05:22:50 +0000 Subject: [PATCH] Added bevels --- otk/truerendercontrol.cc | 63 +++++++++++++++++++++++++++++++++++++--- otk/truerendercontrol.hh | 2 ++ 2 files changed, 61 insertions(+), 4 deletions(-) diff --git a/otk/truerendercontrol.cc b/otk/truerendercontrol.cc index ecc5d347..8e2b1083 100644 --- a/otk/truerendercontrol.cc +++ b/otk/truerendercontrol.cc @@ -143,12 +143,36 @@ void TrueRenderControl::drawGradientBackground( + (g << 8) + b; for (off = 0, x = 0; x < w; ++x, off++) { - *(data + off) = current; - *(data + off + ((h-1) * w)) = current; + *(data + off) = current; + *(data + off + ((h-1) * w)) = current; } for (off = 0, x = 0; x < h; ++x, off++) { - *(data + (off * w)) = current; - *(data + (off * w) + w - 1) = current; + *(data + (off * w)) = current; + *(data + (off * w) + w - 1) = current; + } + } + + if (texture.relief() != RenderTexture::Flat) { + if (texture.bevel() == RenderTexture::Bevel1) { + for (off = 0, x = 0; x < w; ++x, off++) + highlight(data + off, + data + off + (h-1) * w, + texture.relief()==RenderTexture::Raised); + for (off = 0, x = 0; x < h; ++x, off++) + highlight(data + off * w, + data + off * w + w - 1, + texture.relief()==RenderTexture::Raised); + } + + if (texture.bevel() == RenderTexture::Bevel2) { + for (off = 1, x = 1; x < w - 1; ++x, off++) + highlight(data + off + w, + data + off + (h-2) * w, + texture.relief()==RenderTexture::Raised); + for (off = 1, x = 1; x < h-1; ++x, off++) + highlight(data + off * w + 1, + data + off * w + w - 2, + texture.relief()==RenderTexture::Raised); } } @@ -162,6 +186,37 @@ void TrueRenderControl::drawGradientBackground( XDestroyImage(im); } +void TrueRenderControl::highlight(pixel32 *x, pixel32 *y, bool raised) const +{ + int r, g, b; + + pixel32 *up, *down; + if (raised) { + up = x; + down = y; + } else { + up = y; + down = x; + } + r = (*up >> 16) & 0xFF; + r += r >> 1; + g = (*up >> 8) & 0xFF; + g += g >> 1; + b = *up & 0xFF; + b += b >> 1; + if (r > 255) r = 255; + if (g > 255) r = 255; + if (b > 255) r = 255; + *up = (r << 16) + (g << 8) + b; + + r = (*down >> 16) & 0xFF; + r = (r >> 1) + (r >> 2); + g = (*down >> 8) & 0xFF; + g = (g >> 1) + (g >> 2); + b = *down & 0xFF; + b = (b >> 1) + (b >> 2); + *down = (r << 16) + (g << 8) + b; +} void TrueRenderControl::drawBackground(Surface& sf, const RenderTexture &texture) const { diff --git a/otk/truerendercontrol.hh b/otk/truerendercontrol.hh index e4975aeb..a4735c8f 100644 --- a/otk/truerendercontrol.hh +++ b/otk/truerendercontrol.hh @@ -46,6 +46,8 @@ public: virtual void drawBackground(Surface& sf, const RenderTexture &texture) const; virtual void drawGradientBackground(Surface &sf, const RenderTexture &texture) const; + + inline void highlight(pixel32 *x, pixel32 *y, bool raised) const; }; } -- 2.39.2