From 58847af218e486f5c1a34ffe947a961a74f97c0a Mon Sep 17 00:00:00 2001 From: Dana Jansens Date: Tue, 11 Feb 2003 21:50:06 +0000 Subject: store the pixel32 data in the surface so it can be reused --- otk/surface.hh | 28 ++++++++++++++++++++++++---- 1 file changed, 24 insertions(+), 4 deletions(-) (limited to 'otk/surface.hh') diff --git a/otk/surface.hh b/otk/surface.hh index 7a202491..40dfbf84 100644 --- a/otk/surface.hh +++ b/otk/surface.hh @@ -3,23 +3,41 @@ #define __surface_hh #include "size.hh" -#include "truerendercontrol.hh" -#include "pseudorendercontrol.hh" extern "C" { #include #define _XFT_NO_COMPAT_ // no Xft 1 API #include + +#ifdef HAVE_STDINT_H +# include +#else +# ifdef HAVE_SYS_TYPES_H +# include +# endif +#endif } namespace otk { class ScreenInfo; class RenderColor; +class RenderControl; +class TrueRenderControl; +class PseudoRenderControl; + +#ifdef HAVE_STDINT_H +typedef uint32_t pixel32; +typedef uint16_t pixel16; +#else +typedef u_int32_t pixel32; +typedef u_int16_t pixel16; +#endif /* HAVE_STDINT_H */ class Surface { int _screen; Size _size; + pixel32 *_pixel_data; Pixmap _pixmap; XftDraw *_xftdraw; @@ -36,9 +54,11 @@ public: inline int screen(void) const { return _screen; } - virtual const Size& size() const { return _size; } + const Size& size() const { return _size; } + + Pixmap pixmap() const { return _pixmap; } - virtual Pixmap pixmap() const { return _pixmap; } + pixel32 *pixelData() { return _pixel_data; } // The RenderControl classes use the internal objects in this class to render // to it. Noone else needs them tho, so they are private. -- cgit v1.2.3