Accept FS#7080 by Mauricio Peccorini with some minor changes by me:

- show more info in the stopwatch screen, and use the whole display for lap times


git-svn-id: svn://svn.rockbox.org/rockbox/trunk@13271 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
Jonathan Gordon 2007-04-26 13:52:53 +00:00
parent 5079812031
commit ed8b3bb74b

View file

@ -22,16 +22,13 @@
PLUGIN_HEADER PLUGIN_HEADER
#ifdef HAVE_LCD_BITMAP #ifdef HAVE_LCD_BITMAP
#define LAP_LINES 6
#define TIMER_Y 1 #define TIMER_Y 1
#else #else
#define LAP_LINES 1
#define TIMER_Y 0 #define TIMER_Y 0
#endif #endif
#define LAP_Y TIMER_Y+1 #define LAP_Y TIMER_Y+1
#define MAX_LAPS 10 #define MAX_LAPS 64
#define MAX_SCROLL (MAX_LAPS - LAP_LINES)
/* variable button definitions */ /* variable button definitions */
#if CONFIG_KEYPAD == RECORDER_PAD #if CONFIG_KEYPAD == RECORDER_PAD
@ -148,9 +145,30 @@ static void ticks_to_string(int ticks,int lap,int buflen, char * buf)
} }
else else
{ {
rb->snprintf(buf, buflen,
"%2d %2d:%02d:%02d.%02d", if (lap > 1)
lap, hours, minutes, seconds, cs); {
int last_ticks, last_hours, last_minutes, last_seconds, last_cs;
last_ticks = lap_times[(lap-1)%MAX_LAPS] - lap_times[(lap-2)%MAX_LAPS];
last_hours = last_ticks / (HZ * 3600);
last_ticks -= (HZ * last_hours * 3600);
last_minutes = last_ticks / (HZ * 60);
last_ticks -= (HZ * last_minutes * 60);
last_seconds = last_ticks / HZ;
last_ticks -= (HZ * last_seconds);
last_cs = last_ticks;
rb->snprintf(buf, buflen,
"%2d %2d:%02d:%02d.%02d [%2d:%02d:%02d.%02d]",
lap, hours, minutes, seconds, cs, last_hours,
last_minutes, last_seconds, last_cs);
}
else
{
rb->snprintf(buf, buflen,
"%2d %2d:%02d:%02d.%02d",
lap, hours, minutes, seconds, cs);
}
} }
} }
@ -161,16 +179,21 @@ enum plugin_status plugin_start(struct plugin_api* api, void* parameter)
int lap; int lap;
int done = false; int done = false;
bool update_lap = true; bool update_lap = true;
int lines, h;
(void)parameter; (void)parameter;
rb = api; rb = api;
#ifdef HAVE_LCD_BITMAP #ifdef HAVE_LCD_BITMAP
rb->lcd_setfont(FONT_UI); rb->lcd_setfont(FONT_UI);
rb->lcd_getstringsize("M", NULL, &h);
lines = (LCD_HEIGHT / h) - (LAP_Y);
#else
lines = 1;
#endif #endif
rb->lcd_clear_display(); rb->lcd_clear_display();
while (!done) while (!done)
{ {
if (counting) if (counting)
@ -188,7 +211,7 @@ enum plugin_status plugin_start(struct plugin_api* api, void* parameter)
if(update_lap) if(update_lap)
{ {
lap_start = curr_lap - lap_scroll; lap_start = curr_lap - lap_scroll;
for (lap = lap_start; lap > lap_start - LAP_LINES; lap--) for (lap = lap_start; lap > lap_start - lines; lap--)
{ {
if (lap > 0) if (lap > 0)
{ {
@ -272,8 +295,8 @@ enum plugin_status plugin_start(struct plugin_api* api, void* parameter)
/* Scroll Lap timer down */ /* Scroll Lap timer down */
case STOPWATCH_SCROLL_DOWN: case STOPWATCH_SCROLL_DOWN:
if ((lap_scroll < curr_lap - LAP_LINES) && if ((lap_scroll < curr_lap - lines) &&
(lap_scroll < MAX_SCROLL) ) (lap_scroll < (MAX_LAPS - lines)) )
{ {
lap_scroll ++; lap_scroll ++;
update_lap = true; update_lap = true;