#include <pthread.h>
#include <string>
#include <lib/base/object.h>
+#include <lib/base/smartptr.h>
#include <lib/base/elock.h>
#include <lib/gdi/erect.h>
#include <lib/gdi/fb.h>
-struct gColor
-{
- int color;
- gColor(int color): color(color)
- {
- }
- gColor(): color(0)
- {
- }
- operator int() const { return color; }
- bool operator==(const gColor &o) const { return o.color==color; }
-};
-
struct gRGB
{
unsigned char b, g, r, a;
gRGB(): b(0), g(0), r(0), a(0)
{
}
+
+ unsigned long argb() const
+ {
+ return (a<<24)|(r<<16)|(g<<8)|b;
+ }
+
void operator=(unsigned long val)
{
b = val&0xFF;
}
};
+#ifndef SWIG
+struct gColor
+{
+ int color;
+ gColor(int color): color(color)
+ {
+ }
+ gColor(): color(0)
+ {
+ }
+ operator int() const { return color; }
+ bool operator==(const gColor &o) const { return o.color==color; }
+};
+
struct gPalette
{
int start, colors;
gPalette clut;
void *data;
- virtual ~gSurface();
-};
+ int data_phys;
+ int offset; // only for backbuffers
-struct gSurfaceSystem: gSurface
-{
- gSurfaceSystem(eSize size, int bpp);
- ~gSurfaceSystem();
+ gSurface();
+ gSurface(eSize size, int bpp, int accel);
+ ~gSurface();
};
+#endif
-struct gPixmap: public iObject
+class gRegion;
+
+SWIG_IGNORE(gPixmap);
+class gPixmap: public iObject
{
-DECLARE_REF(gPixmap);
-private:
- friend class gDC;
- void fill(const gRegion &clip, const gColor &color);
-
+ DECLARE_REF(gPixmap);
+public:
+#ifndef SWIG
enum
{
- blitAlphaTest=1
+ blitAlphaTest=1,
+ blitAlphaBlend=2
};
- void blit(const gPixmap &src, ePoint pos, const gRegion &clip, int flags=0);
-
- void mergePalette(const gPixmap &target);
- void line(const gRegion &clip, ePoint start, ePoint end, gColor color);
-public:
+
+ gPixmap(gSurface *surface);
+ gPixmap(eSize, int bpp, int accel = 0);
+
gSurface *surface;
eLock contentlock;
gPixmap *lock();
void unlock();
+ inline bool needClut() const { return surface && surface->bpp <= 8; }
+#endif
+ virtual ~gPixmap();
+ eSize size() const { return eSize(surface->x, surface->y); }
+private:
+ bool must_delete_surface;
+ friend class gDC;
+ void fill(const gRegion &clip, const gColor &color);
+ void fill(const gRegion &clip, const gRGB &color);
- eSize getSize() const { return eSize(surface->x, surface->y); }
+ void blit(const gPixmap &src, ePoint pos, const gRegion &clip, int flags=0);
- gPixmap(gSurface *surface);
- gPixmap(eSize, int bpp);
- virtual ~gPixmap();
+ void mergePalette(const gPixmap &target);
+ void line(const gRegion &clip, ePoint start, ePoint end, gColor color);
+#ifdef SWIG
+ gPixmap();
+#endif
};
+SWIG_TEMPLATE_TYPEDEF(ePtr<gPixmap>, gPixmapPtr);
#endif