summaryrefslogtreecommitdiff
path: root/otk/truerendercontrol.cc
diff options
context:
space:
mode:
authorDerek Foreman <manmower@gmail.com>2003-01-23 05:22:50 +0000
committerDerek Foreman <manmower@gmail.com>2003-01-23 05:22:50 +0000
commit312db4ca9ac0b3b488236404230e13e24d01d40a (patch)
treee9641a84fbdbc8c172df5396c405bd73ba08a31d /otk/truerendercontrol.cc
parent28b8f67562bb7eb15134f2bf7a8394f0a009b9ba (diff)
Added bevels
Diffstat (limited to 'otk/truerendercontrol.cc')
-rw-r--r--otk/truerendercontrol.cc63
1 files changed, 59 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
{