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:
parent
5079812031
commit
ed8b3bb74b
1 changed files with 34 additions and 11 deletions
|
@ -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;
|
||||||
|
|
Loading…
Reference in a new issue