P3D-Legacy/P3D/Player/Pokedex.vb

466 lines
18 KiB
VB.net

Public Class Pokedex
'0 = undiscovered
'1 = seen
'2 = caught + seen
'3 = shiny + caught + seen
Public Shared AutoDetect As Boolean = True
Public Shared PokemonMaxCount As Integer = 1010
Public Shared PokemonCount As Integer = 1010
Public Shared PokemonIDs As New List(Of String)
#Region "PlayerData"
Public Shared Function CountEntries(ByVal Data As String, ByVal Type() As Integer) As Integer
Dim counts As Integer = 0
Dim pData() As String = Data.Split(CChar(Environment.NewLine))
For Each Entry As String In pData
Entry = Entry.Remove(0, Entry.IndexOf("{") + 1)
Entry = Entry.Remove(Entry.Length - 1, 1)
Dim eID As Integer = CInt(Entry.GetSplit(0, "|"))
Dim eType As Integer = CInt(Entry.GetSplit(1, "|"))
If Type.Contains(eType) = True Then
counts += 1
End If
Next
Return counts
End Function
Public Shared Function CountEntries(ByVal Data As String, ByVal Type() As Integer, ByVal Range() As String) As Integer
Dim IDs As New List(Of Integer)
For Each r As String In Range
If StringHelper.IsNumeric(r) = True Then
If IDs.Contains(CInt(r)) = False Then
IDs.Add(CInt(r))
End If
Else
If r.Contains("-") = True Then
Dim min As Integer = CInt(r.Remove(r.IndexOf("-")))
Dim max As Integer = CInt(r.Remove(0, r.IndexOf("-") + 1))
For i = min To max
If IDs.Contains(i) = False Then
IDs.Add(i)
End If
Next
End If
End If
Next
Dim counts As Integer = 0
Dim pData() As String = Data.Split(CChar(Environment.NewLine))
For Each Entry As String In pData
Entry = Entry.Remove(0, Entry.IndexOf("{") + 1)
Entry = Entry.Remove(Entry.Length - 1, 1)
Dim eID As Integer = CInt(Entry.GetSplit(0, "|"))
Dim eType As Integer = CInt(Entry.GetSplit(1, "|"))
If IDs.Contains(eID) = True Then
If Type.Contains(eType) = True Then
counts += 1
End If
End If
Next
Return counts
End Function
Public Shared Function GetEntryType(ByVal Data As String, ByVal ID As String) As Integer
Dim pData() As String = Data.Split(CChar(Environment.NewLine))
For Each Entry As String In pData
If Entry.Contains(ID & "|") = True Then
Return CInt(Entry.Remove(Entry.Length - 1, 1).Remove(0, Entry.IndexOf("|") + 1))
End If
Next
Return 0
End Function
Public Shared Function ChangeEntry(ByVal Data As String, ByVal ID As String, ByVal Type As Integer, Optional ForceChange As Boolean = False) As String
If ForceChange = True OrElse Type = 0 Or AutoDetect = True Then
If Data.Contains("{" & ID & "|") = True Then
Dim cOriginalEntry As String = ""
If ID.Contains(";") Then
cOriginalEntry = GetEntryType(Data, ID.GetSplit(0, ";")).ToString
End If
If ID.Contains("_") Then
If Pokemon.GetPokemonByID(CInt(ID.GetSplit(0, "_"))).DexForms.Contains(ID.GetSplit(1, "_")) Then
cOriginalEntry = GetEntryType(Data, ID.GetSplit(0, "_")).ToString
End If
End If
Dim cEntry As Integer = GetEntryType(Data, ID)
Dim cData As String = Data
If cOriginalEntry <> "" Then
If CInt(cOriginalEntry) < Type Then
If Data.Contains("{" & ID.GetSplit(0, ";").GetSplit(0, "_") & "|") = False Then
cData &= Environment.NewLine & "{" & ID.GetSplit(0, ";").GetSplit(0, "_") & "|" & 0 & "}"
End If
End If
End If
If ForceChange = True OrElse cEntry < Type Then
Return cData.Replace("{" & ID & "|" & cEntry & "}", "{" & ID & "|" & Type & "}")
Else
Return cData
End If
Else
Dim cData As String = Data
If cData <> "" Then
cData &= Environment.NewLine
End If
If ID.Contains("_") Then
If Pokemon.GetPokemonByID(CInt(ID.GetSplit(0, "_"))).DexForms.Contains(ID.GetSplit(1, "_")) Then
If cData.Contains("{" & ID.GetSplit(0, "_") & "|") = False Then
cData &= "{" & ID.GetSplit(0, "_") & "|" & 0 & "}" & Environment.NewLine
End If
End If
End If
If ID.Contains(";") Then
If cData.Contains("{" & ID.GetSplit(0, ";") & "|") = False Then
cData &= "{" & ID.GetSplit(0, ";") & "|" & 0 & "}" & Environment.NewLine
End If
End If
cData &= "{" & ID & "|" & Type & "}"
Return cData
End If
End If
Return Data
End Function
Public Shared Function NewPokedex() As String
Dim Data As String = ""
Dim IDs As New List(Of String)
For Each file As String In System.IO.Directory.GetFiles(GameController.GamePath & "\" & GameModeManager.ActiveGameMode.ContentPath & "Pokemon\Data\", "*.dat")
Dim id As String = file.Remove(file.Length - 4, 4).Remove(0, CStr(GameController.GamePath & "\" & GameModeManager.ActiveGameMode.ContentPath & "Pokemon\Data\").Length)
If id.Contains("_") Then
While id.GetSplit(0, "_").Length < 3
id = 0 & id
End While
End If
IDs.Add(id)
Next
Dim formIDs As New List(Of String)
For Each id As String In IDs
If id.Contains("_") = False Then
Dim baseID As String = id.GetSplit(0, "_")
While baseID.StartsWith("0")
baseID = baseID.Remove(0, 1)
End While
Dim AdditionalDataForms As List(Of String) = PokemonForms.GetAdditionalDataForms(CInt(baseID))
If AdditionalDataForms IsNot Nothing Then
For i = 0 To AdditionalDataForms.Count - 1
formIDs.Add(baseID & ";" & AdditionalDataForms(i))
Next
End If
End If
Next
IDs.AddRange(formIDs)
PokemonCount = IDs.Count
PokemonIDs = (From id In IDs Order By CInt(id.GetSplit(0, "_").GetSplit(0, ";"))).ToList()
For i = 0 To PokemonCount - 1
Dim entry As String = PokemonIDs(i)
While entry.StartsWith("0")
entry = entry.Remove(0, 1)
End While
Data &= "{" & entry & "|0}"
If i <> PokemonCount - 1 Then
Data &= Environment.NewLine
End If
Next
Return Data
End Function
Public Shared Function GetLastSeen(ByVal Data As String) As Integer
Dim pData() As String = Data.Split(CChar(Environment.NewLine))
Dim lastSeen As Integer = 1
For Each Entry As String In pData
Entry = Entry.Remove(0, Entry.IndexOf("{") + 1)
Entry = Entry.Remove(Entry.Length - 1, 1)
Dim eID As Integer = CInt(Entry.GetSplit(0, "|"))
Dim eType As Integer = CInt(Entry.GetSplit(1, "|"))
If eType > 0 Then
lastSeen = eID
End If
Next
Return lastSeen
End Function
Public Shared Sub Load()
Core.Player.Pokedexes.Clear()
Dim path As String = GameModeManager.GetContentFilePath("Data\pokedex.dat")
Security.FileValidation.CheckFileValid(path, False, "Pokedex.vb")
Dim lines() As String = System.IO.File.ReadAllLines(path)
For Each PokedexData As String In lines
Core.Player.Pokedexes.Add(New Pokedex(PokedexData))
Next
End Sub
Public Shared Function RegisterPokemon(ByVal Data As String, ByVal Pokemon As Pokemon) As String
Dim dexID As String = PokemonForms.GetPokemonDataFileName(Pokemon.Number, Pokemon.AdditionalData)
If dexID.Contains("_") = False Then
If PokemonForms.GetAdditionalDataForms(Pokemon.Number) IsNot Nothing AndAlso PokemonForms.GetAdditionalDataForms(Pokemon.Number).Contains(Pokemon.AdditionalData) Then
dexID = Pokemon.Number & ";" & Pokemon.AdditionalData
Else
dexID = Pokemon.Number.ToString
End If
End If
If Pokemon.IsShiny = True Then
Return ChangeEntry(Data, dexID, 3)
Else
Return ChangeEntry(Data, dexID, 2)
End If
End Function
#End Region
#Region "PokedexHandler"
'The Pokedex screen changes the PokemonList array to add Pokémon not in the array, so this will get used to count things when focussing on the Pokémon in this dex.
Private _originalPokemonList As New Dictionary(Of Integer, String)
'Fields:
Public PokemonList As New Dictionary(Of Integer, String)
Public Name As String = ""
Public Activation As String = ""
Public OriginalCount As Integer = 0
Public IncludeExternalPokemon As Boolean = False 'for the pokedex screen, if true, this pokedex view will include all Pokémon seen/caught at the end.
Public Sub New(ByVal input As String)
Dim data() As String = input.Split(CChar("|"))
Me.Name = data(0)
Me.Activation = data(1)
Dim pokemonData() As String = data(2).Split(CChar(","))
Dim Place As Integer = 1
For Each l As String In pokemonData
l = l.Replace("[MAX]", PokemonMaxCount.ToString())
If l.Contains("-") = True AndAlso l.Contains("_") = False Then
Dim range() As String = l.Split(CChar("-"))
Dim min As Integer = CInt(range(0))
Dim max As Integer = CInt(range(1))
For j = min To max
PokemonList.Add(Place, j.ToString)
_originalPokemonList.Add(Place, j.ToString)
Place += 1
Next
Else
PokemonList.Add(Place, l)
_originalPokemonList.Add(Place, l)
Place += 1
End If
Next
If data.Length >= 4 Then
Me.IncludeExternalPokemon = CBool(data(3))
End If
Me.OriginalCount = Me.PokemonList.Count
End Sub
Dim TempPlaces As New Dictionary(Of String, Integer)
Public Function GetPlace(ByVal PokemonNumber As String) As Integer
If TempPlaces.ContainsKey(PokemonNumber) = True Then
Return TempPlaces(PokemonNumber)
End If
If PokemonList.ContainsValue(PokemonNumber) = True Then
For i = 0 To PokemonList.Values.Count - 1
If PokemonList.Values(i) = PokemonNumber Then
TempPlaces.Add(PokemonNumber, PokemonList.Keys(i))
Return PokemonList.Keys(i)
End If
Next
End If
Return -1
End Function
Public Function GetPokemonNumber(ByVal Place As Integer) As String
If PokemonList.ContainsKey(Place) = True Then
Return PokemonList(Place)
End If
Return "-1"
End Function
Public ReadOnly Property IsActivated() As Boolean
Get
If Me.Activation = "0" Then
Return True
Else
If ActionScript.IsRegistered(Me.Activation) = True Then
Return True
End If
End If
Return False
End Get
End Property
Public ReadOnly Property Obtained() As Integer
Get
Dim o As Integer = 0
For Each v As String In _originalPokemonList.Values
If GetEntryType(Core.Player.PokedexData, v) > 1 Then
o += 1
Else
If v.Contains("_") = False AndAlso v.Contains(";") = False Then
Dim Forms As List(Of String) = PokemonForms.GetCountForms(CInt(v))
Dim addCount As Boolean = False
If Forms IsNot Nothing Then
For f = 0 To Forms.Count - 1
If GetEntryType(Core.Player.PokedexData, Forms(f)) > 1 Then
addCount = True
End If
Next
End If
If addCount = True Then
o += 1
End If
End If
End If
Next
Return o
End Get
End Property
Public ReadOnly Property Seen() As Integer
Get
Dim o As Integer = 0
For Each v As String In _originalPokemonList.Values
If GetEntryType(Core.Player.PokedexData, v) = 1 Then
o += 1
Else
If v.Contains("_") = False AndAlso v.Contains(";") = False Then
Dim Forms As List(Of String) = PokemonForms.GetCountForms(CInt(v))
Dim addCount As Boolean = False
If Forms IsNot Nothing Then
For f = 0 To Forms.Count - 1
If GetEntryType(Core.Player.PokedexData, Forms(f)) = 1 Then
addCount = True
End If
Next
If addCount = True Then
o += 1
End If
End If
End If
End If
Next
Return o
End Get
End Property
Public Shared Function HasAnyForm(ID As Integer) As Integer
If GetEntryType(Core.Player.PokedexData, ID.ToString) > 0 Then
Return GetEntryType(Core.Player.PokedexData, ID.ToString)
Else
Dim p As Pokemon = Pokemon.GetPokemonByID(ID, "", True)
Dim EntryType As Integer = 0
If p.DexForms.Count > 0 AndAlso p.DexForms(0) <> " " Then
For i = 0 To p.DexForms.Count - 1
Dim pAD As String = PokemonForms.GetAdditionalValueFromDataFile(CStr(p.Number & "_" & p.DexForms(i)))
If pAD <> "" Then
If GetEntryType(Core.Player.PokedexData, CStr(p.Number & "_" & p.DexForms(i))) > 0 Then
Dim Forms As List(Of String) = PokemonForms.GetCountForms(CInt(p.Number))
If Forms IsNot Nothing Then
If Forms.Contains(CStr(p.Number & "_" & p.DexForms(i))) = True Then
If GetEntryType(Core.Player.PokedexData, CStr(p.Number & "_" & p.DexForms(i))) > EntryType Then
EntryType = GetEntryType(Core.Player.PokedexData, CStr(p.Number & "_" & p.DexForms(i)))
End If
Else
If 1 > EntryType Then
EntryType = 1
End If
End If
Else
If 1 > EntryType Then
EntryType = 1
End If
End If
End If
End If
Next
Else
Dim ADlist As List(Of String) = PokemonForms.GetAdditionalDataForms(p.Number)
If ADlist IsNot Nothing AndAlso ADlist.Count > 0 Then
For i = 0 To ADlist.Count - 1
If GetEntryType(Core.Player.PokedexData, CStr(p.Number & ";" & ADlist(i))) > 0 Then
Dim Forms As List(Of String) = PokemonForms.GetCountForms(CInt(p.Number))
If Forms IsNot Nothing Then
If Forms.Contains(CStr(p.Number & ";" & ADlist(i))) = True Then
If GetEntryType(Core.Player.PokedexData, CStr(p.Number & ";" & ADlist(i))) > EntryType Then
EntryType = GetEntryType(Core.Player.PokedexData, CStr(p.Number & ";" & ADlist(i)))
End If
Else
If 1 > EntryType Then
EntryType = 1
End If
End If
Else
If 1 > EntryType Then
EntryType = 1
End If
End If
End If
Next
End If
End If
Return EntryType
End If
End Function
Public ReadOnly Property Count() As Integer
Get
Return Me._originalPokemonList.Keys.Count
End Get
End Property
Public ReadOnly Property HasPokemon(ByVal pokemonNumber As String, ByVal originalList As Boolean) As Boolean
Get
If originalList = True Then
Return _originalPokemonList.ContainsValue(pokemonNumber)
Else
Return PokemonList.ContainsValue(pokemonNumber)
End If
End Get
End Property
#End Region
End Class