diff options
author | Vincent Sanders <vince@netsurf-browser.org> | 2009-06-30 13:02:23 +0000 |
---|---|---|
committer | Vincent Sanders <vince@netsurf-browser.org> | 2009-06-30 13:02:23 +0000 |
commit | aa2684341170424783f9937d8fe441fb3984d825 (patch) | |
tree | b7b1adaf3867666f15d7bf9bacf804846372eff7 /image/png.c | |
parent | 38356d46ff15fe669c59bdf6aa96b7f4248d1b6a (diff) | |
download | netsurf-aa2684341170424783f9937d8fe441fb3984d825.tar.gz netsurf-aa2684341170424783f9937d8fe441fb3984d825.tar.bz2 |
Improve bitmap plotter API
svn path=/trunk/netsurf/; revision=8195
Diffstat (limited to 'image/png.c')
-rw-r--r-- | image/png.c | 25 |
1 files changed, 15 insertions, 10 deletions
diff --git a/image/png.c b/image/png.c index 7fb6358a3..34c517d90 100644 --- a/image/png.c +++ b/image/png.c @@ -270,12 +270,11 @@ bool nspng_redraw(struct content *c, int x, int y, int clip_x0, int clip_y0, int clip_x1, int clip_y1, float scale, colour background_colour) { - if (c->bitmap != NULL) { - return plot.bitmap(x, y, width, height, c->bitmap, - background_colour, c); - } + if (c->bitmap == NULL) + return true; - return true; + return plot.bitmap(x, y, width, height, c->bitmap, + background_colour, BITMAPF_NONE); } bool nspng_redraw_tiled(struct content *c, int x, int y, int width, int height, @@ -283,12 +282,18 @@ bool nspng_redraw_tiled(struct content *c, int x, int y, int width, int height, float scale, colour background_colour, bool repeat_x, bool repeat_y) { - if (c->bitmap != NULL) { - return plot.bitmap_tile(x, y, width, height, c->bitmap, - background_colour, repeat_x, repeat_y, c); - } + bitmap_flags_t flags = 0; - return true; + if (c->bitmap == NULL) + return true; + + if (repeat_x) + flags |= BITMAPF_REPEAT_X; + if (repeat_y) + flags |= BITMAPF_REPEAT_Y; + + return plot.bitmap(x, y, width, height, c->bitmap, + background_colour, flags); } #endif |