*Compatibility issue fix for some Seagate HDDs

*Added left/right on game info screen to go to the next/previous game
*Fixed loading of titles cache settings
*Changed to show always the first game as first visible cover on carousel
This commit is contained in:
dimok321 2011-02-12 18:26:18 +00:00
parent d52b7e0ac3
commit 1392093741
8 changed files with 115 additions and 159 deletions

View File

@ -2,8 +2,8 @@
<app version="1"> <app version="1">
<name> USB Loader GX</name> <name> USB Loader GX</name>
<coder>USB Loader GX Team</coder> <coder>USB Loader GX Team</coder>
<version>2.0 r1070</version> <version>2.0 r1071</version>
<release_date>201102111742</release_date> <release_date>201102120952</release_date>
<no_ios_reload/> <no_ios_reload/>
<short_description>Loads games from USB-devices</short_description> <short_description>Loads games from USB-devices</short_description>
<long_description>USB Loader GX is a libwiigui based USB iso loader with a wii-like GUI. You can install games to your HDDs and boot them with shorter loading times. <long_description>USB Loader GX is a libwiigui based USB iso loader with a wii-like GUI. You can install games to your HDDs and boot them with shorter loading times.

View File

@ -52,7 +52,7 @@ GuiGameCarousel::GuiGameCarousel(int w, int h, const char *themePath, int select
width = w; width = w;
height = h; height = h;
pagesize = (gameList.size() < 11) ? gameList.size() : 11; pagesize = (gameList.size() < 11) ? gameList.size() : 11;
listOffset = (selectedGame >= 0 && selectedGame < gameList.size()) ? selectedGame : 0; listOffset = (gameList.size() < 11) ? 0 : gameList.size()-2;
selectable = true; selectable = true;
selectedItem = -1; selectedItem = -1;
focus = 1; // allow focus focus = 1; // allow focus

View File

@ -980,11 +980,8 @@ int GameBrowseMenu::MainLoop()
if (SelectedGame >= 0 && SelectedGame < (s32) gameList.size()) if (SelectedGame >= 0 && SelectedGame < (s32) gameList.size())
{ {
rockout(SelectedGame); rockout(SelectedGame);
struct discHdr *header = gameList[SelectedGame];
char IDfull[7];
snprintf(IDfull, sizeof(IDfull), "%s", (char *) header->id);
SetState(STATE_DISABLED); SetState(STATE_DISABLED);
int choice = showGameInfo(IDfull); int choice = showGameInfo(SelectedGame);
SetState(STATE_DEFAULT); SetState(STATE_DEFAULT);
rockout(SelectedGame, 2); rockout(SelectedGame, 2);
if (choice == 2) if (choice == 2)

View File

@ -575,11 +575,8 @@ int GameWindow::MainLoop()
} }
else if(detailsBtn->GetState() == STATE_CLICKED) else if(detailsBtn->GetState() == STATE_CLICKED)
{ {
char gameID[7];
struct discHdr * header = (mountMethod ? dvdheader : gameList[gameSelected]);
snprintf(gameID, sizeof(gameID), (char *) header->id);
diskImg->SetState(STATE_DISABLED); diskImg->SetState(STATE_DISABLED);
showGameInfo(gameID); showGameInfo(gameSelected);
mainWindow->SetState(STATE_DISABLED); mainWindow->SetState(STATE_DISABLED);
this->SetState(STATE_DEFAULT); this->SetState(STATE_DEFAULT);
diskImg->SetState(STATE_DEFAULT); diskImg->SetState(STATE_DEFAULT);

View File

@ -25,10 +25,13 @@
#include "utils/ShowError.h" #include "utils/ShowError.h"
#include "BoxCover/BoxCover.hpp" #include "BoxCover/BoxCover.hpp"
extern int mountMethod;
extern struct discHdr *dvdheader;
/**************************************************************************** /****************************************************************************
* gameinfo * gameinfo
***************************************************************************/ ***************************************************************************/
int showGameInfo(char *ID) static int InternalShowGameInfo(char *ID)
{ {
HaltGui();//put this first to try to get rid of the code dump caused by loading this window at the same time as loading images from the SD card HaltGui();//put this first to try to get rid of the code dump caused by loading this window at the same time as loading images from the SD card
mainWindow->SetState(STATE_DISABLED); mainWindow->SetState(STATE_DISABLED);
@ -57,8 +60,6 @@ int showGameInfo(char *ID)
XML_DB.CloseFile(); XML_DB.CloseFile();
bool showmeminfo = false;
int choice = -1; int choice = -1;
int titley = 10; int titley = 10;
int marginY = titley + 40; int marginY = titley + 40;
@ -136,9 +137,8 @@ int showGameInfo(char *ID)
gameinfoWindow.SetAlignment(ALIGN_CENTRE, ALIGN_MIDDLE); gameinfoWindow.SetAlignment(ALIGN_CENTRE, ALIGN_MIDDLE);
gameinfoWindow.SetPosition(0, -50); gameinfoWindow.SetPosition(0, -50);
GuiWindow gameinfoWindow2(600, 308); GuiWindow InfoWindow(600, 308);
gameinfoWindow2.SetAlignment(ALIGN_CENTRE, ALIGN_MIDDLE); InfoWindow.SetAlignment(ALIGN_LEFT, ALIGN_TOP);
gameinfoWindow2.SetPosition(0, -50);
GuiWindow txtWindow(350, 270); GuiWindow txtWindow(350, 270);
txtWindow.SetAlignment(ALIGN_CENTRE, ALIGN_RIGHT); txtWindow.SetAlignment(ALIGN_CENTRE, ALIGN_RIGHT);
@ -172,6 +172,20 @@ int showGameInfo(char *ID)
GuiTrigger trigA_Simple; GuiTrigger trigA_Simple;
trigA_Simple.SetSimpleTrigger(-1, WPAD_BUTTON_A | WPAD_CLASSIC_BUTTON_A, PAD_BUTTON_A); trigA_Simple.SetSimpleTrigger(-1, WPAD_BUTTON_A | WPAD_CLASSIC_BUTTON_A, PAD_BUTTON_A);
GuiTrigger trigLeft;
trigLeft.SetButtonOnlyTrigger(-1, WPAD_BUTTON_LEFT | WPAD_CLASSIC_BUTTON_LEFT, PAD_BUTTON_LEFT);
GuiTrigger trigRight;
trigRight.SetButtonOnlyTrigger(-1, WPAD_BUTTON_RIGHT | WPAD_CLASSIC_BUTTON_RIGHT, PAD_BUTTON_RIGHT);
GuiButton LeftBtn(0, 0);
LeftBtn.SetTrigger(&trigLeft);
if(mountMethod == 0) gameinfoWindow.Append(&LeftBtn);
GuiButton RightBtn(0, 0);
RightBtn.SetTrigger(&trigRight);
if(mountMethod == 0) gameinfoWindow.Append(&RightBtn);
GuiButton coverBtn(180, 250); GuiButton coverBtn(180, 250);
coverBtn.SetPosition(20, 20); coverBtn.SetPosition(20, 20);
coverBtn.SetTrigger(&trigA_Simple); coverBtn.SetTrigger(&trigA_Simple);
@ -381,7 +395,7 @@ int showGameInfo(char *ID)
playersImg->SetWidescreen(Settings.widescreen); playersImg->SetWidescreen(Settings.widescreen);
playersImg->SetPosition(intputX, inputY); playersImg->SetPosition(intputX, inputY);
playersImg->SetAlignment(0, 4); playersImg->SetAlignment(0, 4);
gameinfoWindow.Append(playersImg); InfoWindow.Append(playersImg);
intputX += (Settings.widescreen ? playersImg->GetWidth() * .8 : playersImg->GetWidth()) + 5; intputX += (Settings.widescreen ? playersImg->GetWidth() * .8 : playersImg->GetWidth()) + 5;
} }
@ -392,7 +406,7 @@ int showGameInfo(char *ID)
motionplusImg->SetWidescreen(Settings.widescreen); motionplusImg->SetWidescreen(Settings.widescreen);
motionplusImg->SetPosition(intputX, inputY); motionplusImg->SetPosition(intputX, inputY);
motionplusImg->SetAlignment(0, 4); motionplusImg->SetAlignment(0, 4);
gameinfoWindow.Append(motionplusImg); InfoWindow.Append(motionplusImg);
intputX += (Settings.widescreen ? motionplusImg->GetWidth() * .8 : motionplusImg->GetWidth()) + 5; intputX += (Settings.widescreen ? motionplusImg->GetWidth() * .8 : motionplusImg->GetWidth()) + 5;
} }
if (nunchuk == 1) if (nunchuk == 1)
@ -401,7 +415,7 @@ int showGameInfo(char *ID)
nunchukImg->SetWidescreen(Settings.widescreen); nunchukImg->SetWidescreen(Settings.widescreen);
nunchukImg->SetPosition(intputX, inputY); nunchukImg->SetPosition(intputX, inputY);
nunchukImg->SetAlignment(0, 4); nunchukImg->SetAlignment(0, 4);
gameinfoWindow.Append(nunchukImg); InfoWindow.Append(nunchukImg);
intputX += (Settings.widescreen ? nunchukImg->GetWidth() * .8 : nunchukImg->GetWidth()) + 5; intputX += (Settings.widescreen ? nunchukImg->GetWidth() * .8 : nunchukImg->GetWidth()) + 5;
} }
if (classiccontroller == 1) if (classiccontroller == 1)
@ -410,7 +424,7 @@ int showGameInfo(char *ID)
classiccontrollerImg->SetWidescreen(Settings.widescreen); classiccontrollerImg->SetWidescreen(Settings.widescreen);
classiccontrollerImg->SetPosition(intputX, inputY); classiccontrollerImg->SetPosition(intputX, inputY);
classiccontrollerImg->SetAlignment(0, 4); classiccontrollerImg->SetAlignment(0, 4);
gameinfoWindow.Append(classiccontrollerImg); InfoWindow.Append(classiccontrollerImg);
intputX += (Settings.widescreen ? classiccontrollerImg->GetWidth() * .8 : classiccontrollerImg->GetWidth()) + 5; intputX += (Settings.widescreen ? classiccontrollerImg->GetWidth() * .8 : classiccontrollerImg->GetWidth()) + 5;
} }
if (gamecube == 1) if (gamecube == 1)
@ -419,7 +433,7 @@ int showGameInfo(char *ID)
gcImg->SetWidescreen(Settings.widescreen); gcImg->SetWidescreen(Settings.widescreen);
gcImg->SetPosition(intputX, inputY); gcImg->SetPosition(intputX, inputY);
gcImg->SetAlignment(0, 4); gcImg->SetAlignment(0, 4);
gameinfoWindow.Append(gcImg); InfoWindow.Append(gcImg);
intputX += (Settings.widescreen ? gcImg->GetWidth() * .8 : gcImg->GetWidth()) + 5; intputX += (Settings.widescreen ? gcImg->GetWidth() * .8 : gcImg->GetWidth()) + 5;
} }
if (wheel == 1) if (wheel == 1)
@ -428,7 +442,7 @@ int showGameInfo(char *ID)
wheelImg->SetWidescreen(Settings.widescreen); wheelImg->SetWidescreen(Settings.widescreen);
wheelImg->SetPosition(intputX, inputY); wheelImg->SetPosition(intputX, inputY);
wheelImg->SetAlignment(0, 4); wheelImg->SetAlignment(0, 4);
gameinfoWindow.Append(wheelImg); InfoWindow.Append(wheelImg);
intputX += (Settings.widescreen ? wheelImg->GetWidth() * .8 : wheelImg->GetWidth()) + 5; intputX += (Settings.widescreen ? wheelImg->GetWidth() * .8 : wheelImg->GetWidth()) + 5;
} }
if (guitar == 1) if (guitar == 1)
@ -437,7 +451,7 @@ int showGameInfo(char *ID)
guitarImg->SetWidescreen(Settings.widescreen); guitarImg->SetWidescreen(Settings.widescreen);
guitarImg->SetPosition(intputX, inputY); guitarImg->SetPosition(intputX, inputY);
guitarImg->SetAlignment(0, 4); guitarImg->SetAlignment(0, 4);
gameinfoWindow.Append(guitarImg); InfoWindow.Append(guitarImg);
intputX += (Settings.widescreen ? guitarImg->GetWidth() * .8 : guitarImg->GetWidth()) + 5; intputX += (Settings.widescreen ? guitarImg->GetWidth() * .8 : guitarImg->GetWidth()) + 5;
} }
if (drums == 1) if (drums == 1)
@ -446,7 +460,7 @@ int showGameInfo(char *ID)
drumsImg->SetWidescreen(Settings.widescreen); drumsImg->SetWidescreen(Settings.widescreen);
drumsImg->SetPosition(intputX, inputY); drumsImg->SetPosition(intputX, inputY);
drumsImg->SetAlignment(0, 4); drumsImg->SetAlignment(0, 4);
gameinfoWindow.Append(drumsImg); InfoWindow.Append(drumsImg);
intputX += (Settings.widescreen ? drumsImg->GetWidth() * .8 : drumsImg->GetWidth()) + 5; intputX += (Settings.widescreen ? drumsImg->GetWidth() * .8 : drumsImg->GetWidth()) + 5;
} }
if (microphone == 1) if (microphone == 1)
@ -455,7 +469,7 @@ int showGameInfo(char *ID)
microphoneImg->SetWidescreen(Settings.widescreen); microphoneImg->SetWidescreen(Settings.widescreen);
microphoneImg->SetPosition(intputX, inputY); microphoneImg->SetPosition(intputX, inputY);
microphoneImg->SetAlignment(0, 4); microphoneImg->SetAlignment(0, 4);
gameinfoWindow.Append(microphoneImg); InfoWindow.Append(microphoneImg);
intputX += (Settings.widescreen ? microphoneImg->GetWidth() * .8 : microphoneImg->GetWidth()) + 5; intputX += (Settings.widescreen ? microphoneImg->GetWidth() * .8 : microphoneImg->GetWidth()) + 5;
} }
if (zapper == 1) if (zapper == 1)
@ -464,7 +478,7 @@ int showGameInfo(char *ID)
zapperImg->SetWidescreen(Settings.widescreen); zapperImg->SetWidescreen(Settings.widescreen);
zapperImg->SetPosition(intputX, inputY); zapperImg->SetPosition(intputX, inputY);
zapperImg->SetAlignment(0, 4); zapperImg->SetAlignment(0, 4);
gameinfoWindow.Append(zapperImg); InfoWindow.Append(zapperImg);
intputX += (Settings.widescreen ? zapperImg->GetWidth() * .8 : zapperImg->GetWidth()) + 5; intputX += (Settings.widescreen ? zapperImg->GetWidth() * .8 : zapperImg->GetWidth()) + 5;
} }
if (wiispeak == 1) if (wiispeak == 1)
@ -473,7 +487,7 @@ int showGameInfo(char *ID)
wiispeakImg->SetWidescreen(Settings.widescreen); wiispeakImg->SetWidescreen(Settings.widescreen);
wiispeakImg->SetPosition(intputX, inputY); wiispeakImg->SetPosition(intputX, inputY);
wiispeakImg->SetAlignment(0, 4); wiispeakImg->SetAlignment(0, 4);
gameinfoWindow.Append(wiispeakImg); InfoWindow.Append(wiispeakImg);
intputX += (Settings.widescreen ? wiispeakImg->GetWidth() * .8 : wiispeakImg->GetWidth()) + 5; intputX += (Settings.widescreen ? wiispeakImg->GetWidth() * .8 : wiispeakImg->GetWidth()) + 5;
} }
if (nintendods == 1) if (nintendods == 1)
@ -482,7 +496,7 @@ int showGameInfo(char *ID)
nintendodsImg->SetWidescreen(Settings.widescreen); nintendodsImg->SetWidescreen(Settings.widescreen);
nintendodsImg->SetPosition(intputX, inputY); nintendodsImg->SetPosition(intputX, inputY);
nintendodsImg->SetAlignment(0, 4); nintendodsImg->SetAlignment(0, 4);
gameinfoWindow.Append(nintendodsImg); InfoWindow.Append(nintendodsImg);
intputX += (Settings.widescreen ? nintendodsImg->GetWidth() * .8 : nintendodsImg->GetWidth()) + 5; intputX += (Settings.widescreen ? nintendodsImg->GetWidth() * .8 : nintendodsImg->GetWidth()) + 5;
} }
if (dancepad == 1) if (dancepad == 1)
@ -491,7 +505,7 @@ int showGameInfo(char *ID)
dancepadImg->SetWidescreen(Settings.widescreen); dancepadImg->SetWidescreen(Settings.widescreen);
dancepadImg->SetPosition(intputX, inputY); dancepadImg->SetPosition(intputX, inputY);
dancepadImg->SetAlignment(0, 4); dancepadImg->SetAlignment(0, 4);
gameinfoWindow.Append(dancepadImg); InfoWindow.Append(dancepadImg);
intputX += (Settings.widescreen ? dancepadImg->GetWidth() * .8 : dancepadImg->GetWidth()) + 5; intputX += (Settings.widescreen ? dancepadImg->GetWidth() * .8 : dancepadImg->GetWidth()) + 5;
} }
if (balanceboard == 1) if (balanceboard == 1)
@ -500,7 +514,7 @@ int showGameInfo(char *ID)
balanceboardImg->SetWidescreen(Settings.widescreen); balanceboardImg->SetWidescreen(Settings.widescreen);
balanceboardImg->SetPosition(intputX, inputY); balanceboardImg->SetPosition(intputX, inputY);
balanceboardImg->SetAlignment(0, 4); balanceboardImg->SetAlignment(0, 4);
gameinfoWindow.Append(balanceboardImg); InfoWindow.Append(balanceboardImg);
intputX += (Settings.widescreen ? balanceboardImg->GetWidth() * .8 : balanceboardImg->GetWidth()) + 5; intputX += (Settings.widescreen ? balanceboardImg->GetWidth() * .8 : balanceboardImg->GetWidth()) + 5;
} }
@ -532,7 +546,7 @@ int showGameInfo(char *ID)
wifiplayersImg->SetWidescreen(Settings.widescreen); wifiplayersImg->SetWidescreen(Settings.widescreen);
wifiplayersImg->SetPosition(intputX, inputY); wifiplayersImg->SetPosition(intputX, inputY);
wifiplayersImg->SetAlignment(0, 4); wifiplayersImg->SetAlignment(0, 4);
gameinfoWindow.Append(wifiplayersImg); InfoWindow.Append(wifiplayersImg);
intputX += (Settings.widescreen ? wifiplayersImg->GetWidth() * .8 : wifiplayersImg->GetWidth()) + 5; intputX += (Settings.widescreen ? wifiplayersImg->GetWidth() * .8 : wifiplayersImg->GetWidth()) + 5;
} }
@ -599,21 +613,10 @@ int showGameInfo(char *ID)
ratingImg->SetWidescreen(Settings.widescreen); ratingImg->SetWidescreen(Settings.widescreen);
ratingImg->SetPosition(-25, inputY); ratingImg->SetPosition(-25, inputY);
ratingImg->SetAlignment(1, 4); ratingImg->SetAlignment(1, 4);
gameinfoWindow.Append(ratingImg); InfoWindow.Append(ratingImg);
intputX += (Settings.widescreen ? ratingImg->GetWidth() * .8 : ratingImg->GetWidth()) + 5; intputX += (Settings.widescreen ? ratingImg->GetWidth() * .8 : ratingImg->GetWidth()) + 5;
} }
// memory info
if (showmeminfo)
{
char meminfotxt[200];
strlcpy(meminfotxt, MemInfo(), sizeof(meminfotxt));
memTxt = new GuiText(meminfotxt, 18, ( GXColor ) {0, 0, 0, 255});
memTxt->SetAlignment(ALIGN_LEFT, ALIGN_TOP);
memTxt->SetPosition(0, 0);
gameinfoWindow.Append(memTxt);
}
// title // title
int titlefontsize = 25; int titlefontsize = 25;
if (GameInfo.Title.size() > 0) if (GameInfo.Title.size() > 0)
@ -622,7 +625,7 @@ int showGameInfo(char *ID)
titleTxt->SetMaxWidth(350, SCROLL_HORIZONTAL); titleTxt->SetMaxWidth(350, SCROLL_HORIZONTAL);
titleTxt->SetAlignment(ALIGN_CENTRE, ALIGN_TOP); titleTxt->SetAlignment(ALIGN_CENTRE, ALIGN_TOP);
titleTxt->SetPosition(txtXOffset, 12 + titley); titleTxt->SetPosition(txtXOffset, 12 + titley);
gameinfoWindow.Append(titleTxt); InfoWindow.Append(titleTxt);
} }
//date //date
@ -682,7 +685,7 @@ int showGameInfo(char *ID)
releasedTxt->SetPosition(-17, 12 + indexy); releasedTxt->SetPosition(-17, 12 + indexy);
indexy += (20 * newline); indexy += (20 * newline);
newline = 1; newline = 1;
gameinfoWindow.Append(releasedTxt); InfoWindow.Append(releasedTxt);
} }
//publisher //publisher
@ -696,7 +699,7 @@ int showGameInfo(char *ID)
publisherTxt->SetPosition(-17, 12 + indexy); publisherTxt->SetPosition(-17, 12 + indexy);
indexy += (20 * newline); indexy += (20 * newline);
newline = 1; newline = 1;
gameinfoWindow.Append(publisherTxt); InfoWindow.Append(publisherTxt);
} }
//developer //developer
@ -710,7 +713,7 @@ int showGameInfo(char *ID)
developerTxt->SetPosition(-17, 12 + indexy); developerTxt->SetPosition(-17, 12 + indexy);
indexy += (20 * newline); indexy += (20 * newline);
newline = 1; newline = 1;
gameinfoWindow.Append(developerTxt); InfoWindow.Append(developerTxt);
} }
//genre //genre
@ -721,7 +724,7 @@ int showGameInfo(char *ID)
genreTitleTxt->SetAlignment(ALIGN_LEFT, ALIGN_TOP); genreTitleTxt->SetAlignment(ALIGN_LEFT, ALIGN_TOP);
genreTitleTxt->SetPosition(205, 12 + genreY); genreTitleTxt->SetPosition(205, 12 + genreY);
genreY += 20; genreY += 20;
gameinfoWindow.Append(genreTitleTxt); InfoWindow.Append(genreTitleTxt);
} }
genreTxt = new GuiText *[GameInfo.GenreList.size()+1]; //to not alloc a 0 vector genreTxt = new GuiText *[GameInfo.GenreList.size()+1]; //to not alloc a 0 vector
@ -731,7 +734,7 @@ int showGameInfo(char *ID)
genreTxt[i]->SetAlignment(ALIGN_LEFT, ALIGN_TOP); genreTxt[i]->SetAlignment(ALIGN_LEFT, ALIGN_TOP);
genreTxt[i]->SetPosition(215, 12 + genreY); genreTxt[i]->SetPosition(215, 12 + genreY);
genreY += 20; genreY += 20;
gameinfoWindow.Append(genreTxt[i]); InfoWindow.Append(genreTxt[i]);
} }
//online //online
@ -750,7 +753,7 @@ int showGameInfo(char *ID)
wifiTxt[i]->SetAlignment(ALIGN_LEFT, ALIGN_TOP); wifiTxt[i]->SetAlignment(ALIGN_LEFT, ALIGN_TOP);
wifiTxt[i]->SetPosition(215, 200 + wifiY); wifiTxt[i]->SetPosition(215, 200 + wifiY);
wifiY -= 20; wifiY -= 20;
gameinfoWindow.Append(wifiTxt[i]); InfoWindow.Append(wifiTxt[i]);
} }
if (GameInfo.WifiFeatureList.size() > 0) if (GameInfo.WifiFeatureList.size() > 0)
{ {
@ -763,7 +766,7 @@ int showGameInfo(char *ID)
wifiTxt[0] = new GuiText(linebuf2, 16, ( GXColor ) {0, 0, 0, 255}); wifiTxt[0] = new GuiText(linebuf2, 16, ( GXColor ) {0, 0, 0, 255});
wifiTxt[0]->SetAlignment(ALIGN_LEFT, ALIGN_TOP); wifiTxt[0]->SetAlignment(ALIGN_LEFT, ALIGN_TOP);
wifiTxt[0]->SetPosition(205, 200 + wifiY); wifiTxt[0]->SetPosition(205, 200 + wifiY);
gameinfoWindow.Append(wifiTxt[0]); InfoWindow.Append(wifiTxt[0]);
//synopsis //synopsis
int pagesize = 12; int pagesize = 12;
@ -776,31 +779,9 @@ int showGameInfo(char *ID)
synopsisTxt->SetLinesToDraw(pagesize); synopsisTxt->SetLinesToDraw(pagesize);
synopsisTxt->Refresh(); synopsisTxt->Refresh();
dialogBoxImg11 = new GuiImage(&dialogBox1);
dialogBoxImg11->SetAlignment(0, 3);
dialogBoxImg11->SetPosition(-9, 0);
dialogBoxImg22 = new GuiImage(&dialogBox2);
dialogBoxImg22->SetAlignment(0, 3);
dialogBoxImg22->SetPosition(145, 0);
dialogBoxImg33 = new GuiImage(&dialogBox3);
dialogBoxImg33->SetAlignment(0, 3);
dialogBoxImg33->SetPosition(301, 0);
dialogBoxImg44 = new GuiImage(&dialogBox4);
dialogBoxImg44->SetAlignment(0, 3);
dialogBoxImg44->SetPosition(457, 0);
gameinfoWindow2.Append(dialogBoxImg11);
gameinfoWindow2.Append(dialogBoxImg22);
gameinfoWindow2.Append(dialogBoxImg33);
gameinfoWindow2.Append(dialogBoxImg44);
txtWindow.Append(synopsisTxt); txtWindow.Append(synopsisTxt);
txtWindow.Append(&upBtn); txtWindow.Append(&upBtn);
txtWindow.Append(&dnBtn); txtWindow.Append(&dnBtn);
gameinfoWindow2.Append(&txtWindow);
} }
wiitdb1Txt = new GuiText("http://wiitdb.com", 16, ( GXColor ) {0, 0, 0, 255}); wiitdb1Txt = new GuiText("http://wiitdb.com", 16, ( GXColor ) {0, 0, 0, 255});
@ -809,6 +790,9 @@ int showGameInfo(char *ID)
gameinfoWindow.Append(wiitdb1Txt); gameinfoWindow.Append(wiitdb1Txt);
if(coverImg) gameinfoWindow.Append(coverImg); if(coverImg) gameinfoWindow.Append(coverImg);
// Set info window first
gameinfoWindow.Append(&InfoWindow);
HaltGui(); HaltGui();
//mainWindow->SetState(STATE_DISABLED); //mainWindow->SetState(STATE_DISABLED);
mainWindow->Append(&gameinfoWindow); mainWindow->Append(&gameinfoWindow);
@ -828,32 +812,31 @@ int showGameInfo(char *ID)
else if (reset == 1) else if (reset == 1)
Sys_Reboot(); Sys_Reboot();
else if(LeftBtn.GetState() == STATE_CLICKED)
{
choice = 3;
break;
}
else if(RightBtn.GetState() == STATE_CLICKED)
{
choice = 4;
break;
}
else if ((backBtn.GetState() == STATE_CLICKED) || (backBtn.GetState() == STATE_HELD)) else if ((backBtn.GetState() == STATE_CLICKED) || (backBtn.GetState() == STATE_HELD))
{ {
backBtn.ResetState(); backBtn.ResetState();
if (page == 1) if (page == 1)
{ {
choice = 1; choice = 1;
if (synopsisTxt) delete synopsisTxt;
synopsisTxt = NULL;
break; break;
} }
else if (page == 2) else if (page == 2)
{ {
HaltGui(); HaltGui();
gameinfoWindow2.Remove(&nextBtn); gameinfoWindow.Remove(&txtWindow);
gameinfoWindow2.Remove(&backBtn); gameinfoWindow.Append(&InfoWindow);
gameinfoWindow2.Remove(&homeBtn);
gameinfoWindow2.Remove(&coverBtn);
gameinfoWindow2.Remove(coverImg);
gameinfoWindow2.SetVisible(false);
gameinfoWindow.SetVisible(true);
gameinfoWindow.Append(&backBtn);
gameinfoWindow.Append(&nextBtn);
gameinfoWindow.Append(&homeBtn);
gameinfoWindow.Append(&coverBtn);
gameinfoWindow.Append(coverImg);
mainWindow->Remove(&gameinfoWindow2);
ResumeGui(); ResumeGui();
page = 1; page = 1;
} }
@ -861,10 +844,10 @@ int showGameInfo(char *ID)
else if(coverBtn.GetState() == STATE_CLICKED && boxCov) else if(coverBtn.GetState() == STATE_CLICKED && boxCov)
{ {
boxCov->SetEffect(EFFECT_BOX_FLY_CENTRE, 100); boxCov->SetEffect(EFFECT_BOX_FLY_CENTRE, 100);
gameinfoWindow2.Remove(&nextBtn);
gameinfoWindow2.Remove(&homeBtn);
gameinfoWindow.Remove(&nextBtn); gameinfoWindow.Remove(&nextBtn);
gameinfoWindow.Remove(&homeBtn); gameinfoWindow.Remove(&homeBtn);
gameinfoWindow.Remove(&LeftBtn);
gameinfoWindow.Remove(&RightBtn);
boxCov->SetZoomable(true); boxCov->SetZoomable(true);
while(backBtn.GetState() != STATE_CLICKED && homeBtn.GetState() != STATE_CLICKED) while(backBtn.GetState() != STATE_CLICKED && homeBtn.GetState() != STATE_CLICKED)
@ -876,16 +859,10 @@ int showGameInfo(char *ID)
Sys_Reboot(); Sys_Reboot();
} }
if (page == 1)
{
gameinfoWindow.Append(&nextBtn); gameinfoWindow.Append(&nextBtn);
gameinfoWindow.Append(&homeBtn); gameinfoWindow.Append(&homeBtn);
} gameinfoWindow.Append(&LeftBtn);
else gameinfoWindow.Append(&RightBtn);
{
gameinfoWindow2.Append(&nextBtn);
gameinfoWindow2.Append(&homeBtn);
}
boxCov->SetZoomable(false); boxCov->SetZoomable(false);
boxCov->SetEffect(EFFECT_BOX_FLY_BACK, 100); boxCov->SetEffect(EFFECT_BOX_FLY_BACK, 100);
@ -900,42 +877,16 @@ int showGameInfo(char *ID)
if (page == 1) if (page == 1)
{ {
HaltGui(); HaltGui();
gameinfoWindow.Remove(&nextBtn); gameinfoWindow.Remove(&InfoWindow);
gameinfoWindow.Remove(&backBtn); gameinfoWindow.Append(&txtWindow);
gameinfoWindow.Remove(&homeBtn);
gameinfoWindow.Remove(&coverBtn);
gameinfoWindow.Remove(wiitdb1Txt);
gameinfoWindow.Remove(coverImg);
gameinfoWindow.SetVisible(false);
gameinfoWindow2.SetVisible(true);
gameinfoWindow2.Append(&nextBtn);
gameinfoWindow2.Append(&backBtn);
gameinfoWindow2.Append(&homeBtn);
gameinfoWindow2.Append(&coverBtn);
gameinfoWindow2.Append(wiitdb1Txt);
gameinfoWindow2.Append(coverImg);
mainWindow->Append(&gameinfoWindow2);
ResumeGui(); ResumeGui();
page = 2; page = 2;
} }
else else
{ {
HaltGui(); HaltGui();
gameinfoWindow2.Remove(&nextBtn); gameinfoWindow.Remove(&txtWindow);
gameinfoWindow2.Remove(&backBtn); gameinfoWindow.Append(&InfoWindow);
gameinfoWindow2.Remove(&homeBtn);
gameinfoWindow2.Remove(&coverBtn);
gameinfoWindow2.Remove(wiitdb1Txt);
gameinfoWindow2.Remove(coverImg);
gameinfoWindow2.SetVisible(false);
gameinfoWindow.SetVisible(true);
gameinfoWindow.Append(&backBtn);
gameinfoWindow.Append(&nextBtn);
gameinfoWindow.Append(&homeBtn);
gameinfoWindow.Append(&coverBtn);
gameinfoWindow.Append(wiitdb1Txt);
gameinfoWindow.Append(coverImg);
mainWindow->Remove(&gameinfoWindow2);
ResumeGui(); ResumeGui();
page = 1; page = 1;
} }
@ -957,24 +908,10 @@ int showGameInfo(char *ID)
if (!((ButtonsHold() & WPAD_BUTTON_DOWN) || (ButtonsHold() & PAD_BUTTON_DOWN))) dnBtn.ResetState(); if (!((ButtonsHold() & WPAD_BUTTON_DOWN) || (ButtonsHold() & PAD_BUTTON_DOWN))) dnBtn.ResetState();
} }
else if (homeBtn.GetState() == STATE_CLICKED) else if (homeBtn.GetState() == STATE_CLICKED)
{
if (page == 1)
{ {
choice = 2; choice = 2;
if (synopsisTxt) delete synopsisTxt;
synopsisTxt = NULL;
break; break;
} }
else if (page == 2)
{
HaltGui();
gameinfoWindow2.SetVisible(false);
gameinfoWindow.SetVisible(true);
mainWindow->Remove(&gameinfoWindow2);
ResumeGui();
page = 1;
}
}
} }
HaltGui(); HaltGui();
@ -1055,6 +992,33 @@ int showGameInfo(char *ID)
return choice; return choice;
} }
int showGameInfo(int gameSelected)
{
char gameID[7];
int choice = 5;
while(choice > 2)
{
struct discHdr * header = (mountMethod ? dvdheader : gameList[gameSelected]);
snprintf(gameID, sizeof(gameID), (char *) header->id);
choice = InternalShowGameInfo(gameID);
if(choice == 3)
{
--gameSelected;
if(gameSelected < 0)
gameSelected = 0;
}
else if(choice == 4)
{
gameSelected = (gameSelected + 1) % gameList.size();
}
}
return choice;
}
bool save_gamelist(int txt) // save gamelist bool save_gamelist(int txt) // save gamelist
{ {
mainWindow->SetState(STATE_DISABLED); mainWindow->SetState(STATE_DISABLED);
@ -1132,10 +1096,3 @@ bool save_gamelist(int txt) // save gamelist
mainWindow->SetState(STATE_DEFAULT); mainWindow->SetState(STATE_DEFAULT);
return true; return true;
} }
void MemInfoPrompt()
{
char meminfotxt[200];
strlcpy(meminfotxt, MemInfo(), sizeof(meminfotxt));
WindowPrompt(0, meminfotxt, tr( "OK" ));
}

