mirror of
https://github.com/kwsch/PKHeX
synced 2025-01-11 12:08:57 +00:00
ccf87242c1
struct implementing interface is boxed when passed to method that accepts interface (not generic method). Removes IDexLevel (no other inheritors but EvoCriteria) and uses the primitive the data is stored (array, not IReadOnlyList) for slightly better perf.
98 lines
3.1 KiB
C#
98 lines
3.1 KiB
C#
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using static PKHeX.Core.Encounters8Nest;
|
|
|
|
namespace PKHeX.Core
|
|
{
|
|
/// <summary>
|
|
/// Generation 8 Nest Encounter (Regular Raid Dens)
|
|
/// </summary>
|
|
/// <inheritdoc cref="EncounterStatic8Nest{T}"/>
|
|
public sealed record EncounterStatic8N : EncounterStatic8Nest<EncounterStatic8N>
|
|
{
|
|
private readonly uint MinRank;
|
|
private readonly uint MaxRank;
|
|
private readonly byte NestID;
|
|
|
|
private IReadOnlyList<byte> NestLocations => Encounters8Nest.NestLocations[NestID];
|
|
|
|
public override byte Level { get => LevelMin; init { } }
|
|
public override byte LevelMin => LevelCaps[MinRank * 2];
|
|
public override byte LevelMax => LevelCaps[(MaxRank * 2) + 1];
|
|
|
|
public EncounterStatic8N(byte nestID, uint minRank, uint maxRank, byte val, GameVersion game) : base(game)
|
|
{
|
|
NestID = nestID;
|
|
MinRank = minRank;
|
|
MaxRank = maxRank;
|
|
DynamaxLevel = (byte)(MinRank + 1u);
|
|
FlawlessIVCount = val;
|
|
}
|
|
|
|
private static readonly byte[] LevelCaps =
|
|
{
|
|
15, 20, // 0
|
|
25, 30, // 1
|
|
35, 40, // 2
|
|
45, 50, // 3
|
|
55, 60, // 4
|
|
};
|
|
|
|
protected override bool IsMatchLevel(PKM pkm, EvoCriteria evo)
|
|
{
|
|
var met = pkm.Met_Level;
|
|
var metLevel = met - 15;
|
|
var rank = ((uint)metLevel) / 10;
|
|
if (rank > 4)
|
|
return false;
|
|
if (rank > MaxRank)
|
|
return false;
|
|
|
|
if (rank <= 1)
|
|
{
|
|
if (InaccessibleRank12Nests.TryGetValue(pkm.Met_Location, out var nests) && nests.Contains(NestID))
|
|
return false;
|
|
}
|
|
|
|
if (rank < MinRank) // down-leveled
|
|
return IsDownLeveled(pkm, metLevel, met);
|
|
|
|
return metLevel % 10 <= 5;
|
|
}
|
|
|
|
public bool IsDownLeveled(PKM pkm)
|
|
{
|
|
var met = pkm.Met_Level;
|
|
var metLevel = met - 15;
|
|
return met != LevelMax && IsDownLeveled(pkm, metLevel, met);
|
|
}
|
|
|
|
private bool IsDownLeveled(PKM pkm, int metLevel, int met)
|
|
{
|
|
if (metLevel % 5 != 0)
|
|
return false;
|
|
|
|
// shared nests can be down-leveled to any
|
|
if (pkm.Met_Location == SharedNest)
|
|
return met >= 20;
|
|
|
|
// native down-levels: only allow 1 rank down (1 badge 2star -> 25), (3badge 3star -> 35)
|
|
return ((MinRank <= 1 && 1 <= MaxRank && met == 25)
|
|
|| (MinRank <= 2 && 2 <= MaxRank && met == 35)) && !pkm.IsShiny;
|
|
}
|
|
|
|
protected override bool IsMatchLocation(PKM pkm)
|
|
{
|
|
var loc = pkm.Met_Location;
|
|
return loc == SharedNest || (loc <= 255 && NestLocations.Contains((byte)loc));
|
|
}
|
|
|
|
public override bool IsMatchExact(PKM pkm, EvoCriteria evo)
|
|
{
|
|
if (pkm.FlawlessIVCount < FlawlessIVCount)
|
|
return false;
|
|
|
|
return base.IsMatchExact(pkm, evo);
|
|
}
|
|
}
|
|
}
|