From d2f76bb1313364397135c93c37672e57b50fb0a2 Mon Sep 17 00:00:00 2001 From: Colin Noga Date: Tue, 17 Jul 2012 18:55:15 -0500 Subject: Map fixes: HUD now reflects map status, Mario model reflects powerup --- src/koopatlas/hud.cpp | 275 +++++++++++++++++++++++++++++++++++++++++++++++--- 1 file changed, 260 insertions(+), 15 deletions(-) (limited to 'src/koopatlas/hud.cpp') diff --git a/src/koopatlas/hud.cpp b/src/koopatlas/hud.cpp index c20f026..286bbf5 100644 --- a/src/koopatlas/hud.cpp +++ b/src/koopatlas/hud.cpp @@ -1,5 +1,7 @@ #include "koopatlas/hud.h" +void CharToWChar(const char *input, wchar_t *output, int length) { for (int i = 0; i < length; i++) output[i] = input[i]; } + dWMHud_c *dWMHud_c::instance = 0; dWMHud_c *dWMHud_c::build() { @@ -54,10 +56,12 @@ int dWMHud_c::onCreate() { layout.disableAllAnimations(); layout.enableNonLoopAnim(ANIM_BOTTOM_SHOW); - showPointBar(); + hidePointBar(); + setWorldText(" "); + setWorldName(); if (dScKoopatlas_c::instance->pathManager.mustComplainToMapCreator) - dWMHud_c::instance->setText("Please Fix Your Missing Entrance. Thanks"); + dWMHud_c::instance->setLevelText("Please Fix Your Missing Entrance. Thanks"); layoutLoaded = true; } @@ -72,6 +76,11 @@ int dWMHud_c::onDelete() { int dWMHud_c::onExecute() { + updateLives(); + setWorldName(); + checkPointStatus(); + setPointName(); + layout.execAnimations(); layout.update(); @@ -86,14 +95,41 @@ int dWMHud_c::onDraw() { } -void dWMHud_c::updateText() { - setPointName(); -} +void dWMHud_c::updateLives() { + + static const char *textID[4] = {"M", "L", "B", "Y"}; + static const char *picID[4] = {"P_mariopic", "P_luigipic", "P_toadBlue", "P_toadyellow"}; + + for (int i = 0; i < 4; i++) { + char boxName [13]; + sprintf(boxName, "T_%slifes_01", textID[i]); + nw4r::lyt::TextBox *box = layout.findTextBoxByName(boxName); + nw4r::lyt::Pane *pic = layout.findPictureByName(picID[i]); -void dWMHud_c::setText(const char *str, int length) { + if (Player_Active[i] != 0) { + box->alpha = 0xFF; + pic->alpha = 0xFF; + + char lives [3]; + sprintf(lives, "%02d", Player_Lives[Player_ID[i]]); + const char *loaves = lives; + wchar_t life; + + CharToWChar(loaves, &life, 3); + + box->SetString(&life); + } + else { + box->alpha = 0; + pic->alpha = 0; + } + } +} + +void dWMHud_c::setLevelText(const char *str, int length) { if (str == 0) { - setText("--NULL STRING--"); + setLevelText("--NULL STRING--"); return; } @@ -109,13 +145,12 @@ void dWMHud_c::setText(const char *str, int length) { } newString[i] = 0; - setText(newString, i); + setLevelText(newString, i); } - -void dWMHud_c::setText(const wchar_t *str, int length) { +void dWMHud_c::setLevelText(const wchar_t *str, int length) { if (str == 0) { - setText("--NULL STRING--"); + setLevelText("--NULL STRING--"); return; } @@ -152,12 +187,224 @@ void dWMHud_c::setPointName() { dLevelInfo_c *li = &dScKoopatlas_c::instance->levelInfo; dLevelInfo_c::entry_s *entry = li->search(node->levelNumber[0] - 1, node->levelNumber[1] - 1); - setText(li->getNameForLevel(entry)); + setLevelText(li->getNameForLevel(entry)); } else { - setText(""); + setLevelText(" "); + hidePointBar(); + } +} + +void dWMHud_c::checkPointStatus() { + dKPNode_s *node = dScKoopatlas_c::instance->pathManager.currentNode; + + if (node->type == dKPNode_s::LEVEL) { + SaveBlock *save = GetSaveFile()->GetBlock(-1); + + int world = node->levelNumber[0]; + int level = node->levelNumber[1]; + + u32 conds = save->GetLevelCondition(world-1, level-1); + nw4r::lyt::Pane *pic; + + if (conds & COND_COIN1) { + pic = layout.findPictureByName("P_coin_on_01"); + pic->alpha = 0xFF; + + pic = layout.findPictureByName("P_coin_off_01"); + pic->alpha = 0; + } + else { + pic = layout.findPictureByName("P_coin_on_01"); + pic->alpha = 0; + + pic = layout.findPictureByName("P_coin_off_01"); + pic->alpha = 0xFF; + } + + if (conds & COND_COIN2) { + pic = layout.findPictureByName("P_coin_on_02"); + pic->alpha = 0xFF; + + pic = layout.findPictureByName("P_coin_off_02"); + pic->alpha = 0; + } + else { + pic = layout.findPictureByName("P_coin_on_02"); + pic->alpha = 0; + + pic = layout.findPictureByName("P_coin_off_02"); + pic->alpha = 0xFF; + } + + if (conds & COND_COIN3) { + pic = layout.findPictureByName("P_coin_on_03"); + pic->alpha = 0xFF; + + pic = layout.findPictureByName("P_coin_off_03"); + pic->alpha = 0; + } + else { + pic = layout.findPictureByName("P_coin_on_03"); + pic->alpha = 0; + + pic = layout.findPictureByName("P_coin_off_03"); + pic->alpha = 0xFF; + } + + if (conds & COND_NORMAL) { + pic = layout.findPictureByName("P_normalexitflag"); + pic->alpha = 0xFF; + } + else { + pic = layout.findPictureByName("P_normalexitflag"); + pic->alpha = 0; + } + + if (conds & COND_SECRET) { + pic = layout.findPictureByName("P_secretexitflag"); + pic->alpha = 0xFF; + } + else { + pic = layout.findPictureByName("P_secretexitflag"); + pic->alpha = 0; + } + + } else { + nw4r::lyt::Pane *pic; + + static const char *picNames[8] = {"P_coin_on_01", "P_coin_off_01", "P_coin_on_02", "P_coin_off_02", + "P_coin_on_03", "P_coin_off_03", "P_normalexitflag", "P_secretexitflag"}; + + for (int i = 0; i < 8; i++) { + pic = layout.findPictureByName(picNames[i]); + pic->alpha = 0; + } } } +void dWMHud_c::setWorldText(const char *str, int length) { + if (str == 0) { + setWorldText("--NULL STRING--"); + return; + } + + if (length == -1) { + length = strlen(str); + } + + wchar_t newString[128]; + + int i; + for (i = 0; i < length && i < 128; i++) { + newString[i] = str[i]; + } + newString[i] = 0; + + setWorldText(newString, i); +} + +void dWMHud_c::setWorldText(const wchar_t *str, int length) { + if (str == 0) { + setWorldText("--NULL STRING--"); + return; + } + + if (length == -1) { + length = wcslen(str); + } + + nw4r::lyt::TextBox *box = layout.findTextBoxByName("T_area_01"); + + nw4r::ut::TextWriter tw; + tw.font = box->font; + tw.SetFontSize(box->fontSizeX, box->fontSizeY); + tw.somethingRelatedToLineHeight = box->lineSpace; + tw.charSpace = box->charSpace; + if (box->tagProc != 0) + tw.tagProcessorMaybe = box->tagProc; + + float width = tw.CalcStringWidth(str, length); + SpammyReport("Text width: %f\n", width); + + box->SetString(str); +} + +void dWMHud_c::setWorldName() { + // figure this out... + dKPNode_s *node = dScKoopatlas_c::instance->pathManager.currentNode; + + if (node->type == dKPNode_s::LEVEL) { + int world = node->levelNumber[0]; + int level = node->levelNumber[1]; + + switch (world) { + case 1: + setWorldText("Yoshi's\nIsland"); + break; + + case 2: + if (((level > 1) && (level < 5)) || (level == 15) || (level == 33) || (level == 34)) + setWorldText("Soggy\nSewers"); + else + setWorldText("Rubble\nRuins"); + break; + + case 3: + setWorldText("Mushroom\nPeaks"); + break; + + case 4: + setWorldText("Sakura\nVillage"); + break; + + case 5: + if ((level < 6) || (level == 15) || (level == 33) || (level == 34)) + setWorldText("Freeze Flame\nValley"); + else + setWorldText("Freeze Flame\nVolcano"); + break; + + case 6: + setWorldText("Ghost\nRealm"); + break; + + case 7: + if (level < 4) + setWorldText("Sky\nMountain"); + else + setWorldText("Starry\nSkies"); + break; + + case 8: + if ((level < 6) || (level == 15) || (level == 25) || (level == 33) || (level == 34)) + setWorldText("Koopa\nPlanet"); + else + setWorldText("Koopa\nCore"); + break; + + case 9: + setWorldText("Bonus\nLand"); + break; + + case 10: + if ((level < 6) || (level == 33) || (level == 34)) + setWorldText("Goldwood\nForest"); + else if ((level < 11) || (level == 35) || (level == 36)) + setWorldText("Mini-Mega\nIsland"); + else if ((level < 16) || (level == 37) || (level == 38) || (level == 31) ) + setWorldText("Crystal\nCaves"); + else if ((level < 19) || (level == 39) || (level == 40)) + setWorldText("Bombard\nCliffs"); + else + setWorldText("Sky\nCity"); + break; + + default: + setWorldText("Unknown\nWorld"); + break; + } + } +} void dWMHud_c::showPointBar() { dKPNode_s *node = dScKoopatlas_c::instance->pathManager.currentNode; @@ -165,8 +412,6 @@ void dWMHud_c::showPointBar() { if (node->type == dKPNode_s::LEVEL) { isPointBarShown = true; - updateText(); - layout.enableNonLoopAnim(ANIM_TOP_SHOW); } } -- cgit v1.2.3