View File

@ -8,7 +8,7 @@
#ifndef _GAMEINFO_H_ #ifndef _GAMEINFO_H_
#define _GAMEINFO_H_ #define _GAMEINFO_H_
int showGameInfo(char *ID); int showGameInfo(int selectedGame);
bool save_gamelist(int txt); bool save_gamelist(int txt);
void MemInfoPrompt();
#endif #endif

View File

@ -258,6 +258,7 @@ bool CSettings::Save()
fprintf(file, "HomeMenu = %d\n ", HomeMenu); fprintf(file, "HomeMenu = %d\n ", HomeMenu);
fprintf(file, "MultiplePartitions = %d\n ", MultiplePartitions); fprintf(file, "MultiplePartitions = %d\n ", MultiplePartitions);
fprintf(file, "USBPort = %d\n ", USBPort); fprintf(file, "USBPort = %d\n ", USBPort);
fprintf(file, "CacheTitles = %d\n ", CacheTitles);
fclose(file); fclose(file);
return true; return true;
@ -470,6 +471,11 @@ bool CSettings::SetSetting(char *name, char *value)
if (sscanf(value, "%d", &i) == 1) USBPort = i; if (sscanf(value, "%d", &i) == 1) USBPort = i;
return true; return true;
} }
else if (strcmp(name, "CacheTitles") == 0)
{
if (sscanf(value, "%d", &i) == 1) CacheTitles = i;
return true;
}
else if (strcmp(name, "patchcountrystrings") == 0) else if (strcmp(name, "patchcountrystrings") == 0)
{ {
if (sscanf(value, "%d", &i) == 1) patchcountrystrings = i; if (sscanf(value, "%d", &i) == 1) patchcountrystrings = i;

View File

@ -60,7 +60,7 @@
#define isMEM2Buffer(p) (((u32) p & 0x10000000) != 0) #define isMEM2Buffer(p) (((u32) p & 0x10000000) != 0)
#define MAX_BUFFER_SECTORS 256 #define MAX_BUFFER_SECTORS 256
#define UMS_HEAPSIZE 0x1000 #define UMS_HEAPSIZE 0x8000
/* Variables */ /* Variables */
static char fs[] ATTRIBUTE_ALIGN(32) = "/dev/usb2"; static char fs[] ATTRIBUTE_ALIGN(32) = "/dev/usb2";
@ -96,7 +96,6 @@ s32 USBStorage2_Init(void)
/* Initialize USB storage */ /* Initialize USB storage */
ret = IOS_IoctlvFormat(hid, fd, USB_IOCTL_UMS_INIT, ":"); ret = IOS_IoctlvFormat(hid, fd, USB_IOCTL_UMS_INIT, ":");
if (ret < 0) goto err;
/* Get device capacity */ /* Get device capacity */
if (USBStorage2_GetCapacity(&hdd_sector_size) == 0) if (USBStorage2_GetCapacity(&hdd_sector_size) == 0)
@ -105,7 +104,7 @@ s32 USBStorage2_Init(void)
goto err; goto err;
} }
return ret; // 0->HDD, 1->DVD return 0; // 0->HDD, 1->DVD
err: err:
/* Close USB device */ /* Close USB device */