diff options
author | David Phillips <david@sighup.nz> | 2018-06-06 22:30:41 +1200 |
---|---|---|
committer | David Phillips <david@sighup.nz> | 2018-06-06 22:30:41 +1200 |
commit | 7f6ecb8d49854c8cfe83457c396de622918bbddb (patch) | |
tree | 850cc38dafa315ca2f00563b5dfde84370879b5c | |
parent | 7ae83792cc044a1b8abfea3fc18e47ffb4fc5d97 (diff) | |
download | paramano-7f6ecb8d49854c8cfe83457c396de622918bbddb.tar.xz |
Only update battery icon on change
-rw-r--r-- | bat_tray.c | 42 |
1 files changed, 32 insertions, 10 deletions
@@ -9,6 +9,7 @@ static GtkStatusIcon* tray; static char tooltip_text[1024]; +static int old_rounded; static int bat_num; // Shortcoming: we only detect one battery static char CHARGE_VALUE_PATH[1024]; static char CHARGE_STATE_PATH[1024]; @@ -23,6 +24,27 @@ int get_bat_percent() /*********************************************************************** + * Get battery level percentage, rounded to one of: 0, 20, 40, 60, 80 + * or 100. These values match the icon files + **********************************************************************/ +int get_bat_percent_rounded() +{ + int rounded = 0; + + rounded = 20 * (int)((get_bat_percent() + 10) / 20); + + /* cap rounded value to safe bounds */ + if (rounded < 0) + rounded = 0; + + if (rounded > 100) + rounded = 100; + + return rounded; +} + + +/*********************************************************************** * Return number of seconds until battery is fully charged/discharged **********************************************************************/ long get_bat_seconds_left() @@ -140,15 +162,13 @@ static gboolean update() char icon_file[1024]; int rounded = 0; - /* Round percentage to 0, 20, 40, 60, 80 or 100 */ - rounded = 20 * (int)((get_bat_percent() + 10) / 20); - - /* cap rounded value to safe bounds */ - if (rounded < 0) - rounded = 0; + update_tooltip_cache(); - if (rounded > 100) - rounded = 100; + /* if rounded hasn't changed, don't spend time changing icon */ + rounded = get_bat_percent_rounded(); + if (rounded == old_rounded) { + return true; + } switch (get_battery_state()) { @@ -165,7 +185,6 @@ static gboolean update() break; } - update_tooltip_cache(); gtk_status_icon_set_from_file(tray, icon_file); return true; } @@ -192,7 +211,10 @@ void bat_tray_init() g_signal_connect(G_OBJECT(tray), "query-tooltip", GTK_SIGNAL_FUNC(show_tooltip), NULL); g_timeout_add(120000, update, NULL); - /* Force useful cached tooltip text, force meaningful icon */ + /* trigger icon refresh in update() below */ + old_rounded = get_bat_percent_rounded() - 1; + + /* pre-load cached tooltip text */ update(); } |