make reduceDepth set the im->data member, with newly allocated data, so the pixelData in the surface isn't reduced

This commit is contained in:
Dana Jansens 2003-02-14 19:18:19 +00:00
parent 53b5c60a5e
commit e3f6e0ff81
4 changed files with 29 additions and 27 deletions

View file

@ -124,7 +124,8 @@ inline const XColor *PseudoRenderControl::pickColor(int r, int g, int b) const
void PseudoRenderControl::reduceDepth(Surface &sf, XImage *im) const void PseudoRenderControl::reduceDepth(Surface &sf, XImage *im) const
{ {
pixel32 *data = sf.pixelData(); pixel32 *data = sf.pixelData();
char *p = (char *)data; pixel32 *ret = (pixel32*)malloc(im->width * im->height * 4);
char *p = (char *)ret;
int x, y; int x, y;
for (y = 0; y < im->height; y++) { for (y = 0; y < im->height; y++) {
for (x = 0; x < im->width; x++) { for (x = 0; x < im->width; x++) {
@ -135,7 +136,7 @@ void PseudoRenderControl::reduceDepth(Surface &sf, XImage *im) const
data += im->width; data += im->width;
p += im->bytes_per_line; p += im->bytes_per_line;
} }
im->data = (char*)ret;
} }
void PseudoRenderControl::allocateColor(XColor *color) const void PseudoRenderControl::allocateColor(XColor *color) const

View file

@ -285,12 +285,7 @@ void RenderControl::drawGradientBackground(
} }
reduceDepth(sf, im); reduceDepth(sf, im);
im->data = (char*) data;
sf.setPixmap(im); sf.setPixmap(im);
im->data = NULL;
XDestroyImage(im); XDestroyImage(im);
} }
@ -451,7 +446,7 @@ void RenderControl::drawImage(Surface &sf, int w, int h,
if (x < 0) x = 0; if (x < 0) x = 0;
if (y < 0) y = 0; if (y < 0) y = 0;
// XXX SCALING!@!&*(@! to make it fit on the surface // Reduce the image size if its too big to make it fit on the surface
int oldw = w, oldh = h; int oldw = w, oldh = h;
unsigned long *olddata = data; unsigned long *olddata = data;
if (w > sfw) w = sfw; if (w > sfw) w = sfw;
@ -507,12 +502,7 @@ void RenderControl::drawImage(Surface &sf, int w, int h,
im->byte_order = endian; im->byte_order = endian;
reduceDepth(sf, im); reduceDepth(sf, im);
im->data = (char*) bg;
sf.setPixmap(im); sf.setPixmap(im);
im->data = NULL;
XDestroyImage(im); XDestroyImage(im);
} }

View file

@ -26,8 +26,6 @@ protected:
RenderControl(int screen); RenderControl(int screen);
virtual void reduceDepth(Surface &sf, XImage *im) const = 0;
inline void highlight(pixel32 *x, pixel32 *y, bool raised) const; inline void highlight(pixel32 *x, pixel32 *y, bool raised) const;
void verticalGradient(Surface &sf, const RenderTexture &texture) const; void verticalGradient(Surface &sf, const RenderTexture &texture) const;
void diagonalGradient(Surface &sf, const RenderTexture &texture) const; void diagonalGradient(Surface &sf, const RenderTexture &texture) const;
@ -37,11 +35,20 @@ protected:
virtual void drawSolidBackground(Surface& sf, virtual void drawSolidBackground(Surface& sf,
const RenderTexture& texture) const; const RenderTexture& texture) const;
//! Reduces a Surface's Surface::pixelData so that it will display correctly
//! on the screen's depth
/*!
This function allocates and sets the im->data member. The allocated memory
will be freed when XDetroyImage is called on the XImage.
*/
virtual void reduceDepth(Surface &sf, XImage *im) const = 0;
public: public:
virtual ~RenderControl(); virtual ~RenderControl();
static RenderControl *getRenderControl(int screen); static RenderControl *getRenderControl(int screen);
//! Draws onto the root window
virtual void drawRoot(const RenderColor &color) const; virtual void drawRoot(const RenderColor &color) const;
//! Draws a background onto a Surface, as specified by a RenderTexture //! Draws a background onto a Surface, as specified by a RenderTexture

View file

@ -60,7 +60,8 @@ void TrueRenderControl::reduceDepth(Surface &sf, XImage *im) const
int r, g, b; int r, g, b;
int x,y; int x,y;
pixel32 *data = sf.pixelData(); pixel32 *data = sf.pixelData();
pixel16 *p = (pixel16*) data; pixel32 *ret = (pixel32*)malloc(im->width * im->height * 4);
pixel16 *p = (pixel16*) ret;
switch (im->bits_per_pixel) { switch (im->bits_per_pixel) {
case 32: case 32:
if ((_red_offset != default_red_shift) || if ((_red_offset != default_red_shift) ||
@ -72,13 +73,15 @@ void TrueRenderControl::reduceDepth(Surface &sf, XImage *im) const
r = (data[x] >> default_red_shift) & 0xFF; r = (data[x] >> default_red_shift) & 0xFF;
g = (data[x] >> default_green_shift) & 0xFF; g = (data[x] >> default_green_shift) & 0xFF;
b = (data[x] >> default_blue_shift) & 0xFF; b = (data[x] >> default_blue_shift) & 0xFF;
data[x] = (r << _red_offset) + (g << _green_offset) + ret[x] = (r << _red_offset) + (g << _green_offset) +
(b << _blue_offset); (b << _blue_offset);
} }
data += im->width; data += im->width;
} }
} else {
memcpy(ret, data, im->width * im->height * 4);
} }
return; break;
case 16: case 16:
for (y = 0; y < im->height; y++) { for (y = 0; y < im->height; y++) {
for (x = 0; x < im->width; x++) { for (x = 0; x < im->width; x++) {
@ -97,6 +100,7 @@ void TrueRenderControl::reduceDepth(Surface &sf, XImage *im) const
default: default:
printf("your bit depth is currently unhandled\n"); printf("your bit depth is currently unhandled\n");
} }
im->data = (char*)ret;
} }
void TrueRenderControl::allocateColor(XColor *color) const void TrueRenderControl::allocateColor(XColor *color) const