Fix excluded locs, ap icon in notifs, death link while connecting
This commit is contained in:
@@ -421,6 +421,7 @@ void Context::ParseArchipelago() {
|
||||
mSeedGenerated = false;
|
||||
mSpoilerLoaded = false;
|
||||
|
||||
Rando::Settings::GetInstance()->ResetExcludedLocations();
|
||||
ArchipelagoClient& apClient = ArchipelagoClient::GetInstance();
|
||||
ParseArchipelagoItemsLocations(apClient.GetScoutedItems());
|
||||
ParseArchipelagoOptions(apClient.GetSlotData());
|
||||
|
||||
@@ -2929,6 +2929,13 @@ void Settings::ParseJson(nlohmann::json spoilerFileJson) {
|
||||
}
|
||||
}
|
||||
|
||||
void Settings::ResetExcludedLocations() {
|
||||
const auto ctx = Context::GetInstance();
|
||||
for (int rc = 1; rc < RC_MAX; rc++) {
|
||||
ctx->GetItemLocation(rc)->SetExcludedOption(RO_GENERIC_OFF);
|
||||
}
|
||||
}
|
||||
|
||||
void Settings::AssignContext(std::shared_ptr<Context> ctx) {
|
||||
mContext = ctx;
|
||||
}
|
||||
|
||||
@@ -115,7 +115,8 @@ class Settings {
|
||||
*/
|
||||
void ParseJson(nlohmann::json spoilerFileJson);
|
||||
|
||||
void ParseArchipelago(const std::map<std::string, int>& slot_data);
|
||||
void ResetExcludedLocations();
|
||||
|
||||
std::map<RandomizerArea, std::vector<RandomizerTrick>> mTricksByArea = {};
|
||||
|
||||
/**
|
||||
|
||||
@@ -262,6 +262,20 @@ bool ArchipelagoClient::StopClient() {
|
||||
}
|
||||
|
||||
void ArchipelagoClient::GameLoaded() {
|
||||
|
||||
// Load textures for the archipelago items that're shown in the notifications
|
||||
static bool sArchipelagoTexturesLoaded = false;
|
||||
if (!sArchipelagoTexturesLoaded) {
|
||||
Ship::Context::GetInstance()->GetWindow()->GetGui()->LoadTextureFromRawImage(
|
||||
"Archipelago Progressive Icon", "textures/parameter_static/gArchipelagoProgressive.png");
|
||||
Ship::Context::GetInstance()->GetWindow()->GetGui()->LoadTextureFromRawImage(
|
||||
"Archipelago Useful Icon", "textures/parameter_static/gArchipelagoUseful.png");
|
||||
Ship::Context::GetInstance()->GetWindow()->GetGui()->LoadTextureFromRawImage(
|
||||
"Archipelago Junk Icon", "textures/parameter_static/gArchipelagoJunk.png");
|
||||
|
||||
sArchipelagoTexturesLoaded = true;
|
||||
}
|
||||
|
||||
if (apClient == nullptr) {
|
||||
if(IS_ARCHIPELAGO) {
|
||||
CVarSetString(CVAR_REMOTE_ARCHIPELAGO("ServerAddress"), gSaveContext.ship.quest.data.archipelago.archiUri);
|
||||
@@ -560,7 +574,7 @@ void ArchipelagoClient::SendDeathLink() {
|
||||
}
|
||||
|
||||
void ArchipelagoClient::SetDeathLinkTag() {
|
||||
if (!apClient) {
|
||||
if (!ArchipelagoClient::IsConnected()) {
|
||||
return;
|
||||
}
|
||||
std::list<std::string> tags;
|
||||
|
||||
@@ -75,18 +75,6 @@ void ArchipelagoSettingsWindow::DrawElement() {
|
||||
UIWidgets::CheckboxOptions().Color(THEME_COLOR).Tooltip("You die, others die. Others die, you die!"))) {
|
||||
apClient.SetDeathLinkTag();
|
||||
}
|
||||
|
||||
static bool sArchipelagoTexturesLoaded = false;
|
||||
if (!sArchipelagoTexturesLoaded) {
|
||||
Ship::Context::GetInstance()->GetWindow()->GetGui()->LoadTextureFromRawImage(
|
||||
"Archipelago Progressive Icon", "textures/parameter_static/gArchipelagoProgressive.png");
|
||||
Ship::Context::GetInstance()->GetWindow()->GetGui()->LoadTextureFromRawImage(
|
||||
"Archipelago Useful Icon", "textures/parameter_static/gArchipelagoUseful.png");
|
||||
Ship::Context::GetInstance()->GetWindow()->GetGui()->LoadTextureFromRawImage(
|
||||
"Archipelago Junk Icon", "textures/parameter_static/gArchipelagoJunk.png");
|
||||
|
||||
sArchipelagoTexturesLoaded = true;
|
||||
}
|
||||
};
|
||||
|
||||
void ArchipelagoSettingsWindow::InitElement() {
|
||||
|
||||
Reference in New Issue
Block a user