Mercurial > MadButterfly
diff src/graph_engine_openvg.c @ 607:51dc49fd34a8 openvg
Create pattern from an image
author | Thinker K.F. Li <thinker@branda.to> |
---|---|
date | Sun, 04 Jul 2010 21:09:56 +0800 |
parents | e21eb54c7d9c |
children | 6c74bc371e37 |
line wrap: on
line diff
--- a/src/graph_engine_openvg.c Sun Jul 04 16:31:39 2010 +0800 +++ b/src/graph_engine_openvg.c Sun Jul 04 21:09:56 2010 +0800 @@ -98,6 +98,54 @@ return pattern; } +mbe_pattern_t * +mbe_pattern_create_image(mb_img_data_t *img) { + VGPaint paint; + mbe_pattern_t *pattern; + _ge_openvg_img_t *ge_img; + VGImage vg_img; + VGImageFormat fmt = VG_sARGB_8888; + + /* \note OpenVG implementation supports one \ref MB_IFMT_ARGB32 + * image. + */ + if(img->fmt != MB_IFMT_ARGB32) + return NULL; + + /* Create and copy pixels into VGImage */ + vg_img = vgCreateImage(fmt, img->w, img->h, + VG_IMAGE_QUALITY_NONANTIALIASED); + if(vg_img == VG_INVALID_HANDLE) + return NULL; + vgImageSubData(vg_img, img->content, img->stride, fmt, + 0, 0, img->w, img->h); + + /* Allocate objects */ + ge_img = O_ALLOC(_ge_openvg_img_t); + pattern = O_ALLOC(mbe_pattern_t); + paint = vgCreatePaint(); + if(ge_img == NULL || pattern == NULL || paint == VG_INVALID_HANDLE) + goto err; + + + /* Initialize objects */ + ge_img->img = vg_img; + ge_img->asso_pattern = NULL; + ge_img->asso_surface = NULL; + + pattern->paint = paint; + pattern->asso_img = ge_img; + + return pattern; + + err: + if(ge_img) free(ge_img); + if(pattern) free(pattern); + if(paint != VG_INVALID_HANDLE) vgDestroyPaint(paint); + vgDestroyImage(vg_img); + return NULL; +} + void mbe_set_source_rgba(mbe_t *canvas, co_comp_t r, co_comp_t g, co_comp_t b, co_comp_t a) {