summaryrefslogtreecommitdiff
path: root/firmware
diff options
context:
space:
mode:
Diffstat (limited to 'firmware')
-rw-r--r--firmware/drivers/lcd-16bit.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/firmware/drivers/lcd-16bit.c b/firmware/drivers/lcd-16bit.c
index 2d228b6566..f748b4027c 100644
--- a/firmware/drivers/lcd-16bit.c
+++ b/firmware/drivers/lcd-16bit.c
@@ -529,6 +529,8 @@ void lcd_fillrect(int x, int y, int width, int height)
529/* Fill a rectangle with a gradient */ 529/* Fill a rectangle with a gradient */
530void lcd_gradient_rect(int x1, int x2, int y, int h) 530void lcd_gradient_rect(int x1, int x2, int y, int h)
531{ 531{
532 if (h == 0) return;
533
532 int h_r = RGB_UNPACK_RED(lss_pattern) << 16; 534 int h_r = RGB_UNPACK_RED(lss_pattern) << 16;
533 int h_b = RGB_UNPACK_BLUE(lss_pattern) << 16; 535 int h_b = RGB_UNPACK_BLUE(lss_pattern) << 16;
534 int h_g = RGB_UNPACK_GREEN(lss_pattern) << 16; 536 int h_g = RGB_UNPACK_GREEN(lss_pattern) << 16;
@@ -861,7 +863,7 @@ void lcd_puts_style_offset(int x, int y, const unsigned char *str, int style,
861 863
862 if (style & STYLE_GRADIENT) { 864 if (style & STYLE_GRADIENT) {
863 drawmode = DRMODE_FG; 865 drawmode = DRMODE_FG;
864 lcd_gradient_rect(xpos, LCD_WIDTH, ypos, h); 866 lcd_gradient_rect(xpos, LCD_WIDTH, ypos, h*(style & STYLE_COLOR_MASK));
865 fg_pattern = lst_pattern; 867 fg_pattern = lst_pattern;
866 } 868 }
867 else if (style & STYLE_COLORBAR) { 869 else if (style & STYLE_COLORBAR) {