mirror of
https://github.com/HarbourMasters/Shipwright.git
synced 2025-01-13 23:18:03 -05:00
Merge pull request #1108 from leggettc18/rando-custom-message-fixes
Rando-custom-message-fixes
This commit is contained in:
commit
b949440fd1
@ -1406,14 +1406,15 @@ std::unordered_map<std::string, RandomizerSettingKey> SpoilerfileSettingNameToEn
|
|||||||
{ "Open Settings:Random Ganon's Trials", RSK_RANDOM_TRIALS },
|
{ "Open Settings:Random Ganon's Trials", RSK_RANDOM_TRIALS },
|
||||||
{ "Open Settings:Trial Count", RSK_TRIAL_COUNT },
|
{ "Open Settings:Trial Count", RSK_TRIAL_COUNT },
|
||||||
{ "Shuffle Settings:Shuffle Cows", RSK_SHUFFLE_COWS },
|
{ "Shuffle Settings:Shuffle Cows", RSK_SHUFFLE_COWS },
|
||||||
|
{ "Shuffle Settings:Tokensanity", RSK_SHUFFLE_TOKENS },
|
||||||
{ "Start with Deku Shield", RSK_STARTING_DEKU_SHIELD },
|
{ "Start with Deku Shield", RSK_STARTING_DEKU_SHIELD },
|
||||||
{ "Start with Kokiri Sword", RSK_STARTING_KOKIRI_SWORD },
|
{ "Start with Kokiri Sword", RSK_STARTING_KOKIRI_SWORD },
|
||||||
{ "Start with Fairy Ocarina", RSK_STARTING_OCARINA },
|
{ "Start with Fairy Ocarina", RSK_STARTING_OCARINA },
|
||||||
{ "Shuffle Dungeon Items:Start with Maps/Compasses", RSK_STARTING_MAPS_COMPASSES },
|
{ "Shuffle Dungeon Items:Start with Maps/Compasses", RSK_STARTING_MAPS_COMPASSES },
|
||||||
{ "Shuffle Dungeon Items:Ganon's Boss Key", RSK_GANONS_BOSS_KEY },
|
{ "Shuffle Dungeon Items:Ganon's Boss Key", RSK_GANONS_BOSS_KEY },
|
||||||
{ "Misc Settings:Gossip Stone Hints", RSK_GOSSIP_STONE_HINTS },
|
{ "Misc Settings:Gossip Stone Hints", RSK_GOSSIP_STONE_HINTS },
|
||||||
{ "Misc Settings:Hint Clarity", RSK_HINT_CLARITY},
|
{ "Misc Settings:Hint Clarity", RSK_HINT_CLARITY },
|
||||||
{ "Misc Settings:Hint Distribution", RSK_HINT_DISTRIBUTION},
|
{ "Misc Settings:Hint Distribution", RSK_HINT_DISTRIBUTION },
|
||||||
{ "Skip Child Zelda", RSK_SKIP_CHILD_ZELDA },
|
{ "Skip Child Zelda", RSK_SKIP_CHILD_ZELDA },
|
||||||
{ "Start with Consumables", RSK_STARTING_CONSUMABLES },
|
{ "Start with Consumables", RSK_STARTING_CONSUMABLES },
|
||||||
{ "Start with Max Rupees", RSK_FULL_WALLETS },
|
{ "Start with Max Rupees", RSK_FULL_WALLETS },
|
||||||
@ -1731,6 +1732,18 @@ void Randomizer::ParseRandomizerSettingsFile(const char* spoilerFileName) {
|
|||||||
} else if (it.value() == "Skip") {
|
} else if (it.value() == "Skip") {
|
||||||
gSaveContext.randoSettings[index].value = 1;
|
gSaveContext.randoSettings[index].value = 1;
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
case RSK_SHUFFLE_TOKENS:
|
||||||
|
if (it.value() == "Off") {
|
||||||
|
gSaveContext.randoSettings[index].value = 0;
|
||||||
|
} else if (it.value() == "Dungeons") {
|
||||||
|
gSaveContext.randoSettings[index].value = 1;
|
||||||
|
} else if (it.value() == "Overworld") {
|
||||||
|
gSaveContext.randoSettings[index].value = 2;
|
||||||
|
} else if (it.value() == "All Tokens") {
|
||||||
|
gSaveContext.randoSettings[index].value = 3;
|
||||||
|
}
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
index++;
|
index++;
|
||||||
}
|
}
|
||||||
@ -4374,10 +4387,16 @@ void CreateGetItemMessages(std::vector<GetItemMessage> messageEntries) {
|
|||||||
CustomMessageManager* customMessageManager = CustomMessageManager::Instance;
|
CustomMessageManager* customMessageManager = CustomMessageManager::Instance;
|
||||||
customMessageManager->AddCustomMessageTable(Randomizer::getItemMessageTableID);
|
customMessageManager->AddCustomMessageTable(Randomizer::getItemMessageTableID);
|
||||||
for (GetItemMessage messageEntry : messageEntries) {
|
for (GetItemMessage messageEntry : messageEntries) {
|
||||||
customMessageManager->CreateGetItemMessage(Randomizer::getItemMessageTableID, messageEntry.giid, messageEntry.iid,
|
if (messageEntry.giid == GI_ICE_TRAP) {
|
||||||
{ TEXTBOX_TYPE_BLUE, TEXTBOX_POS_BOTTOM,
|
customMessageManager->CreateMessage(Randomizer::getItemMessageTableID, messageEntry.giid,
|
||||||
messageEntry.english, messageEntry.german,
|
{ TEXTBOX_TYPE_BLUE, TEXTBOX_POS_BOTTOM, messageEntry.english,
|
||||||
messageEntry.french });
|
messageEntry.german, messageEntry.french });
|
||||||
|
} else {
|
||||||
|
customMessageManager->CreateGetItemMessage(Randomizer::getItemMessageTableID, messageEntry.giid,
|
||||||
|
messageEntry.iid,
|
||||||
|
{ TEXTBOX_TYPE_BLUE, TEXTBOX_POS_BOTTOM, messageEntry.english,
|
||||||
|
messageEntry.german, messageEntry.french });
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4403,23 +4422,27 @@ void Randomizer::CreateCustomMessages() {
|
|||||||
// RANDTODO: Translate into french and german and replace GIMESSAGE_UNTRANSLATED
|
// RANDTODO: Translate into french and german and replace GIMESSAGE_UNTRANSLATED
|
||||||
// with GIMESSAGE(getItemID, itemID, english, german, french).
|
// with GIMESSAGE(getItemID, itemID, english, german, french).
|
||||||
const std::vector<GetItemMessage> getItemMessages = {
|
const std::vector<GetItemMessage> getItemMessages = {
|
||||||
|
GIMESSAGE(GI_ICE_TRAP, ITEM_NONE, "\x08\x06\x30You are a %bFOWL%w!\x0E\x20",
|
||||||
|
"\x08\x06\x15 Du bist ein %bDUMMKOPF%w!\x0E\x20", "\x08\x06\x50%bIDIOT%w\x0E\x20"),
|
||||||
GIMESSAGE_UNTRANSLATED(GI_BOTTLE_WITH_BLUE_FIRE, ITEM_BLUE_FIRE,
|
GIMESSAGE_UNTRANSLATED(GI_BOTTLE_WITH_BLUE_FIRE, ITEM_BLUE_FIRE,
|
||||||
"You got a %rBottle with Blue &Fire%w! Use it to melt Red Ice!"),
|
"You got a %rBottle with Blue &Fire%w! Use it to melt Red Ice!"),
|
||||||
GIMESSAGE_UNTRANSLATED(GI_BOTTLE_WITH_BIG_POE, ITEM_BIG_POE,
|
GIMESSAGE_UNTRANSLATED(GI_BOTTLE_WITH_BIG_POE, ITEM_BIG_POE,
|
||||||
"You got a %rBig Poe in a Bottle%w!&Sell it to the Ghost Shop!"),
|
"You got a %rBig Poe in a Bottle%w!&Sell it to the Ghost Shop!"),
|
||||||
GIMESSAGE_UNTRANSLATED(GI_BOTTLE_WITH_BLUE_POTION, ITEM_POTION_BLUE,
|
GIMESSAGE_UNTRANSLATED(
|
||||||
"You got a %rBottle of Blue Potion%w!&Drink it to replenish your&%ghealth%w and %bmagic%w!"),
|
GI_BOTTLE_WITH_BLUE_POTION, ITEM_POTION_BLUE,
|
||||||
GIMESSAGE_UNTRANSLATED(GI_BOTTLE_WITH_FISH, ITEM_FISH,
|
"You got a %rBottle of Blue Potion%w!&Drink it to replenish your&%ghealth%w and %bmagic%w!"),
|
||||||
"You got a %rFish in a Bottle%w!&It looks fresh and delicious!&They say Jabu-Jabu loves them!"),
|
GIMESSAGE_UNTRANSLATED(
|
||||||
|
GI_BOTTLE_WITH_FISH, ITEM_FISH,
|
||||||
|
"You got a %rFish in a Bottle%w!&It looks fresh and delicious!&They say Jabu-Jabu loves them!"),
|
||||||
GIMESSAGE_UNTRANSLATED(GI_BOTTLE_WITH_BUGS, ITEM_BUG,
|
GIMESSAGE_UNTRANSLATED(GI_BOTTLE_WITH_BUGS, ITEM_BUG,
|
||||||
"You got a %rBug in a Bottle%w!&They love to burrow in&dirt holes!"),
|
"You got a %rBug in a Bottle%w!&They love to burrow in&dirt holes!"),
|
||||||
GIMESSAGE_UNTRANSLATED(GI_BOTTLE_WITH_FAIRY, ITEM_FAIRY, "You got a %rFairy in a Bottle%w!&Use it wisely!"),
|
GIMESSAGE_UNTRANSLATED(GI_BOTTLE_WITH_FAIRY, ITEM_FAIRY, "You got a %rFairy in a Bottle%w!&Use it wisely!"),
|
||||||
GIMESSAGE_UNTRANSLATED(GI_BOTTLE_WITH_RED_POTION, ITEM_POTION_RED,
|
GIMESSAGE_UNTRANSLATED(GI_BOTTLE_WITH_RED_POTION, ITEM_POTION_RED,
|
||||||
"You got a %rBottle of Red Potion%w!&Drink it to replenish your&%ghealth%w!"),
|
"You got a %rBottle of Red Potion%w!&Drink it to replenish your&%ghealth%w!"),
|
||||||
GIMESSAGE_UNTRANSLATED(GI_BOTTLE_WITH_GREEN_POTION, ITEM_POTION_GREEN,
|
GIMESSAGE_UNTRANSLATED(GI_BOTTLE_WITH_GREEN_POTION, ITEM_POTION_GREEN,
|
||||||
"You got a %rBottle of Green Potion%w!&Drink it to replenish your&%bmagic%w!"),
|
"You got a %rBottle of Green Potion%w!&Drink it to replenish your&%bmagic%w!"),
|
||||||
GIMESSAGE_UNTRANSLATED(GI_BOTTLE_WITH_POE, ITEM_POE,
|
GIMESSAGE_UNTRANSLATED(GI_BOTTLE_WITH_POE, ITEM_POE,
|
||||||
"You got a %rPoe in a Bottle%w!&That creepy Ghost Shop might&be interested in this..."),
|
"You got a %rPoe in a Bottle%w!&That creepy Ghost Shop might&be interested in this..."),
|
||||||
};
|
};
|
||||||
CreateGetItemMessages(getItemMessages);
|
CreateGetItemMessages(getItemMessages);
|
||||||
CreateScrubMessages();
|
CreateScrubMessages();
|
||||||
|
@ -1546,7 +1546,15 @@ extern "C" int CustomMessage_RetrieveIfExists(GlobalContext* globalCtx) {
|
|||||||
}
|
}
|
||||||
if (textId == TEXT_GS_NO_FREEZE || textId == TEXT_GS_FREEZE) {
|
if (textId == TEXT_GS_NO_FREEZE || textId == TEXT_GS_FREEZE) {
|
||||||
if (CVar_GetS32("gInjectSkulltulaCount", 0) != 0) {
|
if (CVar_GetS32("gInjectSkulltulaCount", 0) != 0) {
|
||||||
if (CVar_GetS32("gSkulltulaFreeze", 0) != 0) {
|
// The freeze text cannot be manually dismissed and must be auto-dismissed.
|
||||||
|
// This is fine and even wanted when skull tokens are not shuffled, but when
|
||||||
|
// when they are shuffled we don't want to be able to manually dismiss the box.
|
||||||
|
// Otherwise if we get a token from a chest or an NPC we get stuck in the ItemGet
|
||||||
|
// animation until the text box auto-dismisses.
|
||||||
|
// RANDOTODO: Implement a way to determine if an item came from a skulltula and
|
||||||
|
// inject the auto-dismiss control code if it did.
|
||||||
|
if (CVar_GetS32("gSkulltulaFreeze", 0) != 0 &&
|
||||||
|
!(gSaveContext.n64ddFlag && Randomizer_GetSettingValue(RSK_SHUFFLE_TOKENS) > 0)) {
|
||||||
textId = TEXT_GS_NO_FREEZE;
|
textId = TEXT_GS_NO_FREEZE;
|
||||||
} else {
|
} else {
|
||||||
textId = TEXT_GS_FREEZE;
|
textId = TEXT_GS_FREEZE;
|
||||||
|
Loading…
Reference in New Issue
Block a user