From 5b2cba17aa95ececfdb6a498540de4dfa215e920 Mon Sep 17 00:00:00 2001 From: Jens Arnold Date: Wed, 16 Nov 2005 21:09:23 +0000 Subject: Changed the LCD_COLOR pixel value format to packed RGB (unsigned int). Now all LCDs with depth > 1 use the same datatype. Added macros for easy pixel value definition. git-svn-id: svn://svn.rockbox.org/rockbox/trunk@7912 a1c6a512-1295-4272-9138-f99709370657 --- firmware/drivers/lcd-16bit.c | 42 +++++++++++++----------------------------- firmware/drivers/lcd-h100.c | 10 +++++----- 2 files changed, 18 insertions(+), 34 deletions(-) (limited to 'firmware/drivers') diff --git a/firmware/drivers/lcd-16bit.c b/firmware/drivers/lcd-16bit.c index 185f572182..1aed98e5f6 100644 --- a/firmware/drivers/lcd-16bit.c +++ b/firmware/drivers/lcd-16bit.c @@ -34,13 +34,11 @@ #define SCROLLABLE_LINES 26 -#define RGB_PACK(r,g,b) (htobe16(((r)<<11)|((g)<<5)|(b))) - /*** globals ***/ fb_data lcd_framebuffer[LCD_HEIGHT][LCD_WIDTH] __attribute__ ((aligned (4))); -static unsigned fg_pattern; -static unsigned bg_pattern; +static unsigned fg_pattern = LCD_DEFAULT_FG; +static unsigned bg_pattern = LCD_DEFAULT_BG; static int drawmode = DRMODE_SOLID; static int xmargin = 0; static int ymargin = 0; @@ -72,9 +70,6 @@ int lcd_default_contrast(void) /* LCD init */ void lcd_init(void) { - fg_pattern = 0x0000; /* Black */ - bg_pattern = RGB_PACK(0x17, 0x31, 0x1d); /* "Rockbox blue" */ - lcd_clear_display(); /* Call device specific init */ lcd_init_device(); @@ -94,43 +89,32 @@ int lcd_get_drawmode(void) return drawmode; } -void lcd_set_foreground(struct rgb color) +void lcd_set_foreground(unsigned color) { - fg_pattern = RGB_PACK(color.red, color.green, color.blue); + fg_pattern = color; } -struct rgb lcd_get_foreground(void) +unsigned lcd_get_foreground(void) { - struct rgb colour; - - colour.red = (fg_pattern >> 11) & 0x1f; - colour.green = (fg_pattern >> 5) & 0x3f; - colour.blue = fg_pattern & 0x1f; - return colour; + return fg_pattern; } -void lcd_set_background(struct rgb color) +void lcd_set_background(unsigned color) { - bg_pattern = RGB_PACK(color.red, color.green, color. blue); + bg_pattern = color; } -struct rgb lcd_get_background(void) +unsigned lcd_get_background(void) { - struct rgb colour; - - colour.red = (bg_pattern >> 11) & 0x1f; - colour.green = (bg_pattern >> 5) & 0x3f; - colour.blue = bg_pattern & 0x1f; - return colour; + return bg_pattern; } -void lcd_set_drawinfo(int mode, struct rgb fg_color, - struct rgb bg_color) +void lcd_set_drawinfo(int mode, unsigned fg_color, unsigned bg_color) { lcd_set_drawmode(mode); - lcd_set_foreground(fg_color); - lcd_set_background(bg_color); + fg_pattern = fg_color; + bg_pattern = bg_color; } void lcd_setmargins(int x, int y) diff --git a/firmware/drivers/lcd-h100.c b/firmware/drivers/lcd-h100.c index e8541f7621..1005cf6b5f 100644 --- a/firmware/drivers/lcd-h100.c +++ b/firmware/drivers/lcd-h100.c @@ -307,27 +307,27 @@ int lcd_get_drawmode(void) return drawmode; } -void lcd_set_foreground(int brightness) +void lcd_set_foreground(unsigned brightness) { fg_pattern = 0x55 * (~brightness & 3); } -int lcd_get_foreground(void) +unsigned lcd_get_foreground(void) { return ~fg_pattern & 3; } -void lcd_set_background(int brightness) +void lcd_set_background(unsigned brightness) { bg_pattern = 0x55 * (~brightness & 3); } -int lcd_get_background(void) +unsigned lcd_get_background(void) { return ~bg_pattern & 3; } -void lcd_set_drawinfo(int mode, int fg_brightness, int bg_brightness) +void lcd_set_drawinfo(int mode, unsigned fg_brightness, unsigned bg_brightness) { lcd_set_drawmode(mode); lcd_set_foreground(fg_brightness); -- cgit v1.2.3