Fix random wild evolution logic

pull/1/head
Flashfyre 2023-05-04 20:47:41 -04:00
parent 4423f79b66
commit f33ee493bd
1 changed files with 36 additions and 20 deletions

View File

@ -227,39 +227,55 @@ export default class PokemonSpecies extends PokemonSpeciesForm {
const evolutions = pokemonEvolutions[this.speciesId]; const evolutions = pokemonEvolutions[this.speciesId];
const speciesIds: Species[] = [];
const easeInFunc = Phaser.Tweens.Builders.GetEaseFunction('Sine.easeIn'); const easeInFunc = Phaser.Tweens.Builders.GetEaseFunction('Sine.easeIn');
const easeOutFunc = Phaser.Tweens.Builders.GetEaseFunction('Sine.easeOut'); const easeOutFunc = Phaser.Tweens.Builders.GetEaseFunction('Sine.easeOut');
const evolutionPool: Map<number, Species> = new Map();
let totalWeight = 0;
let noEvolutionChance = 1;
for (let ev of evolutions) { for (let ev of evolutions) {
if (ev.level > level) if (ev.level > level)
continue; continue;
let evolutionChance: number;
if (ev.wildDelay === SpeciesWildEvolutionDelay.NONE) { if (ev.wildDelay === SpeciesWildEvolutionDelay.NONE)
speciesIds.push(ev.speciesId); evolutionChance = Math.min(0.5 + easeInFunc((level - ev.level) / 40) / 2, 1);
continue; else {
let preferredMinLevel = ev.wildDelay * 10;
let evolutionLevel = ev.level > 1 ? ev.level : 0;
if (!evolutionLevel && pokemonPrevolutions.hasOwnProperty(this.speciesId)) {
const prevolutionLevel = pokemonEvolutions[pokemonPrevolutions[this.speciesId]].find(ev => ev.speciesId === this.speciesId).level;
if (prevolutionLevel > 1)
evolutionLevel = prevolutionLevel;
}
evolutionChance = Math.min(0.65 * easeInFunc((Math.min(Math.max(level - evolutionLevel, 0), preferredMinLevel) / preferredMinLevel)) + 0.35 * easeOutFunc(Math.min(level - evolutionLevel, preferredMinLevel * 2.5) / (preferredMinLevel * 2.5)), 1);
} }
let preferredMinLevel = ev.wildDelay * 10; if (evolutionChance > 0) {
let evolutionLevel = ev.level > 1 ? ev.level : 0; totalWeight += evolutionChance;
if (!evolutionLevel && pokemonPrevolutions.hasOwnProperty(this.speciesId)) { evolutionPool.set(totalWeight, ev.speciesId);
const prevolutionLevel = pokemonEvolutions[pokemonPrevolutions[this.speciesId]].find(ev => ev.speciesId === this.speciesId).level;
if (prevolutionLevel > 1) if ((1 - evolutionChance) < noEvolutionChance)
evolutionLevel = prevolutionLevel; noEvolutionChance = 1 - evolutionChance;
} }
const evolutionChance = 0.65 * easeInFunc((Math.min(Math.max(level - evolutionLevel, 0), preferredMinLevel) / preferredMinLevel)) + 0.35 * easeOutFunc(Math.min(level - evolutionLevel, preferredMinLevel * 2.5) / (preferredMinLevel * 2.5));
if (Math.random() <= evolutionChance)
speciesIds.push(ev.speciesId);
} }
if (speciesIds.length) { if (noEvolutionChance === 1 || Math.random() < noEvolutionChance)
return speciesIds.length === 1 return this.speciesId;
? speciesIds[0]
: speciesIds[Utils.randInt(speciesIds.length)]; if (evolutionPool.size === 1)
return evolutionPool.values()[0];
const randValue = Math.random() * totalWeight;
for (let weight of evolutionPool.keys()) {
if (randValue < weight)
return evolutionPool.get(weight);
} }
return this.speciesId; return this.speciesId;