From 3d1065a3ad1af4ea8b30f633870601b3afd67d68 Mon Sep 17 00:00:00 2001 From: dborth Date: Wed, 17 Jun 2009 07:45:46 +0000 Subject: [PATCH] only update battery images when required --- source/ngc/menu.cpp | 50 ++++++++++++++++++++++++++++++--------------- 1 file changed, 34 insertions(+), 16 deletions(-) diff --git a/source/ngc/menu.cpp b/source/ngc/menu.cpp index 5172b8c..6efc8b6 100644 --- a/source/ngc/menu.cpp +++ b/source/ngc/menu.cpp @@ -1246,8 +1246,12 @@ static int MenuGame() closeBtn.SetEffectGrow(); #ifdef HW_RVL - int i, level; + int i; char txt[3]; + bool status[4] = { false, false, false, false }; + int level[4] = { 0, 0, 0, 0 }; + bool newStatus; + int newLevel; GuiText * batteryTxt[4]; GuiImage * batteryImg[4]; GuiImage * batteryBarImg[4]; @@ -1336,24 +1340,38 @@ static int MenuGame() #ifdef HW_RVL for(i=0; i < 4; i++) { - if(WPAD_Probe(i, NULL) == WPAD_ERR_NONE) // controller connected + if(WPAD_Probe(i, NULL) == WPAD_ERR_NONE) { - level = (userInput[i].wpad.battery_level / 100.0) * 4; - if(level > 4) level = 4; - batteryBarImg[i]->SetTile(level); - - if(level == 0) - batteryImg[i]->SetImage(&batteryRed); - else - batteryImg[i]->SetImage(&battery); - - batteryBtn[i]->SetAlpha(255); + newStatus = true; + newLevel = (userInput[i].wpad.battery_level / 100.0) * 4; + if(newLevel > 4) newLevel = 4; } - else // controller not connected + else { - batteryBarImg[i]->SetTile(0); - batteryImg[i]->SetImage(&battery); - batteryBtn[i]->SetAlpha(150); + newStatus = false; + newLevel = 0; + } + + if(status[i] != newStatus || level[i] != newLevel) + { + if(newStatus == true) // controller connected + { + batteryBtn[i]->SetAlpha(255); + batteryBarImg[i]->SetTile(newLevel); + + if(newLevel == 0) + batteryImg[i]->SetImage(&batteryRed); + else + batteryImg[i]->SetImage(&battery); + } + else // controller not connected + { + batteryBtn[i]->SetAlpha(150); + batteryBarImg[i]->SetTile(0); + batteryImg[i]->SetImage(&battery); + } + status[i] = newStatus; + level[i] = newLevel; } } #endif