1
0
Fork 0
forked from len0rd/rockbox

FS#11546: Adjustable brightness in lamp plugin

git-svn-id: svn://svn.rockbox.org/rockbox/trunk@28519 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
Teruaki Kawashima 2010-11-06 13:40:09 +00:00
parent f20582442f
commit 781f05e40d
2 changed files with 87 additions and 49 deletions

View file

@ -25,42 +25,56 @@
#include "plugin.h"
#include "lib/helper.h"
/* variable button definitions - only targets with a colour display */
#if defined(HAVE_LCD_COLOR)
/* variable button definitions.
- only targets with a colour display
LAMP_LEFT / LAMP_RIGHT: change the color
LAMP_NEXT / LAMP_PREV: (optional) change the color
- only targets which can set brightness
LAMP_UP / LAMP_DOWN: change the brightness
*/
#if defined(HAVE_LCD_COLOR) || defined(HAVE_BACKLIGHT_BRIGHTNESS)
#if (CONFIG_KEYPAD == IRIVER_H300_PAD)
# define LAMP_LEFT BUTTON_LEFT
# define LAMP_RIGHT BUTTON_RIGHT
# define LAMP_UP BUTTON_UP
# define LAMP_DOWN BUTTON_DOWN
#elif (CONFIG_KEYPAD == IPOD_4G_PAD)
# define LAMP_LEFT BUTTON_LEFT
# define LAMP_RIGHT BUTTON_RIGHT
# define LAMP_NEXT BUTTON_SCROLL_FWD
# define LAMP_PREV BUTTON_SCROLL_BACK
# define LAMP_UP BUTTON_SCROLL_FWD
# define LAMP_DOWN BUTTON_SCROLL_BACK
#elif (CONFIG_KEYPAD == IAUDIO_X5M5_PAD)
# define LAMP_LEFT BUTTON_LEFT
# define LAMP_RIGHT BUTTON_RIGHT
# define LAMP_UP BUTTON_UP
# define LAMP_DOWN BUTTON_DOWN
#elif (CONFIG_KEYPAD == GIGABEAT_PAD)
# define LAMP_LEFT BUTTON_LEFT
# define LAMP_RIGHT BUTTON_RIGHT
# define LAMP_UP BUTTON_UP
# define LAMP_DOWN BUTTON_DOWN
#elif (CONFIG_KEYPAD == GIGABEAT_S_PAD)
# define LAMP_LEFT BUTTON_LEFT
# define LAMP_RIGHT BUTTON_RIGHT
# define LAMP_UP BUTTON_UP
# define LAMP_DOWN BUTTON_DOWN
#elif (CONFIG_KEYPAD == SANSA_E200_PAD) || \
(CONFIG_KEYPAD == SANSA_FUZE_PAD)
# define LAMP_LEFT BUTTON_LEFT
# define LAMP_RIGHT BUTTON_RIGHT
# define LAMP_NEXT BUTTON_SCROLL_FWD
# define LAMP_PREV BUTTON_SCROLL_BACK
# define LAMP_UP BUTTON_SCROLL_FWD
# define LAMP_DOWN BUTTON_SCROLL_BACK
#elif (CONFIG_KEYPAD == SANSA_C200_PAD)
# define LAMP_LEFT BUTTON_LEFT
# define LAMP_RIGHT BUTTON_RIGHT
# define LAMP_UP BUTTON_UP
# define LAMP_DOWN BUTTON_DOWN
#elif (CONFIG_KEYPAD == IRIVER_H10_PAD)
# define LAMP_LEFT BUTTON_LEFT
@ -81,14 +95,20 @@
#elif CONFIG_KEYPAD == PHILIPS_HDD1630_PAD
# define LAMP_LEFT BUTTON_LEFT
# define LAMP_RIGHT BUTTON_RIGHT
# define LAMP_UP BUTTON_UP
# define LAMP_DOWN BUTTON_DOWN
#elif CONFIG_KEYPAD == PHILIPS_HDD6330_PAD
# define LAMP_LEFT BUTTON_LEFT
# define LAMP_RIGHT BUTTON_RIGHT
# define LAMP_UP BUTTON_UP
# define LAMP_DOWN BUTTON_DOWN
#elif CONFIG_KEYPAD == PHILIPS_SA9200_PAD
# define LAMP_LEFT BUTTON_PREV
# define LAMP_RIGHT BUTTON_NEXT
# define LAMP_UP BUTTON_UP
# define LAMP_DOWN BUTTON_DOWN
#elif CONFIG_KEYPAD == ONDAVX747_PAD
# define LAMP_LEFT BUTTON_VOL_DOWN
@ -103,11 +123,17 @@
#elif CONFIG_KEYPAD == PBELL_VIBE500_PAD
# define LAMP_LEFT BUTTON_PREV
# define LAMP_RIGHT BUTTON_NEXT
# define LAMP_UP BUTTON_UP
# define LAMP_DOWN BUTTON_DOWN
#elif CONFIG_KEYPAD == MPIO_HD200_PAD
# define LAMP_UP BUTTON_REW
# define LAMP_DOWN BUTTON_FF
#else
# error Missing key definitions for this keypad
#endif
#endif
#endif /* HAVE_LCD_COLOR || HAVE_BACKLIGHT_BRIGHTNESS */
#ifdef HAVE_TOUCHSCREEN
# ifndef LAMP_LEFT
@ -116,11 +142,11 @@
# ifndef LAMP_RIGHT
# define LAMP_RIGHT BUTTON_MIDRIGHT
# endif
# ifndef LAMP_NEXT
# define LAMP_NEXT BUTTON_TOPMIDDLE
# ifndef LAMP_UP
# define LAMP_UP BUTTON_TOPMIDDLE
# endif
# ifndef LAMP_PREV
# define LAMP_PREV BUTTON_BOTTOMMIDDLE
# ifndef LAMP_DOWN
# define LAMP_DOWN BUTTON_BOTTOMMIDDLE
# endif
#endif
@ -138,12 +164,12 @@ enum plugin_status plugin_start(const void* parameter)
{
enum plugin_status status = PLUGIN_OK;
long button;
bool quit = false;
(void)parameter;
#ifdef HAVE_LCD_COLOR
int cs = 0;
bool quit = false;
bool update = true;
bool update = false;
#endif /* HAVE_LCD_COLOR */
#if LCD_DEPTH > 1
@ -153,6 +179,7 @@ enum plugin_status plugin_start(const void* parameter)
#endif
#ifdef HAVE_BACKLIGHT_BRIGHTNESS
int current_brightness = MAX_BRIGHTNESS_SETTING;
backlight_brightness_set(MAX_BRIGHTNESS_SETTING);
#endif /* HAVE_BACKLIGHT_BRIGHTNESS */
#ifdef HAVE_BUTTONLIGHT_BRIGHTNESS
@ -172,9 +199,12 @@ enum plugin_status plugin_start(const void* parameter)
buttonlight_force_on();
#endif /* HAVE_BUTTON_LIGHT */
#ifdef HAVE_LCD_COLOR
rb->lcd_clear_display();
rb->lcd_update();
do
{
#ifdef HAVE_LCD_COLOR
if(update)
{
if(cs < 0)
@ -186,9 +216,11 @@ enum plugin_status plugin_start(const void* parameter)
rb->lcd_update();
update = false;
}
#endif /* HAVE_LCD_COLOR */
switch((button = rb->button_get_w_tmo(HZ*30)))
{
#ifdef HAVE_LCD_COLOR
case LAMP_RIGHT:
#ifdef LAMP_NEXT
case LAMP_NEXT:
@ -204,46 +236,39 @@ enum plugin_status plugin_start(const void* parameter)
cs--;
update = true;
break;
#endif /* HAVE_LCD_COLOR */
#ifdef HAVE_BACKLIGHT_BRIGHTNESS
case LAMP_UP:
case (LAMP_UP|BUTTON_REPEAT):
if (current_brightness < MAX_BRIGHTNESS_SETTING)
backlight_brightness_set(++current_brightness);
break;
case LAMP_DOWN:
case (LAMP_DOWN|BUTTON_REPEAT):
if (current_brightness > MIN_BRIGHTNESS_SETTING)
backlight_brightness_set(--current_brightness);
break;
#endif /* HAVE_BACKLIGHT_BRIGHTNESS */
case BUTTON_NONE:
/* time out */
break;
default:
if(button)
if(rb->default_event_handler(button) == SYS_USB_CONNECTED)
{
if(rb->default_event_handler(button) == SYS_USB_CONNECTED)
{
status = PLUGIN_USB_CONNECTED;
quit = true;
}
if(!(button & (BUTTON_REL|BUTTON_REPEAT))
&& !IS_SYSEVENT(button))
quit = true;
status = PLUGIN_USB_CONNECTED;
quit = true;
}
if(!(button & (BUTTON_REL|BUTTON_REPEAT))
&& !IS_SYSEVENT(button))
quit = true;
break;
}
rb->reset_poweroff_timer();
} while (!quit);
#else /* HAVE_LCD_COLOR */
rb->lcd_clear_display();
rb->lcd_update();
/* wait */
do
{
button = rb->button_get_w_tmo(HZ*30);
if(button)
{
if(rb->default_event_handler(button) == SYS_USB_CONNECTED)
{
status = PLUGIN_USB_CONNECTED;
break;
}
if(!IS_SYSEVENT(button))
break;
}
rb->reset_poweroff_timer();
} while (1);
#endif /*HAVE_LCD_COLOR */
/* restore */
backlight_use_settings();
#ifdef HAVE_BUTTON_LIGHT