diff options
author | Joel Bodenmann <joel@embedded.pro> | 2016-11-11 19:09:34 +0100 |
---|---|---|
committer | Joel Bodenmann <joel@embedded.pro> | 2016-11-11 19:09:34 +0100 |
commit | b60383c03e8ddd0fb2f24f597fd15c787653d652 (patch) | |
tree | 194d64c2386f29f6b6faea429ac13c2f2bd35f92 /src/gdisp/gdisp_image_bmp.c | |
parent | c91f42ec85a2c2f127663c0b0a9f11f11a6660b8 (diff) | |
parent | 477aa8e87872ae79e568e1a1d5468c614fc1c457 (diff) | |
download | uGFX-b60383c03e8ddd0fb2f24f597fd15c787653d652.tar.gz uGFX-b60383c03e8ddd0fb2f24f597fd15c787653d652.tar.bz2 uGFX-b60383c03e8ddd0fb2f24f597fd15c787653d652.zip |
Merge branch 'image_palette'
Diffstat (limited to 'src/gdisp/gdisp_image_bmp.c')
-rw-r--r-- | src/gdisp/gdisp_image_bmp.c | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/src/gdisp/gdisp_image_bmp.c b/src/gdisp/gdisp_image_bmp.c index 371fdf2d..2ea4e95f 100644 --- a/src/gdisp/gdisp_image_bmp.c +++ b/src/gdisp/gdisp_image_bmp.c @@ -829,4 +829,65 @@ delaytime_t gdispImageNext_BMP(gdispImage *img) { return TIME_INFINITE; } +uint16_t gdispImageGetPaletteSize_BMP(gdispImage *img) { + #if GDISP_NEED_IMAGE_BMP_1 || GDISP_NEED_IMAGE_BMP_4 || GDISP_NEED_IMAGE_BMP_8 + gdispImagePrivate_BMP *priv; + + priv = (gdispImagePrivate_BMP *)img->priv; + if (!priv) + return 0; + + if (!(priv->bmpflags & BMP_PALETTE)) + return 0; + + return priv->palsize; + #else + return 0; + #endif +} + +color_t gdispImageGetPalette_BMP(gdispImage *img, uint16_t index) { + #if GDISP_NEED_IMAGE_BMP_1 || GDISP_NEED_IMAGE_BMP_4 || GDISP_NEED_IMAGE_BMP_8 + gdispImagePrivate_BMP *priv; + + priv = (gdispImagePrivate_BMP *)img->priv; + if (!priv) + return 0; + + if (!(priv->bmpflags & BMP_PALETTE)) + return 0; + + if (index >= priv->palsize) + return 0; + + return priv->palette[(uint8_t)index]; + + #else + return 0; + #endif +} + +bool_t gdispImageAdjustPalette_BMP(gdispImage *img, uint16_t index, color_t newColor) { + #if GDISP_NEED_IMAGE_BMP_1 || GDISP_NEED_IMAGE_BMP_4 || GDISP_NEED_IMAGE_BMP_8 + gdispImagePrivate_BMP *priv; + + priv = (gdispImagePrivate_BMP *)img->priv; + if (!priv) + return FALSE; + + if (!(priv->bmpflags & BMP_PALETTE)) + return FALSE; + + if (index >= priv->palsize) + return FALSE; + + priv->palette[(uint8_t)index] = newColor; + + return TRUE; + + #else + return 0; + #endif +} + #endif /* GFX_USE_GDISP && GDISP_NEED_IMAGE && GDISP_NEED_IMAGE_BMP */ |