diff --git a/source/ngc/FreeTypeGX.cpp b/source/ngc/FreeTypeGX.cpp index 0cbab38..32110be 100644 --- a/source/ngc/FreeTypeGX.cpp +++ b/source/ngc/FreeTypeGX.cpp @@ -680,6 +680,7 @@ void FreeTypeGX::copyTextureToFramebuffer(GXTexObj *texObj, f32 texWidth, f32 te GX_Color4u8(color.r, color.g, color.b, color.a); GX_TexCoord2f32(0.0f, 1.0f); GX_End(); + GX_DrawDone(); this->setDefaultMode(); } @@ -713,6 +714,7 @@ void FreeTypeGX::copyFeatureToFramebuffer(f32 featureWidth, f32 featureHeight, i GX_Position2s16(screenX, featureHeight + screenY); GX_Color4u8(color.r, color.g, color.b, color.a); GX_End(); + GX_DrawDone(); this->setDefaultMode(); } diff --git a/source/ngc/dvd.cpp b/source/ngc/dvd.cpp index 5c9c054..953badb 100644 --- a/source/ngc/dvd.cpp +++ b/source/ngc/dvd.cpp @@ -365,7 +365,6 @@ static int getentry (int entrycount, unsigned char dvdbuffer[]) { char fname[512]; /* Huge, but experience has determined this */ - char tmpname[512]; char *ptr; char *filename; char *filenamelength; @@ -467,8 +466,7 @@ getentry (int entrycount, unsigned char dvdbuffer[]) } else { - StripExt(tmpname, fname); // hide file extension - strncpy (browserList[entrycount].displayname, tmpname, MAXDISPLAY); + StripExt(browserList[entrycount].displayname, browserList[entrycount].filename); // hide file extension } memcpy (&offset32, &dvdbuffer[diroffset + EXTENT], 4); diff --git a/source/ngc/filebrowser.cpp b/source/ngc/filebrowser.cpp index 2c1ccc7..243c8c3 100644 --- a/source/ngc/filebrowser.cpp +++ b/source/ngc/filebrowser.cpp @@ -406,7 +406,7 @@ void StripExt(char* returnstring, char * inputstring) { char* loc_dot; - strncpy (returnstring, inputstring, 255); + strncpy (returnstring, inputstring, MAXJOLIET); if(inputstring == NULL || strlen(inputstring) < 4) return; diff --git a/source/ngc/filebrowser.h b/source/ngc/filebrowser.h index 2f5743a..83e091f 100644 --- a/source/ngc/filebrowser.h +++ b/source/ngc/filebrowser.h @@ -15,7 +15,6 @@ #include #define MAXJOLIET 255 -#define MAXDISPLAY 40 typedef struct { @@ -32,7 +31,7 @@ typedef struct time_t mtime; // file modified time char isdir; // 0 - file, 1 - directory char filename[MAXJOLIET + 1]; // full filename - char displayname[MAXDISPLAY + 1]; // name for browser display + char displayname[MAXJOLIET + 1]; // name for browser display } BROWSERENTRY; extern BROWSERINFO browser; diff --git a/source/ngc/filelist.h b/source/ngc/filelist.h index 76a72b7..f0e0fcd 100644 --- a/source/ngc/filelist.h +++ b/source/ngc/filelist.h @@ -95,6 +95,12 @@ extern const u32 button_png_size; extern const u8 button_over_png[]; extern const u32 button_over_png_size; +extern const u8 button_short_png[]; +extern const u32 button_short_png_size; + +extern const u8 button_short_over_png[]; +extern const u32 button_short_over_png_size; + extern const u8 button_small_png[]; extern const u32 button_small_png_size; diff --git a/source/ngc/fileop.cpp b/source/ngc/fileop.cpp index 237931a..6b27208 100644 --- a/source/ngc/fileop.cpp +++ b/source/ngc/fileop.cpp @@ -322,7 +322,6 @@ ParseDirectory(int method) DIR_ITER *dir = NULL; char fulldir[MAXPATHLEN]; char filename[MAXPATHLEN]; - char tmpname[MAXPATHLEN]; struct stat filestat; char msg[128]; int retry = 1; @@ -394,8 +393,7 @@ ParseDirectory(int method) } else { - StripExt(tmpname, filename); // hide file extension - strncpy(browserList[entryNum].displayname, tmpname, MAXDISPLAY); // crop name for display + StripExt(browserList[entryNum].displayname, filename); // hide file extension } browserList[entryNum].length = filestat.st_size; diff --git a/source/ngc/gcunzip.cpp b/source/ngc/gcunzip.cpp index c370b39..f6155a8 100644 --- a/source/ngc/gcunzip.cpp +++ b/source/ngc/gcunzip.cpp @@ -4,7 +4,7 @@ * * Tantric September 2008 * - * gcunzip.h + * gcunzip.cpp * * Unzip routines ****************************************************************************/ @@ -483,9 +483,9 @@ int SzParse(char * filepath, int method) } memset(&(browserList[SzJ]), 0, sizeof(BROWSERENTRY)); // clear the new entry - // parse information about this file to the dvd file list structure - strncpy(browserList[SzJ].filename, SzF->Name, MAXJOLIET); // copy joliet name (useless...) - strncpy(browserList[SzJ].displayname, SzF->Name, MAXDISPLAY); // crop name for display + // parse information about this file to the file list structure + strncpy(browserList[SzJ].filename, SzF->Name, MAXJOLIET); + StripExt(browserList[SzJ].displayname, browserList[SzJ].filename); browserList[SzJ].length = SzF->Size; // filesize browserList[SzJ].offset = SzI; // the extraction function identifies the file with this number browserList[SzJ].isdir = 0; // only files will be displayed (-> no flags) diff --git a/source/ngc/gcvideo.cpp b/source/ngc/gcvideo.cpp index efdd7c4..1dbb3cb 100644 --- a/source/ngc/gcvideo.cpp +++ b/source/ngc/gcvideo.cpp @@ -923,8 +923,6 @@ ResetVideo_Menu () ***************************************************************************/ void Menu_Render() { - GX_DrawDone (); - whichfb ^= 1; // flip framebuffer GX_SetZMode(GX_TRUE, GX_LEQUAL, GX_TRUE); GX_SetColorUpdate(GX_TRUE); @@ -984,6 +982,7 @@ void Menu_DrawImg(f32 xpos, f32 ypos, u16 width, u16 height, u8 data[], GX_Color4u8(0xFF,0xFF,0xFF,alpha); GX_TexCoord2f32(0, 1); GX_End(); + GX_DrawDone(); GX_LoadPosMtxImm (GXmodelView2D, GX_PNMTX0); GX_SetTevOp (GX_TEVSTAGE0, GX_PASSCLR); @@ -1022,6 +1021,7 @@ void Menu_DrawRectangle(f32 x, f32 y, f32 width, f32 height, GXColor color, u8 f GX_Color4u8(color.r, color.g, color.b, color.a); } GX_End(); + GX_DrawDone(); } /**************************************************************************** diff --git a/source/ngc/gui/gui.h b/source/ngc/gui/gui.h index 91a70ba..a465ae4 100644 --- a/source/ngc/gui/gui.h +++ b/source/ngc/gui/gui.h @@ -102,6 +102,12 @@ enum TRIGGER_BUTTON_ONLY_IN_FOCUS }; +enum +{ + SCROLL_NONE, + SCROLL_HORIZONTAL +}; + typedef struct _paddata { u16 btns_d; u16 btns_u; @@ -613,7 +619,9 @@ class GuiText : public GuiElement //!Sets the maximum width of the drawn texture image //!If the text exceeds this, it is wrapped to the next line //!\param w Maximum width - void SetMaxWidth(int w); + void SetMaxWidth(int width); + void SetScroll(int s); + void SetWrap(bool w, int width = 0); //!Sets the font color //!\param c Font color void SetColor(GXColor c); @@ -627,9 +635,16 @@ class GuiText : public GuiElement //!Constantly called to draw the text void Draw(); protected: + char * origText; wchar_t* text; //!< Unicode text value int size; //!< Font size int maxWidth; //!< Maximum width of the generated text object (for text wrapping) + bool wrap; + wchar_t* textDyn; + int textScroll; + int textScrollPos; + int textScrollInitialDelay; + int textScrollDelay; u16 style; //!< FreeTypeGX style attributes GXColor color; //!< Font color }; diff --git a/source/ngc/gui/gui_filebrowser.cpp b/source/ngc/gui/gui_filebrowser.cpp index 0e28e67..44c08c9 100644 --- a/source/ngc/gui/gui_filebrowser.cpp +++ b/source/ngc/gui/gui_filebrowser.cpp @@ -103,6 +103,7 @@ GuiFileBrowser::GuiFileBrowser(int w, int h) fileListText[i] = new GuiText(NULL, 20, (GXColor){0, 0, 0, 0xff}); fileListText[i]->SetAlignment(ALIGN_LEFT, ALIGN_MIDDLE); fileListText[i]->SetPosition(5,0); + fileListText[i]->SetMaxWidth(380); fileListBg[i] = new GuiImage(bgGameSelectionEntry); fileListFolder[i] = new GuiImage(gameFolder); @@ -375,6 +376,11 @@ void GuiFileBrowser::Update(GuiTrigger * t) selectedItem = i; browser.selIndex = browser.pageIndex + i; } + + if(selectedItem == i) + fileListText[i]->SetScroll(SCROLL_HORIZONTAL); + else + fileListText[i]->SetScroll(SCROLL_NONE); } // update the location of the scroll box based on the position in the file list diff --git a/source/ngc/gui/gui_text.cpp b/source/ngc/gui/gui_text.cpp index f3254a3..c432403 100644 --- a/source/ngc/gui/gui_text.cpp +++ b/source/ngc/gui/gui_text.cpp @@ -18,23 +18,36 @@ static int presetAlignmentVert = 0; static u16 presetStyle = 0; static GXColor presetColor = (GXColor){255, 255, 255, 255}; +#define TEXT_SCROLL_DELAY 8 +#define TEXT_SCROLL_INITIAL_DELAY 6 + /** * Constructor for the GuiText class. */ GuiText::GuiText(const char * t, int s, GXColor c) { + origText = NULL; text = NULL; size = s; color = c; alpha = c.a; style = FTGX_JUSTIFY_CENTER | FTGX_ALIGN_MIDDLE; maxWidth = 0; + wrap = false; + textDyn = NULL; + textScroll = SCROLL_NONE; + textScrollPos = 0; + textScrollInitialDelay = TEXT_SCROLL_INITIAL_DELAY; + textScrollDelay = TEXT_SCROLL_DELAY; alignmentHor = ALIGN_CENTRE; alignmentVert = ALIGN_MIDDLE; if(t) + { + origText = strdup(t); text = fontSystem->charToWideChar((char *)t); + } } /** @@ -42,18 +55,28 @@ GuiText::GuiText(const char * t, int s, GXColor c) */ GuiText::GuiText(const char * t) { + origText = NULL; text = NULL; size = presetSize; color = presetColor; alpha = presetColor.a; style = presetStyle; maxWidth = presetMaxWidth; + wrap = false; + textDyn = NULL; + textScroll = SCROLL_NONE; + textScrollPos = 0; + textScrollInitialDelay = TEXT_SCROLL_INITIAL_DELAY; + textScrollDelay = TEXT_SCROLL_DELAY; alignmentHor = presetAlignmentHor; alignmentVert = presetAlignmentVert; if(t) + { + origText = strdup(t); text = fontSystem->charToWideChar((char *)t); + } } /** @@ -61,22 +84,34 @@ GuiText::GuiText(const char * t) */ GuiText::~GuiText() { + if(origText) + free(origText); if(text) - { delete text; - text = NULL; - } + if(textDyn) + delete textDyn; } void GuiText::SetText(const char * t) { + if(origText) + free(origText); if(text) delete text; + if(textDyn) + delete textDyn; + origText = NULL; text = NULL; + textDyn = NULL; + textScrollPos = 0; + textScrollInitialDelay = TEXT_SCROLL_INITIAL_DELAY; if(t) + { + origText = strdup(t); text = fontSystem->charToWideChar((char *)t); + } } void GuiText::SetPresets(int sz, GXColor c, int w, u16 s, int h, int v) @@ -94,9 +129,31 @@ void GuiText::SetFontSize(int s) size = s; } -void GuiText::SetMaxWidth(int w) +void GuiText::SetMaxWidth(int width) { - maxWidth = w; + maxWidth = width; +} + +void GuiText::SetWrap(bool w, int width) +{ + wrap = w; + maxWidth = width; +} + +void GuiText::SetScroll(int s) +{ + if(textScroll == s) + return; + + if(textDyn) + { + delete(textDyn); + textDyn = NULL; + } + textScroll = s; + textScrollPos = 0; + textScrollInitialDelay = TEXT_SCROLL_INITIAL_DELAY; + textScrollDelay = TEXT_SCROLL_DELAY; } void GuiText::SetColor(GXColor c) @@ -170,61 +227,116 @@ void GuiText::Draw() if(alignmentVert == ALIGN_MIDDLE) voffset = -newSize/2 + 2; - if(maxWidth > 0) // text wrapping + if(maxWidth > 0) { - int lineheight = newSize + 6; - int strlen = wcslen(text); - int i = 0; - int ch = 0; - int linenum = 0; - int lastSpace = -1; - int lastSpaceIndex = -1; - wchar_t * tmptext[20]; + char * tmpText = strdup(origText); + u8 maxChar = (maxWidth*2.0) / newSize; - while(ch < strlen) + if(!textDyn) { - if(i == 0) - tmptext[linenum] = new wchar_t[strlen + 1]; + if(strlen(tmpText) > maxChar) + tmpText[maxChar] = 0; + textDyn = fontSystem->charToWideChar(tmpText); + } - tmptext[linenum][i] = text[ch]; - tmptext[linenum][i+1] = 0; + if(textScroll == SCROLL_HORIZONTAL) + { + int textlen = strlen(origText); - if(text[ch] == ' ' || ch == strlen-1) + if(textlen > maxChar && (FrameTimer % textScrollDelay == 0)) { - if(fontSystem->getWidth(tmptext[linenum]) >= maxWidth) + if(textScrollInitialDelay) { - if(lastSpace >= 0) + textScrollInitialDelay--; + } + else + { + textScrollPos++; + if(textScrollPos > textlen-1) { - tmptext[linenum][lastSpaceIndex] = 0; // discard space, and everything after - ch = lastSpace; // go backwards to the last space - lastSpace = -1; // we have used this space - lastSpaceIndex = -1; + textScrollPos = 0; + textScrollInitialDelay = TEXT_SCROLL_INITIAL_DELAY; } - linenum++; - i = -1; - } - else if(ch == strlen-1) - { - linenum++; + + strncpy(tmpText, &origText[textScrollPos], maxChar-1); + tmpText[maxChar-1] = 0; + + int dynlen = strlen(tmpText); + + if(dynlen+2 < maxChar) + { + tmpText[dynlen] = ' '; + tmpText[dynlen+1] = ' '; + strncat(&tmpText[dynlen+2], origText, maxChar - dynlen - 2); + } + if(textDyn) delete textDyn; + textDyn = fontSystem->charToWideChar(tmpText); } } - if(text[ch] == ' ' && i >= 0) - { - lastSpace = ch; - lastSpaceIndex = i; - } - ch++; - i++; + if(textDyn) + fontSystem->drawText(this->GetLeft(), this->GetTop()+voffset, textDyn, c, style); } - - if(alignmentVert == ALIGN_MIDDLE) - voffset = voffset - (lineheight*linenum)/2 + lineheight/2; - - for(i=0; i < linenum; i++) + else if(wrap) { - fontSystem->drawText(this->GetLeft(), this->GetTop()+voffset+i*lineheight, tmptext[i], c, style); - delete tmptext[i]; + int lineheight = newSize + 6; + int txtlen = wcslen(text); + int i = 0; + int ch = 0; + int linenum = 0; + int lastSpace = -1; + int lastSpaceIndex = -1; + wchar_t * textrow[20]; + + while(ch < txtlen) + { + if(i == 0) + textrow[linenum] = new wchar_t[txtlen + 1]; + + textrow[linenum][i] = text[ch]; + textrow[linenum][i+1] = 0; + + if(text[ch] == ' ' || ch == txtlen-1) + { + if(wcslen(textrow[linenum]) >= maxChar) + { + if(lastSpace >= 0) + { + textrow[linenum][lastSpaceIndex] = 0; // discard space, and everything after + ch = lastSpace; // go backwards to the last space + lastSpace = -1; // we have used this space + lastSpaceIndex = -1; + } + linenum++; + i = -1; + } + else if(ch == txtlen-1) + { + linenum++; + } + } + if(text[ch] == ' ' && i >= 0) + { + lastSpace = ch; + lastSpaceIndex = i; + } + ch++; + i++; + } + + if(alignmentVert == ALIGN_MIDDLE) + voffset = voffset - (lineheight*linenum)/2 + lineheight/2; + + for(i=0; i < linenum; i++) + { + fontSystem->drawText(this->GetLeft(), this->GetTop()+voffset+i*lineheight, textrow[i], c, style); + delete textrow[i]; + } } + else + { + fontSystem->drawText(this->GetLeft(), this->GetTop()+voffset, textDyn, c, style); + } + free(tmpText); } else { diff --git a/source/ngc/images/button_short.png b/source/ngc/images/button_short.png new file mode 100644 index 0000000..1501e7d Binary files /dev/null and b/source/ngc/images/button_short.png differ diff --git a/source/ngc/images/button_short_over.png b/source/ngc/images/button_short_over.png new file mode 100644 index 0000000..aa4a938 Binary files /dev/null and b/source/ngc/images/button_short_over.png differ diff --git a/source/ngc/memcardop.cpp b/source/ngc/memcardop.cpp index ab250dc..7ed16b0 100644 --- a/source/ngc/memcardop.cpp +++ b/source/ngc/memcardop.cpp @@ -102,7 +102,6 @@ ParseMCDirectory (int slot) card_dir CardDir; int CardError; int entryNum = 0; - char tmpname[MAXPATHLEN]; // Try to mount the card CardError = MountMC(slot, NOTSILENT); @@ -128,8 +127,7 @@ ParseMCDirectory (int slot) memset(&(browserList[entryNum]), 0, sizeof(BROWSERENTRY)); // clear the new entry strncpy(browserList[entryNum].filename, (char *)CardDir.filename, MAXJOLIET); - StripExt(tmpname, (char *)CardDir.filename); // hide file extension - strncpy(browserList[entryNum].displayname, tmpname, MAXDISPLAY); // crop name for display + StripExt(browserList[entryNum].displayname, browserList[entryNum].filename); // hide file extension browserList[entryNum].length = CardDir.filelen; entryNum++; diff --git a/source/ngc/menu.cpp b/source/ngc/menu.cpp index 322a45c..ed2ea82 100644 --- a/source/ngc/menu.cpp +++ b/source/ngc/menu.cpp @@ -144,7 +144,7 @@ WindowPrompt(const char *title, const char *msg, const char *btn1Label, const ch GuiText msgTxt(msg, 26, (GXColor){0, 0, 0, 255}); msgTxt.SetAlignment(ALIGN_CENTRE, ALIGN_MIDDLE); msgTxt.SetPosition(0,-20); - msgTxt.SetMaxWidth(430); + msgTxt.SetWrap(true, 430); GuiText btn1Txt(btn1Label, 24, (GXColor){0, 0, 0, 255}); GuiImage btn1Img(&btnOutline); @@ -1200,7 +1200,7 @@ static int MenuGame() resetBtn.SetEffectGrow(); GuiText gameSettingsBtnTxt("Game Settings", 24, (GXColor){0, 0, 0, 255}); - gameSettingsBtnTxt.SetMaxWidth(btnLargeOutline.GetWidth()-30); + gameSettingsBtnTxt.SetWrap(true, btnLargeOutline.GetWidth()-30); GuiImage gameSettingsBtnImg(&btnLargeOutline); GuiImage gameSettingsBtnImgOver(&btnLargeOutlineOver); GuiImage gameSettingsBtnIcon(&iconGameSettings); @@ -1513,7 +1513,7 @@ static int MenuGameSaves(int action) GuiImage backBtnImgOver(&btnOutlineOver); GuiButton backBtn(btnOutline.GetWidth(), btnOutline.GetHeight()); backBtn.SetAlignment(ALIGN_LEFT, ALIGN_BOTTOM); - backBtn.SetPosition(100, -35); + backBtn.SetPosition(50, -35); backBtn.SetLabel(&backBtnTxt); backBtn.SetImage(&backBtnImg); backBtn.SetImageOver(&backBtnImgOver); @@ -1777,7 +1777,7 @@ static int MenuGameSettings() trigHome.SetButtonOnlyTrigger(-1, WPAD_BUTTON_HOME | WPAD_CLASSIC_BUTTON_HOME, 0); GuiText mappingBtnTxt("Button Mappings", 24, (GXColor){0, 0, 0, 255}); - mappingBtnTxt.SetMaxWidth(btnLargeOutline.GetWidth()-30); + mappingBtnTxt.SetWrap(true, btnLargeOutline.GetWidth()-30); GuiImage mappingBtnImg(&btnLargeOutline); GuiImage mappingBtnImgOver(&btnLargeOutlineOver); GuiImage mappingBtnIcon(&iconMappings); @@ -1794,7 +1794,7 @@ static int MenuGameSettings() mappingBtn.SetEffectGrow(); GuiText videoBtnTxt("Video", 24, (GXColor){0, 0, 0, 255}); - videoBtnTxt.SetMaxWidth(btnLargeOutline.GetWidth()-30); + videoBtnTxt.SetWrap(true, btnLargeOutline.GetWidth()-30); GuiImage videoBtnImg(&btnLargeOutline); GuiImage videoBtnImgOver(&btnLargeOutlineOver); GuiImage videoBtnIcon(&iconVideo); @@ -1862,7 +1862,7 @@ static int MenuGameSettings() GuiImage backBtnImgOver(&btnOutlineOver); GuiButton backBtn(btnOutline.GetWidth(), btnOutline.GetHeight()); backBtn.SetAlignment(ALIGN_LEFT, ALIGN_BOTTOM); - backBtn.SetPosition(100, -35); + backBtn.SetPosition(50, -35); backBtn.SetLabel(&backBtnTxt); backBtn.SetImage(&backBtnImg); backBtn.SetImageOver(&backBtnImgOver); @@ -1985,7 +1985,7 @@ static int MenuGameCheats() GuiImage backBtnImgOver(&btnOutlineOver); GuiButton backBtn(btnOutline.GetWidth(), btnOutline.GetHeight()); backBtn.SetAlignment(ALIGN_LEFT, ALIGN_BOTTOM); - backBtn.SetPosition(100, -35); + backBtn.SetPosition(50, -35); backBtn.SetLabel(&backBtnTxt); backBtn.SetImage(&backBtnImg); backBtn.SetImageOver(&backBtnImgOver); @@ -2060,7 +2060,7 @@ static int MenuSettingsMappings() trigA.SetSimpleTrigger(-1, WPAD_BUTTON_A | WPAD_CLASSIC_BUTTON_A, PAD_BUTTON_A); GuiText nesBtnTxt("NES Controller", 24, (GXColor){0, 0, 0, 255}); - nesBtnTxt.SetMaxWidth(btnLargeOutline.GetWidth()-30); + nesBtnTxt.SetWrap(true, btnLargeOutline.GetWidth()-30); GuiImage nesBtnImg(&btnLargeOutline); GuiImage nesBtnImgOver(&btnLargeOutlineOver); GuiImage nesBtnIcon(&iconNESController); @@ -2077,7 +2077,7 @@ static int MenuSettingsMappings() nesBtn.SetEffectGrow(); GuiText zapperBtnTxt("Zapper", 24, (GXColor){0, 0, 0, 255}); - zapperBtnTxt.SetMaxWidth(btnLargeOutline.GetWidth()-30); + zapperBtnTxt.SetWrap(true, btnLargeOutline.GetWidth()-30); GuiImage zapperBtnImg(&btnLargeOutline); GuiImage zapperBtnImgOver(&btnLargeOutlineOver); GuiImage zapperBtnIcon(&iconZapper); @@ -2098,7 +2098,7 @@ static int MenuSettingsMappings() GuiImage backBtnImgOver(&btnOutlineOver); GuiButton backBtn(btnOutline.GetWidth(), btnOutline.GetHeight()); backBtn.SetAlignment(ALIGN_LEFT, ALIGN_BOTTOM); - backBtn.SetPosition(100, -35); + backBtn.SetPosition(50, -35); backBtn.SetLabel(&backBtnTxt); backBtn.SetImage(&backBtnImg); backBtn.SetImageOver(&backBtnImgOver); @@ -2177,7 +2177,7 @@ static int MenuSettingsMappingsController() trigA.SetSimpleTrigger(-1, WPAD_BUTTON_A | WPAD_CLASSIC_BUTTON_A, PAD_BUTTON_A); GuiText gamecubeBtnTxt("GameCube Controller", 24, (GXColor){0, 0, 0, 255}); - gamecubeBtnTxt.SetMaxWidth(btnLargeOutline.GetWidth()-30); + gamecubeBtnTxt.SetWrap(true, btnLargeOutline.GetWidth()-30); GuiImage gamecubeBtnImg(&btnLargeOutline); GuiImage gamecubeBtnImgOver(&btnLargeOutlineOver); GuiImage gamecubeBtnIcon(&iconGamecube); @@ -2210,7 +2210,7 @@ static int MenuSettingsMappingsController() wiimoteBtn.SetEffectGrow(); GuiText classicBtnTxt("Classic Controller", 24, (GXColor){0, 0, 0, 255}); - classicBtnTxt.SetMaxWidth(btnLargeOutline.GetWidth()-30); + classicBtnTxt.SetWrap(true, btnLargeOutline.GetWidth()-30); GuiImage classicBtnImg(&btnLargeOutline); GuiImage classicBtnImgOver(&btnLargeOutlineOver); GuiImage classicBtnIcon(&iconClassic); @@ -2253,7 +2253,7 @@ static int MenuSettingsMappingsController() GuiImage backBtnImgOver(&btnOutlineOver); GuiButton backBtn(btnOutline.GetWidth(), btnOutline.GetHeight()); backBtn.SetAlignment(ALIGN_LEFT, ALIGN_BOTTOM); - backBtn.SetPosition(100, -35); + backBtn.SetPosition(50, -35); backBtn.SetLabel(&backBtnTxt); backBtn.SetImage(&backBtnImg); backBtn.SetImageOver(&backBtnImgOver); @@ -2368,7 +2368,7 @@ ButtonMappingWindow() GuiText msgTxt(msg, 26, (GXColor){0, 0, 0, 255}); msgTxt.SetAlignment(ALIGN_CENTRE, ALIGN_MIDDLE); msgTxt.SetPosition(0,-20); - msgTxt.SetMaxWidth(430); + msgTxt.SetWrap(true, 430); promptWindow.Append(&dialogBoxImg); promptWindow.Append(&titleTxt); @@ -2465,6 +2465,8 @@ static int MenuSettingsMappingsMap() GuiSound btnSoundClick(button_click_pcm, button_click_pcm_size, SOUND_PCM); GuiImageData btnOutline(button_png); GuiImageData btnOutlineOver(button_over_png); + GuiImageData btnShortOutline(button_short_png); + GuiImageData btnShortOutlineOver(button_short_over_png); GuiTrigger trigA; if(GCSettings.WiimoteOrientation) @@ -2477,7 +2479,7 @@ static int MenuSettingsMappingsMap() GuiImage backBtnImgOver(&btnOutlineOver); GuiButton backBtn(btnOutline.GetWidth(), btnOutline.GetHeight()); backBtn.SetAlignment(ALIGN_LEFT, ALIGN_BOTTOM); - backBtn.SetPosition(100, -35); + backBtn.SetPosition(50, -35); backBtn.SetLabel(&backBtnTxt); backBtn.SetImage(&backBtnImg); backBtn.SetImageOver(&backBtnImgOver); @@ -2486,6 +2488,20 @@ static int MenuSettingsMappingsMap() backBtn.SetTrigger(&trigA); backBtn.SetEffectGrow(); + GuiText resetBtnTxt("Reset", 24, (GXColor){0, 0, 0, 255}); + GuiImage resetBtnImg(&btnShortOutline); + GuiImage resetBtnImgOver(&btnShortOutlineOver); + GuiButton resetBtn(btnShortOutline.GetWidth(), btnShortOutline.GetHeight()); + resetBtn.SetAlignment(ALIGN_LEFT, ALIGN_BOTTOM); + resetBtn.SetPosition(260, -35); + resetBtn.SetLabel(&resetBtnTxt); + resetBtn.SetImage(&resetBtnImg); + resetBtn.SetImageOver(&resetBtnImgOver); + resetBtn.SetSoundOver(&btnSoundOver); + resetBtn.SetSoundClick(&btnSoundClick); + resetBtn.SetTrigger(&trigA); + resetBtn.SetEffectGrow(); + i=0; switch(mapMenuCtrlNES) @@ -2511,6 +2527,9 @@ static int MenuSettingsMappingsMap() break; }; + for(i=0; i < options.length; i++) + options.value[i][0] = 0; + GuiOptionBrowser optionBrowser(552, 248, &options); optionBrowser.SetPosition(0, 108); optionBrowser.SetAlignment(ALIGN_CENTRE, ALIGN_TOP); @@ -2519,6 +2538,7 @@ static int MenuSettingsMappingsMap() HaltGui(); GuiWindow w(screenwidth, screenheight); w.Append(&backBtn); + w.Append(&resetBtn); mainWindow->Append(&optionBrowser); mainWindow->Append(&w); mainWindow->Append(&titleTxt); @@ -2531,14 +2551,17 @@ static int MenuSettingsMappingsMap() for(i=0; i < options.length; i++) { - options.value[i][0] = 0; - for(j=0; j < ctrlr_def[mapMenuCtrl].num_btns; j++) { - if(btnmap[mapMenuCtrlNES][mapMenuCtrl][i] == + if(btnmap[mapMenuCtrlNES][mapMenuCtrl][i] == 0) + { + options.value[i][0] = 0; + } + else if(btnmap[mapMenuCtrlNES][mapMenuCtrl][i] == ctrlr_def[mapMenuCtrl].map[j].btn) { - sprintf(options.value[i], ctrlr_def[mapMenuCtrl].map[j].name); + if(strcmp(options.value[i], ctrlr_def[mapMenuCtrl].map[j].name) != 0) + sprintf(options.value[i], ctrlr_def[mapMenuCtrl].map[j].name); break; } } @@ -2548,13 +2571,27 @@ static int MenuSettingsMappingsMap() if(ret >= 0) { - btnmap[mapMenuCtrlNES][mapMenuCtrl][ret] = ButtonMappingWindow(); // get a button selection from user + // get a button selection from user + btnmap[mapMenuCtrlNES][mapMenuCtrl][ret] = ButtonMappingWindow(); } if(backBtn.GetState() == STATE_CLICKED) { menu = MENU_GAMESETTINGS_MAPPINGS_CTRL; } + else if(resetBtn.GetState() == STATE_CLICKED) + { + resetBtn.ResetState(); + + int choice = WindowPrompt( + "Reset Mappings", + "Are you sure that you want to reset your mappings?", + "Yes", + "No"); + + if(choice == 1) + ResetControls(mapMenuCtrlNES, mapMenuCtrl); + } } HaltGui(); mainWindow->Remove(&optionBrowser); @@ -2789,6 +2826,9 @@ static int MenuSettingsVideo() sprintf(options.name[i++], "Video Mode"); options.length = i; + for(i=0; i < options.length; i++) + options.value[i][0] = 0; + GuiText titleTxt("Game Settings - Video", 28, (GXColor){255, 255, 255, 255}); titleTxt.SetAlignment(ALIGN_LEFT, ALIGN_TOP); titleTxt.SetPosition(50,50); @@ -2809,7 +2849,7 @@ static int MenuSettingsVideo() GuiImage backBtnImgOver(&btnOutlineOver); GuiButton backBtn(btnOutline.GetWidth(), btnOutline.GetHeight()); backBtn.SetAlignment(ALIGN_LEFT, ALIGN_BOTTOM); - backBtn.SetPosition(100, -35); + backBtn.SetPosition(50, -35); backBtn.SetLabel(&backBtnTxt); backBtn.SetImage(&backBtnImg); backBtn.SetImageOver(&backBtnImgOver); @@ -2995,7 +3035,7 @@ static int MenuSettings() savingBtn.SetEffectGrow(); GuiText menuBtnTxt("Menu", 24, (GXColor){0, 0, 0, 255}); - menuBtnTxt.SetMaxWidth(btnLargeOutline.GetWidth()-30); + menuBtnTxt.SetWrap(true, btnLargeOutline.GetWidth()-30); GuiImage menuBtnImg(&btnLargeOutline); GuiImage menuBtnImgOver(&btnLargeOutlineOver); GuiImage menuBtnIcon(&iconMenu); @@ -3012,7 +3052,7 @@ static int MenuSettings() menuBtn.SetEffectGrow(); GuiText networkBtnTxt("Network", 24, (GXColor){0, 0, 0, 255}); - networkBtnTxt.SetMaxWidth(btnLargeOutline.GetWidth()-30); + networkBtnTxt.SetWrap(true, btnLargeOutline.GetWidth()-30); GuiImage networkBtnImg(&btnLargeOutline); GuiImage networkBtnImgOver(&btnLargeOutlineOver); GuiImage networkBtnIcon(&iconNetwork); @@ -3137,6 +3177,9 @@ static int MenuSettingsFile() options.length = i; options.name[4][0] = 0; // hide cheats folder (not implemented) + for(i=0; i < options.length; i++) + options.value[i][0] = 0; + GuiText titleTxt("Settings - Saving & Loading", 28, (GXColor){255, 255, 255, 255}); titleTxt.SetAlignment(ALIGN_LEFT, ALIGN_TOP); titleTxt.SetPosition(50,50); @@ -3320,6 +3363,9 @@ static int MenuSettingsMenu() sprintf(options.name[i++], "Rumble"); options.length = i; + for(i=0; i < options.length; i++) + options.value[i][0] = 0; + GuiText titleTxt("Settings - Menu", 28, (GXColor){255, 255, 255, 255}); titleTxt.SetAlignment(ALIGN_LEFT, ALIGN_TOP); titleTxt.SetPosition(50,50); @@ -3465,6 +3511,9 @@ static int MenuSettingsNetwork() sprintf(options.name[i++], "SMB Share Password"); options.length = i; + for(i=0; i < options.length; i++) + options.value[i][0] = 0; + GuiText titleTxt("Settings - Network", 28, (GXColor){255, 255, 255, 255}); titleTxt.SetAlignment(ALIGN_LEFT, ALIGN_TOP); titleTxt.SetPosition(50,50);