openbox/render/image.c
Dana Jansens 3f32dfa87e this is going to break the kernel/ building.
lots of modifications to the render API, prefixing everything, making proper
names for everything. the structures are not hidden/opaque yet, but the naming scheme of the public API works much better now.
2003-06-20 07:58:51 +00:00

73 lines
2.2 KiB
C

#include "../kernel/geom.h"
#include "image.h"
#include "color.h"
#include <glib.h>
void image_draw(pixel32 *target, RrTextureRGBA *rgba, Rect *area)
{
pixel32 *draw = rgba->data;
gint c, i, e, t, sfw, sfh;
sfw = area->width;
sfh = area->height;
g_assert(rgba->data != NULL);
if ((rgba->width != sfw || rgba->height != sfh) &&
(rgba->width != rgba->cwidth || rgba->height != rgba->cheight)) {
double dx = rgba->width / (double)sfw;
double dy = rgba->height / (double)sfh;
double px = 0.0;
double py = 0.0;
int iy = 0;
/* scale it and cache it */
if (rgba->cache != NULL)
g_free(rgba->cache);
rgba->cache = g_new(pixel32, sfw * sfh);
rgba->cwidth = sfw;
rgba->cheight = sfh;
for (i = 0, c = 0, e = sfw*sfh; i < e; ++i) {
rgba->cache[i] = rgba->data[(int)px + iy];
if (++c >= sfw) {
c = 0;
px = 0;
py += dy;
iy = (int)py * rgba->width;
} else
px += dx;
}
/* do we use the cache we may have just created, or the original? */
if (rgba->width != sfw || rgba->height != sfh)
draw = rgba->cache;
/* apply the alpha channel */
for (i = 0, c = 0, t = area->x, e = sfw*sfh; i < e; ++i, ++t) {
guchar alpha, r, g, b, bgr, bgg, bgb;
alpha = draw[i] >> default_alpha_offset;
r = draw[i] >> default_red_offset;
g = draw[i] >> default_green_offset;
b = draw[i] >> default_blue_offset;
if (c >= sfw) {
c = 0;
t += area->width - sfw;
}
/* background color */
bgr = target[t] >> default_red_offset;
bgg = target[t] >> default_green_offset;
bgb = target[t] >> default_blue_offset;
r = bgr + (((r - bgr) * alpha) >> 8);
g = bgg + (((g - bgg) * alpha) >> 8);
b = bgb + (((b - bgb) * alpha) >> 8);
target[t] = (r << default_red_offset)
| (g << default_green_offset)
| (b << default_blue_offset);
}
}
}