Merge pull request #554 from GriffinRichards/fix-encounters

Fix issues when user supplies incorrect number of encounters
This commit is contained in:
GriffinR 2023-12-02 14:32:54 -05:00 committed by GitHub
commit b88d62ecc1
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 7 additions and 2 deletions

View file

@ -30,6 +30,7 @@ The **"Breaking Changes"** listed below are changes that have been made in the d
- Fix the selection outline sticking in single-tile mode on the Prefab tab. - Fix the selection outline sticking in single-tile mode on the Prefab tab.
- Fix heal location data being cleared if certain spaces aren't used in the table. - Fix heal location data being cleared if certain spaces aren't used in the table.
- Fix bad URL color contrast on dark themes. - Fix bad URL color contrast on dark themes.
- Fix some issues when too few/many pokémon are specified for a wild encounter group.
## [5.1.1] - 2023-02-20 ## [5.1.1] - 2023-02-20
### Added ### Added

View file

@ -1670,6 +1670,11 @@ bool Project::readWildMonData() {
newMon.species = monObj["species"].string_value(); newMon.species = monObj["species"].string_value();
header.wildMons[field].wildPokemon.append(newMon); header.wildMons[field].wildPokemon.append(newMon);
} }
// If the user supplied too few pokémon for this group then we fill in the rest.
for (int i = header.wildMons[field].wildPokemon.length(); i < monField.encounterRates.length(); i++) {
WildPokemon newMon; // Keep default values
header.wildMons[field].wildPokemon.append(newMon);
}
} }
} }
wildMonData[mapConstant].insert({encounterObj["base_label"].string_value(), header}); wildMonData[mapConstant].insert({encounterObj["base_label"].string_value(), header});

View file

@ -10,11 +10,10 @@ EncounterTableModel::EncounterTableModel(WildMonInfo info, EncounterFields field
this->resize(this->monInfo.wildPokemon.size(), ColumnType::Count); this->resize(this->monInfo.wildPokemon.size(), ColumnType::Count);
this->slotRatios = fields[fieldIndex].encounterRates;
for (int r = 0; r < this->numRows; r++) { for (int r = 0; r < this->numRows; r++) {
this->groupNames.append(QString()); this->groupNames.append(QString());
this->slotPercentages.append(0.0); this->slotPercentages.append(0.0);
this->slotRatios.append(fields[fieldIndex].encounterRates.value(r, 0));
} }
if (!this->encounterFields[this->fieldIndex].groups.empty()) { if (!this->encounterFields[this->fieldIndex].groups.empty()) {