diff --git a/apps/debug_menu.c b/apps/debug_menu.c index 1288d9a..18cdfaa 100644 --- a/apps/debug_menu.c +++ b/apps/debug_menu.c @@ -1489,13 +1489,12 @@ static bool tsc2100_debug(void) * The power_history array is updated in power_thread of powermgmt.c. */ -#define BAT_LAST_VAL MIN(LCD_WIDTH, POWER_HISTORY_LEN) #define BAT_YSPACE (LCD_HEIGHT - 20) static bool view_battery(void) { int view = 0; - int i, x, y; + int i, x, y, y1, y2, grid, graph; unsigned short maxv, minv; lcd_setfont(FONT_SYSFIXED); @@ -1508,7 +1507,7 @@ static bool view_battery(void) /* Find maximum and minimum voltage for scaling */ minv = power_history[0]; maxv = minv + 1; - for (i = 1; i < BAT_LAST_VAL && power_history[i]; i++) { + for (i = 1; i < POWER_HISTORY_LEN && power_history[i]; i++) { if (power_history[i] > maxv) maxv = power_history[i]; if (power_history[i] < minv) @@ -1519,18 +1518,59 @@ static bool view_battery(void) power_history[0] % 1000); lcd_putsf(0, 1, "scale %d.%03d-%d.%03dV", minv / 1000, minv % 1000, maxv / 1000, maxv % 1000); + + /* horizontal grid autoscaled to 5/50mV + * depending on data range + */ + i = 1; + if ((maxv - minv) > 50) + grid = 50; + else + grid = 5; + while ((y = (minv - (minv % grid)+i*grid)) < maxv) + { + graph = ((y-minv)*BAT_YSPACE)/(maxv-minv); + graph = LCD_HEIGHT-1 - graph; + + /* draw dotted horizontal grid line */ + for (x=0; x= 0; i--) { - y = (power_history[i] - minv) * BAT_YSPACE / (maxv - minv); - lcd_set_drawmode(DRMODE_SOLID|DRMODE_INVERSEVID); - lcd_vline(x, LCD_HEIGHT-1, 20); - lcd_set_drawmode(DRMODE_SOLID); - lcd_vline(x, LCD_HEIGHT-1, - MIN(MAX(LCD_HEIGHT-1 - y, 20), LCD_HEIGHT-1)); - x++; + /* draw plot of power history + * skip empty entries + */ + for (i = (POWER_HISTORY_LEN) - 1; i > 0; i--) + { + if (power_history[i] && power_history[i-1]) + { + y1 = (power_history[i] - minv) * BAT_YSPACE / + (maxv - minv); + y1 = MIN(MAX(LCD_HEIGHT-1 - y1, 20), + LCD_HEIGHT-1); + y2 = (power_history[i-1] - minv) * BAT_YSPACE / + (maxv - minv); + y2 = MIN(MAX(LCD_HEIGHT-1 - y2, 20), + LCD_HEIGHT-1); + + lcd_set_drawmode(DRMODE_SOLID); + + /* make line thicker */ + lcd_drawline(((x*LCD_WIDTH)/(POWER_HISTORY_LEN)), + y1, + (((x+1)*LCD_WIDTH)/(POWER_HISTORY_LEN)), + y2); + lcd_drawline(((x*LCD_WIDTH)/(POWER_HISTORY_LEN))+1, + y1+1, + (((x+1)*LCD_WIDTH)/(POWER_HISTORY_LEN))+1, + y2+1); + x++; + } } - break; case 1: /* status: */