summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBjörn Stenberg <bjorn@haxx.se>2003-06-04 12:03:23 +0000
committerBjörn Stenberg <bjorn@haxx.se>2003-06-04 12:03:23 +0000
commit7eb6d002b41716836e9e0c969eb18353988a7ec9 (patch)
tree44826b377424788381b4146e5528a801b14673a3
parentc9da8ba6408429b371be855f56085297e5ad5866 (diff)
downloadrockbox-7eb6d002b41716836e9e0c969eb18353988a7ec9.zip
rockbox-7eb6d002b41716836e9e0c969eb18353988a7ec9.tar.gz
rockbox-7eb6d002b41716836e9e0c969eb18353988a7ec9.tar.bz2
rockbox-7eb6d002b41716836e9e0c969eb18353988a7ec9.tar.xz
Simplified and corrected status update. Contributions by Magnus Holmgren and Mats Lidell.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@3723 a1c6a512-1295-4272-9138-f99709370657
-rw-r--r--apps/status.c190
1 files changed, 59 insertions, 131 deletions
diff --git a/apps/status.c b/apps/status.c
index 9773bc6..7217568 100644
--- a/apps/status.c
+++ b/apps/status.c
@@ -36,14 +36,10 @@
static enum playmode current_mode = STATUS_STOP;
-#if defined(HAVE_LCD_CHARCELLS) || defined(HAVE_CHARGE_CTRL)
static long switch_tick;
static int battery_charge_step = 0;
-#ifdef HAVE_CHARGE_CTRL
static bool plug_state;
static bool battery_state;
-#endif
-#endif
struct status_info {
int battlevel;
@@ -111,137 +107,46 @@ void status_draw(bool force_redraw)
(void)force_redraw; /* players always "redraw" */
#endif
- info.battlevel = battery_level();
info.volume = mpeg_val2phys(SOUND_VOLUME, global_settings.volume);
info.inserted = charger_inserted();
+ info.battlevel = battery_level();
+ info.battery_safe = battery_level_safe();
-#if defined(HAVE_LCD_CHARCELLS)
- lcd_icon(ICON_VOLUME, true);
- if(info.volume > 10)
- lcd_icon(ICON_VOLUME_1, true);
- else
- lcd_icon(ICON_VOLUME_1, false);
- if(info.volume > 30)
- lcd_icon(ICON_VOLUME_2, true);
- else
- lcd_icon(ICON_VOLUME_2, false);
- if(info.volume > 50)
- lcd_icon(ICON_VOLUME_3, true);
- else
- lcd_icon(ICON_VOLUME_3, false);
- if(info.volume > 70)
- lcd_icon(ICON_VOLUME_4, true);
- else
- lcd_icon(ICON_VOLUME_4, false);
- if(info.volume > 90)
- lcd_icon(ICON_VOLUME_5, true);
- else
- lcd_icon(ICON_VOLUME_5, false);
-
- switch(current_mode)
- {
- case STATUS_PLAY:
- lcd_icon(ICON_PLAY, true);
- lcd_icon(ICON_PAUSE, false);
- break;
-
- case STATUS_STOP:
- lcd_icon(ICON_PLAY, false);
- lcd_icon(ICON_PAUSE, false);
- break;
-
- case STATUS_PAUSE:
- lcd_icon(ICON_PLAY, false);
- lcd_icon(ICON_PAUSE, true);
- break;
-
- default:
- break;
- }
- if(info.inserted)
- {
- global_settings.runtime = 0;
- if(TIME_AFTER(current_tick, switch_tick))
- {
- lcd_icon(ICON_BATTERY, true);
- lcd_icon(ICON_BATTERY_1, false);
- lcd_icon(ICON_BATTERY_2, false);
- lcd_icon(ICON_BATTERY_3, false);
- switch(battery_charge_step)
- {
- case 0:
- battery_charge_step++;
- break;
- case 1:
- lcd_icon(ICON_BATTERY_1, true);
- battery_charge_step++;
- break;
- case 2:
- lcd_icon(ICON_BATTERY_1, true);
- lcd_icon(ICON_BATTERY_2, true);
- battery_charge_step++;
- break;
- case 3:
- lcd_icon(ICON_BATTERY_1, true);
- lcd_icon(ICON_BATTERY_2, true);
- lcd_icon(ICON_BATTERY_3, true);
- battery_charge_step = 0;
- break;
- default:
- battery_charge_step = 0;
- break;
- }
- switch_tick = current_tick + (HZ/2);
- }
- } else {
- lcd_icon(ICON_BATTERY, true);
- if(info.battlevel > 25)
- lcd_icon(ICON_BATTERY_1, true);
- else
- lcd_icon(ICON_BATTERY_1, false);
- if(info.battlevel > 50)
- lcd_icon(ICON_BATTERY_2, true);
- else
- lcd_icon(ICON_BATTERY_2, false);
- if(info.battlevel > 75)
- lcd_icon(ICON_BATTERY_3, true);
- else
- lcd_icon(ICON_BATTERY_3, false);
- }
-
- lcd_icon(ICON_REPEAT, global_settings.repeat_mode != REPEAT_OFF);
- lcd_icon(ICON_1, global_settings.repeat_mode == REPEAT_ONE);
-
- lcd_icon(ICON_RECORD, record);
- lcd_icon(ICON_AUDIO, audio);
- lcd_icon(ICON_PARAM, param);
- lcd_icon(ICON_USB, usb);
-
-#endif
#ifdef HAVE_LCD_BITMAP
-
tm = get_time();
info.hour = tm->tm_hour;
info.minute = tm->tm_min;
info.shuffle = global_settings.playlist_shuffle;
info.keylock = keys_locked;
- info.battery_safe = battery_level_safe();
info.repeat = global_settings.repeat_mode;
+ /* only redraw if forced to, or info has changed */
if (force_redraw ||
info.inserted ||
!info.battery_safe ||
- memcmp(&info, &lastinfo, sizeof(struct status_info))) {
+ memcmp(&info, &lastinfo, sizeof(struct status_info)))
+ {
lcd_clearrect(0,0,LCD_WIDTH,8);
-
-#ifdef HAVE_CHARGE_CTRL /* Recorder */
- if(info.inserted) {
+#else
+ /* players always "redraw" */
+ {
+#endif
+
+ if (info.inserted) {
battery_state = true;
plug_state = true;
- if (charge_state > 0) /* charge || top off || trickle */
+#ifdef HAVE_CHARGE_CTRL
+ /* zero battery run time if charging */
+ if (charge_state > 0)
global_settings.runtime = 0;
- if (charge_state == 1) { /* animate battery if charging */
- info.battlevel = battery_charge_step * 34; /* 34 for a better look */
+
+ /* animate battery if charging */
+ if (charge_state == 1) {
+#else
+ {
+#endif
+ /* animate in three steps (34% per step for a better look) */
+ info.battlevel = battery_charge_step * 34;
if (info.battlevel > 100)
info.battlevel = 100;
if(TIME_AFTER(current_tick, switch_tick)) {
@@ -252,23 +157,20 @@ void status_draw(bool force_redraw)
}
else {
plug_state=false;
- if(!info.battery_safe)
+ if (info.battery_safe)
battery_state = true;
- else /* blink battery if level is low */
+ else {
+ /* blink battery if level is low */
if(TIME_AFTER(current_tick, switch_tick)) {
switch_tick = current_tick+HZ;
battery_state =! battery_state;
}
+ }
}
-
- statusbar_icon_battery(info.battlevel, plug_state);
-#else
-#ifdef HAVE_FMADC /* FM */
- statusbar_icon_battery(info.battlevel, charger_inserted());
-#else /* Player */
- statusbar_icon_battery(info.battlevel, false);
-#endif /* HAVE_FMADC */
-#endif /* HAVE_CHARGE_CTRL */
+
+#ifdef HAVE_LCD_BITMAP
+ if (battery_state)
+ statusbar_icon_battery(info.battlevel, plug_state);
statusbar_icon_volume(info.volume);
statusbar_icon_play_state(current_mode + Icon_Play);
switch (info.repeat) {
@@ -280,17 +182,43 @@ void status_draw(bool force_redraw)
statusbar_icon_play_mode(Icon_Repeat);
break;
}
- if(info.shuffle)
+ if (info.shuffle)
statusbar_icon_shuffle();
if (info.keylock)
statusbar_icon_lock();
#ifdef HAVE_RTC
statusbar_time(info.hour, info.minute);
#endif
-
lcd_update_rect(0, 0, LCD_WIDTH, STATUSBAR_HEIGHT);
+ lastinfo = info;
+#endif
}
- lastinfo = info;
+
+#if defined(HAVE_LCD_CHARCELLS)
+ lcd_icon(ICON_BATTERY, battery_state);
+ lcd_icon(ICON_BATTERY_1, info.battlevel > 25);
+ lcd_icon(ICON_BATTERY_2, info.battlevel > 50);
+ lcd_icon(ICON_BATTERY_3, info.battlevel > 75);
+
+ lcd_icon(ICON_VOLUME, true);
+ lcd_icon(ICON_VOLUME_1, info.volume > 10);
+ lcd_icon(ICON_VOLUME_2, info.volume > 30);
+ lcd_icon(ICON_VOLUME_3, info.volume > 50);
+ lcd_icon(ICON_VOLUME_4, info.volume > 70);
+ lcd_icon(ICON_VOLUME_5, info.volume > 90);
+
+ lcd_icon(ICON_PLAY, current_mode == STATUS_PLAY);
+ lcd_icon(ICON_PAUSE, current_mode == STATUS_PAUSE);
+
+ lcd_icon(ICON_REPEAT, global_settings.repeat_mode != REPEAT_OFF);
+ lcd_icon(ICON_1, global_settings.repeat_mode == REPEAT_ONE);
+
+ lcd_icon(ICON_RECORD, record);
+ lcd_icon(ICON_AUDIO, audio);
+ lcd_icon(ICON_PARAM, param);
+ lcd_icon(ICON_USB, usb);
#endif
+
}
+