diff options
| author | Dana Jansens <danakj@orodu.net> | 2003-03-29 21:12:47 +0000 |
|---|---|---|
| committer | Dana Jansens <danakj@orodu.net> | 2003-03-29 21:12:47 +0000 |
| commit | 4d5885d271d4943636e7e775492e8f4bd7fe8a84 (patch) | |
| tree | a548aa57166bc0e049be96c5889ea8b98ad321e3 /render | |
| parent | 2b4ab6753cf76f735f211b42e688a5e60d65b6f3 (diff) | |
add pixmap_mask_copy, and add the data to the mask struct, since it is needed for allowing copies
Diffstat (limited to 'render')
| -rw-r--r-- | render/mask.c | 14 | ||||
| -rw-r--r-- | render/mask.h | 1 | ||||
| -rw-r--r-- | render/render.h | 1 |
3 files changed, 16 insertions, 0 deletions
diff --git a/render/mask.c b/render/mask.c index e1a18933..26059ca6 100644 --- a/render/mask.c +++ b/render/mask.c @@ -6,6 +6,8 @@ pixmap_mask *pixmap_mask_new(int w, int h, char *data) pixmap_mask *m = g_new(pixmap_mask, 1); m->w = w; m->h = h; + /* round up to nearest byte */ + m->data = g_memdup(data, (w * h + 7) / 8); m->mask = XCreateBitmapFromData(ob_display, ob_root, data, w, h); return m; } @@ -13,6 +15,7 @@ pixmap_mask *pixmap_mask_new(int w, int h, char *data) void pixmap_mask_free(pixmap_mask *m) { XFreePixmap(ob_display, m->mask); + g_free(m->data); g_free(m); } @@ -39,3 +42,14 @@ void mask_draw(Pixmap p, TextureMask *m, Rect *position) XSetClipMask(ob_display, m->color->gc, None); XSetClipOrigin(ob_display, m->color->gc, 0, 0); } + +pixmap_mask *pixmap_mask_copy(pixmap_mask *src) +{ + pixmap_mask *m = g_new(pixmap_mask, 1); + m->w = src->w; + m->h = src->h; + /* round up to nearest byte */ + m->data = g_memdup(src->data, (src->w * src->h + 7) / 8); + m->mask = XCreateBitmapFromData(ob_display, ob_root, m->data, m->w, m->h); + return m; +} diff --git a/render/mask.h b/render/mask.h index 323e82e3..89716f85 100644 --- a/render/mask.h +++ b/render/mask.h @@ -5,6 +5,7 @@ #include "../kernel/geom.h" pixmap_mask *pixmap_mask_new(int w, int h, char *data); +pixmap_mask *pixmap_mask_copy(pixmap_mask *src); void pixmap_mask_free(pixmap_mask *m); void mask_draw(Pixmap p, TextureMask *m, Rect *position); diff --git a/render/render.h b/render/render.h index d5f5f8bc..35522110 100644 --- a/render/render.h +++ b/render/render.h @@ -100,6 +100,7 @@ typedef struct TextureText { typedef struct { Pixmap mask; guint w, h; + char *data; } pixmap_mask; typedef struct TextureMask { |
