From 014a08cabb856b2360419aac404744029ee4748c Mon Sep 17 00:00:00 2001 From: Jonathan Gordon Date: Thu, 15 Mar 2012 22:50:17 +1100 Subject: skin_engine: New tag to draw a rectangle (optionally with a gradient) %dr(x, y, width, height, [colour1[, colour2]]): x,y - viewport relative pixel coordinates to start the rectangle. width, height - obvious. can be '-' to fill the viewport if both colours are left out the viewports foreground colour will be used if one colour is specified it will fill the rectangle that colour. if both colours are specified it will gradient fill the rectangle. Change-Id: Iad451e99ded663bc7c5d182443659db7d909b388 --- apps/gui/skin_engine/skin_render.c | 23 ++++++++++++++++++++++- 1 file changed, 22 insertions(+), 1 deletion(-) (limited to 'apps/gui/skin_engine/skin_render.c') diff --git a/apps/gui/skin_engine/skin_render.c b/apps/gui/skin_engine/skin_render.c index 80d8c83d27..7ceb0bce17 100644 --- a/apps/gui/skin_engine/skin_render.c +++ b/apps/gui/skin_engine/skin_render.c @@ -176,8 +176,29 @@ static bool do_non_text_tags(struct gui_wps *gwps, struct skin_draw_info *info, if (do_refresh) draw_peakmeters(gwps, info->line_number, vp); break; + case SKIN_TOKEN_DRAWRECTANGLE: + if (do_refresh) + { + struct draw_rectangle *rect = + SKINOFFSETTOPTR(skin_buffer, token->value.data); +#ifdef HAVE_LCD_COLOR + if (rect->start_colour != rect->end_colour && + gwps->display->screen_type == SCREEN_MAIN) + { + gwps->display->gradient_fillrect(rect->x, rect->y, rect->width, + rect->height, rect->start_colour, rect->end_colour); + } + else #endif -#ifdef HAVE_LCD_BITMAP + { + unsigned backup = vp->fg_pattern; + vp->fg_pattern = rect->start_colour; + gwps->display->fillrect(rect->x, rect->y, rect->width, + rect->height); + vp->fg_pattern = backup; + } + } + break; case SKIN_TOKEN_PEAKMETER_LEFTBAR: case SKIN_TOKEN_PEAKMETER_RIGHTBAR: data->peak_meter_enabled = true; -- cgit v1.2.3