Added bevels

This commit is contained in:
Derek Foreman 2003-01-23 05:22:50 +00:00
parent 28b8f67562
commit 312db4ca9a
2 changed files with 61 additions and 4 deletions

View file

@ -152,6 +152,30 @@ void TrueRenderControl::drawGradientBackground(
} }
} }
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);
}
}
//XXX: any dithering should be done now //XXX: any dithering should be done now
im->data = (char*) data; im->data = (char*) data;
@ -162,6 +186,37 @@ void TrueRenderControl::drawGradientBackground(
XDestroyImage(im); 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, void TrueRenderControl::drawBackground(Surface& sf,
const RenderTexture &texture) const const RenderTexture &texture) const
{ {

View file

@ -46,6 +46,8 @@ public:
virtual void drawBackground(Surface& sf, const RenderTexture &texture) const; virtual void drawBackground(Surface& sf, const RenderTexture &texture) const;
virtual void drawGradientBackground(Surface &sf, virtual void drawGradientBackground(Surface &sf,
const RenderTexture &texture) const; const RenderTexture &texture) const;
inline void highlight(pixel32 *x, pixel32 *y, bool raised) const;
}; };
} }