Pokédex Form Progress
This commit is contained in:
parent
0b69b854b9
commit
3065c1960a
|
@ -50,3 +50,4 @@ Move|34,283
|
||||||
EvolutionCondition|20,Level,20,Level
|
EvolutionCondition|20,Level,20,Level
|
||||||
Item|5,2051
|
Item|5,2051
|
||||||
TradeValue|10
|
TradeValue|10
|
||||||
|
DexForms|Alola
|
|
@ -53,3 +53,4 @@ Move|39,38
|
||||||
Move|44,283
|
Move|44,283
|
||||||
Item|5,2051
|
Item|5,2051
|
||||||
TradeValue|20
|
TradeValue|20
|
||||||
|
DexForms|Alola
|
|
@ -52,3 +52,4 @@ Move|50,364
|
||||||
EvolutionCondition|53,Level,28,Level
|
EvolutionCondition|53,Level,28,Level
|
||||||
Item|5,73
|
Item|5,73
|
||||||
TradeValue|15
|
TradeValue|15
|
||||||
|
DexForms|Alola
|
||||||
|
|
|
@ -56,3 +56,4 @@ Move|61,400
|
||||||
Move|65,364
|
Move|65,364
|
||||||
Item|5,73
|
Item|5,73
|
||||||
TradeValue|25
|
TradeValue|25
|
||||||
|
DexForms|Alola
|
||||||
|
|
|
@ -110,10 +110,10 @@
|
||||||
If Core.Player IsNot Nothing Then
|
If Core.Player IsNot Nothing Then
|
||||||
result = result.Replace("<playername>", Core.Player.Name)
|
result = result.Replace("<playername>", Core.Player.Name)
|
||||||
result = result.Replace("<rivalname>", Core.Player.RivalName)
|
result = result.Replace("<rivalname>", Core.Player.RivalName)
|
||||||
|
End If
|
||||||
If result.Contains("<") Then
|
If result.Contains("<") Then
|
||||||
result = CStr(ScriptVersion2.ScriptComparer.EvaluateConstruct(result))
|
result = CStr(ScriptVersion2.ScriptComparer.EvaluateConstruct(result))
|
||||||
End If
|
End If
|
||||||
End If
|
|
||||||
Return result
|
Return result
|
||||||
End If
|
End If
|
||||||
Else
|
Else
|
||||||
|
|
|
@ -1496,11 +1496,13 @@ Public Class Pokemon
|
||||||
If Value.Contains(",") = True Then
|
If Value.Contains(",") = True Then
|
||||||
Dim FormValue() As String = Value.Split(CChar(","))
|
Dim FormValue() As String = Value.Split(CChar(","))
|
||||||
For i = 0 To FormValue.Length - 1
|
For i = 0 To FormValue.Length - 1
|
||||||
Me.DexForms.Add(FormValue(i))
|
Me.DexForms.Add(FormValue(i).ToLower)
|
||||||
Next
|
Next
|
||||||
Else
|
Else
|
||||||
Me.DexForms.Add(Value)
|
Me.DexForms.Add(Value.ToLower)
|
||||||
End If
|
End If
|
||||||
|
Else
|
||||||
|
Me.DexForms.Add(" ".ToLower)
|
||||||
End If
|
End If
|
||||||
Case "canbreed"
|
Case "canbreed"
|
||||||
Me.CanBreed = CBool(Value)
|
Me.CanBreed = CBool(Value)
|
||||||
|
|
|
@ -1294,7 +1294,7 @@ Public Class PokedexViewScreen
|
||||||
Dim yOffset As Integer = 0
|
Dim yOffset As Integer = 0
|
||||||
Dim FrontView As Boolean = True
|
Dim FrontView As Boolean = True
|
||||||
|
|
||||||
Dim EvolutionLine As EvolutionLinePokemon = Nothing
|
Dim EvolutionLines As new List(Of EvolutionLinePokemon)
|
||||||
Dim minimumLevel As Integer = 0
|
Dim minimumLevel As Integer = 0
|
||||||
Dim maximumLevel As Integer = 0
|
Dim maximumLevel As Integer = 0
|
||||||
|
|
||||||
|
@ -1306,6 +1306,7 @@ Public Class PokedexViewScreen
|
||||||
Public PokemonID As String = "0"
|
Public PokemonID As String = "0"
|
||||||
Public PokemonAD As String = ""
|
Public PokemonAD As String = ""
|
||||||
Public Evolutions As New List(Of EvolutionLinePokemon)
|
Public Evolutions As New List(Of EvolutionLinePokemon)
|
||||||
|
Public Forms As New List(Of EvolutionLinePokemon)
|
||||||
Public Devolution As EvolutionLinePokemon = Nothing
|
Public Devolution As EvolutionLinePokemon = Nothing
|
||||||
Public Pokemon As Pokemon = Nothing
|
Public Pokemon As Pokemon = Nothing
|
||||||
|
|
||||||
|
@ -1338,12 +1339,39 @@ Public Class PokedexViewScreen
|
||||||
|
|
||||||
If Me.Pokemon.DexForms.Count > 0 Then
|
If Me.Pokemon.DexForms.Count > 0 Then
|
||||||
For Each form As String In Me.Pokemon.DexForms
|
For Each form As String In Me.Pokemon.DexForms
|
||||||
If form <> "" Then
|
|
||||||
|
Dim formAD As String = ""
|
||||||
|
If form <> " " Then
|
||||||
|
formAD = PokemonForms.GetAdditionalValueFromDataFile(Me.PokemonID.GetSplit(0, "_") & "_" & form)
|
||||||
|
End If
|
||||||
|
|
||||||
|
Dim formpokemon As Pokemon = Pokemon.GetPokemonByID(CInt(Me.PokemonID.GetSplit(0, "_")), formAD)
|
||||||
|
If formpokemon.EvolutionConditions.Count > 0 Then
|
||||||
|
Dim evolutions As New List(Of String)
|
||||||
|
For Each ev As EvolutionCondition In formpokemon.EvolutionConditions
|
||||||
|
If evolutions.Contains(ev.Evolution) = False And fromEvolution <> ev.Evolution Then
|
||||||
|
evolutions.Add(ev.Evolution)
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
|
||||||
|
For Each ev As String In evolutions
|
||||||
If vS.maximumLevel < Me.Level + 1 Then
|
If vS.maximumLevel < Me.Level + 1 Then
|
||||||
vS.maximumLevel = Me.Level + 1
|
vS.maximumLevel = Me.Level + 1
|
||||||
End If
|
End If
|
||||||
Me.Evolutions.Add(New EvolutionLinePokemon(Me.Level + 1, CStr(Me.Pokemon.Number & "_" & form), vS, ""))
|
Me.Evolutions.Add(New EvolutionLinePokemon(Me.Level + 1, ev, vS, ""))
|
||||||
|
Next
|
||||||
End If
|
End If
|
||||||
|
|
||||||
|
If vS.maximumLevel < Me.Level + 1 Then
|
||||||
|
vS.maximumLevel = Me.Level + 1
|
||||||
|
End If
|
||||||
|
Dim formID As String = Me.Pokemon.Number.ToString
|
||||||
|
If form <> " " Then
|
||||||
|
formID &= "_" & form
|
||||||
|
End If
|
||||||
|
|
||||||
|
Me.Forms.Add(New EvolutionLinePokemon(Me.Level + 1, formID, vS, ""))
|
||||||
|
|
||||||
Next
|
Next
|
||||||
End If
|
End If
|
||||||
End Sub
|
End Sub
|
||||||
|
@ -1386,9 +1414,6 @@ Public Class PokedexViewScreen
|
||||||
|
|
||||||
Private Sub FillEvolutionLine()
|
Private Sub FillEvolutionLine()
|
||||||
Dim evoID As String = Me.Pokemon.Number.ToString
|
Dim evoID As String = Me.Pokemon.Number.ToString
|
||||||
If Me.Pokemon.AdditionalData <> "" Then
|
|
||||||
evoID = PokemonForms.GetPokemonDataFileName(Me.Pokemon.Number, Me.Pokemon.AdditionalData)
|
|
||||||
End If
|
|
||||||
Dim p As New EvolutionLinePokemon(0, evoID, Me, "")
|
Dim p As New EvolutionLinePokemon(0, evoID, Me, "")
|
||||||
|
|
||||||
If CInt(p.Pokemon.Devolution.GetSplit(0, "_")) > 0 Then
|
If CInt(p.Pokemon.Devolution.GetSplit(0, "_")) > 0 Then
|
||||||
|
@ -1425,7 +1450,50 @@ Public Class PokedexViewScreen
|
||||||
|
|
||||||
Logger.Debug("Minimum level: " & minimumLevel & "; maximum level: " & maximumLevel)
|
Logger.Debug("Minimum level: " & minimumLevel & "; maximum level: " & maximumLevel)
|
||||||
|
|
||||||
Me.EvolutionLine = p
|
Me.EvolutionLines.Add(p)
|
||||||
|
If p.Forms.Count > 0 Then
|
||||||
|
For Each formp As EvolutionLinePokemon In p.Forms
|
||||||
|
Dim formEvoID As String = formp.Pokemon.Number.ToString
|
||||||
|
If formp.Pokemon.AdditionalData <> "" Then
|
||||||
|
formEvoID = PokemonForms.GetPokemonDataFileName(formp.Pokemon.Number, formp.Pokemon.AdditionalData)
|
||||||
|
End If
|
||||||
|
If CInt(formp.Pokemon.Devolution.GetSplit(0, "_")) > 0 Then
|
||||||
|
Dim devoID As String = formp.Pokemon.Devolution
|
||||||
|
Dim devoAD As String = ""
|
||||||
|
If devoID.Contains("_") Then
|
||||||
|
devoAD = PokemonForms.GetAdditionalValueFromDataFile(formp.Pokemon.Devolution)
|
||||||
|
End If
|
||||||
|
|
||||||
|
Dim devP As Pokemon = P3D.Pokemon.GetPokemonByID(CInt(devoID.GetSplit(0, "_")), devoAD)
|
||||||
|
Dim devR As EvolutionLinePokemon = Nothing
|
||||||
|
Dim level As Integer = -1
|
||||||
|
formp.Devolution = New EvolutionLinePokemon(level, devoID, Me, evoID)
|
||||||
|
Logger.Debug("Add devolution level 1: " & devP.Number)
|
||||||
|
|
||||||
|
devR = formp.Devolution
|
||||||
|
|
||||||
|
While CInt(devR.Pokemon.Devolution.GetSplit(0, "_")) > 0
|
||||||
|
devoID = devR.Pokemon.Devolution
|
||||||
|
devoAD = ""
|
||||||
|
If devR.Pokemon.AdditionalData <> "" Then
|
||||||
|
devoAD = PokemonForms.GetAdditionalValueFromDataFile(devR.Pokemon.Devolution)
|
||||||
|
End If
|
||||||
|
|
||||||
|
devP = P3D.Pokemon.GetPokemonByID(CInt(devoID.GetSplit(0, "_")), devoAD)
|
||||||
|
level -= 1
|
||||||
|
devR.Devolution = New EvolutionLinePokemon(level, devoID, Me, PokemonForms.GetPokemonDataFileName(devR.Pokemon.Number, devR.Pokemon.AdditionalData))
|
||||||
|
devR = devR.Devolution
|
||||||
|
Logger.Debug("Add devolution level " & (level * -1) & ": " & devP.Number)
|
||||||
|
End While
|
||||||
|
|
||||||
|
If minimumLevel > level Then
|
||||||
|
minimumLevel = level
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
Me.EvolutionLines.Add(formp)
|
||||||
|
Next
|
||||||
|
End If
|
||||||
|
Logger.Debug("Minimum level: " & minimumLevel & "; maximum level: " & maximumLevel)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub FillHabitats()
|
Private Sub FillHabitats()
|
||||||
|
@ -1630,7 +1698,7 @@ Public Class PokedexViewScreen
|
||||||
Dim scale As Single = 2.0F
|
Dim scale As Single = 2.0F
|
||||||
|
|
||||||
Private Sub DrawPage3()
|
Private Sub DrawPage3()
|
||||||
If EvolutionLine.Devolution Is Nothing And EvolutionLine.Evolutions.Count = 0 Then
|
If EvolutionLines.Count = 0 OrElse EvolutionLines.Count = 1 AndAlso EvolutionLines(0).Devolution Is Nothing AndAlso EvolutionLines(0).Evolutions.Count = 0 AndAlso EvolutionLines(0).Forms.Count = 0 Then
|
||||||
Canvas.DrawGradient(New Rectangle(CInt(Core.windowSize.Width / 2) - 282, CInt(Core.windowSize.Height / 2 - 45), 80, 90), New Color(84, 198, 216), New Color(42, 167, 198, 150), True, -1)
|
Canvas.DrawGradient(New Rectangle(CInt(Core.windowSize.Width / 2) - 282, CInt(Core.windowSize.Height / 2 - 45), 80, 90), New Color(84, 198, 216), New Color(42, 167, 198, 150), True, -1)
|
||||||
Canvas.DrawRectangle(New Rectangle(CInt(Core.windowSize.Width / 2) - 202, CInt(Core.windowSize.Height / 2 - 45), 404, 90), New Color(42, 167, 198, 150))
|
Canvas.DrawRectangle(New Rectangle(CInt(Core.windowSize.Width / 2) - 202, CInt(Core.windowSize.Height / 2 - 45), 404, 90), New Color(42, 167, 198, 150))
|
||||||
Canvas.DrawGradient(New Rectangle(CInt(Core.windowSize.Width / 2) + 202, CInt(Core.windowSize.Height / 2 - 45), 80, 90), New Color(42, 167, 198, 150), New Color(84, 198, 216), True, -1)
|
Canvas.DrawGradient(New Rectangle(CInt(Core.windowSize.Width / 2) + 202, CInt(Core.windowSize.Height / 2 - 45), 80, 90), New Color(42, 167, 198, 150), New Color(84, 198, 216), True, -1)
|
||||||
|
@ -1641,15 +1709,16 @@ Public Class PokedexViewScreen
|
||||||
Dim levels As New Dictionary(Of Integer, Integer)
|
Dim levels As New Dictionary(Of Integer, Integer)
|
||||||
|
|
||||||
For i = minimumLevel To maximumLevel
|
For i = minimumLevel To maximumLevel
|
||||||
levels.Add(i, 1)
|
levels.Add(i, 0)
|
||||||
Next
|
Next
|
||||||
|
|
||||||
If Not EvolutionLine.Devolution Is Nothing Then
|
For i = 0 To EvolutionLines.Count - 1
|
||||||
connections.Add("-1_0|" & EvolutionLine.Devolution.PokemonID.ToString() & "-" & EvolutionLine.PokemonID.ToString())
|
If Not EvolutionLines(i).Devolution Is Nothing Then
|
||||||
|
connections.Add("-1_0|" & EvolutionLines(i).Devolution.PokemonID.ToString() & "-" & EvolutionLines(i).PokemonID.ToString())
|
||||||
levels(-1) += 1
|
levels(-1) += 1
|
||||||
|
|
||||||
For Each evolution As EvolutionLinePokemon In EvolutionLine.Devolution.Evolutions
|
For Each evolution As EvolutionLinePokemon In EvolutionLines(i).Devolution.Evolutions
|
||||||
connections.Add("-1_0|" & EvolutionLine.Devolution.PokemonID.ToString() & "-" & evolution.PokemonID.ToString())
|
connections.Add("-1_0|" & EvolutionLines(i).Devolution.PokemonID.ToString() & "-" & evolution.PokemonID.ToString())
|
||||||
levels(0) += 1
|
levels(0) += 1
|
||||||
For Each eevolution As EvolutionLinePokemon In evolution.Evolutions
|
For Each eevolution As EvolutionLinePokemon In evolution.Evolutions
|
||||||
connections.Add("0_1|" & evolution.PokemonID.ToString() & "-" & eevolution.PokemonID.ToString())
|
connections.Add("0_1|" & evolution.PokemonID.ToString() & "-" & eevolution.PokemonID.ToString())
|
||||||
|
@ -1657,20 +1726,30 @@ Public Class PokedexViewScreen
|
||||||
Next
|
Next
|
||||||
Next
|
Next
|
||||||
|
|
||||||
If Not EvolutionLine.Devolution.Devolution Is Nothing Then
|
If Not EvolutionLines(i).Devolution.Devolution Is Nothing Then
|
||||||
connections.Add("-2_-1|" & EvolutionLine.Devolution.Devolution.PokemonID.ToString() & "-" & EvolutionLine.Devolution.PokemonID.ToString())
|
connections.Add("-2_-1|" & EvolutionLines(i).Devolution.Devolution.PokemonID.ToString() & "-" & EvolutionLines(i).Devolution.PokemonID.ToString())
|
||||||
levels(-2) += 1
|
levels(-2) += 1
|
||||||
End If
|
End If
|
||||||
|
Else
|
||||||
|
If i > 0 AndAlso levels(1) = i + 1 Then
|
||||||
|
levels(0) += 1
|
||||||
|
levels(1) -= 2
|
||||||
|
End If
|
||||||
End If
|
End If
|
||||||
|
|
||||||
For Each evolution As EvolutionLinePokemon In EvolutionLine.Evolutions
|
For Each evolution As EvolutionLinePokemon In EvolutionLines(i).Evolutions
|
||||||
connections.Add("0_1|" & EvolutionLine.PokemonID.ToString() & "-" & evolution.PokemonID.ToString())
|
connections.Add("0_1|" & EvolutionLines(i).PokemonID.ToString() & "-" & evolution.PokemonID.ToString())
|
||||||
levels(1) += 1
|
levels(1) += 1
|
||||||
For Each eevolution As EvolutionLinePokemon In evolution.Evolutions
|
For Each eevolution As EvolutionLinePokemon In evolution.Evolutions
|
||||||
connections.Add("1_2|" & evolution.PokemonID.ToString() & "-" & eevolution.PokemonID.ToString())
|
connections.Add("1_2|" & evolution.PokemonID.ToString() & "-" & eevolution.PokemonID.ToString())
|
||||||
levels(2) += 1
|
levels(2) += 1
|
||||||
Next
|
Next
|
||||||
Next
|
Next
|
||||||
|
If EvolutionLines(i).Evolutions.Count = 0 AndAlso EvolutionLines(i).Devolution Is Nothing Then
|
||||||
|
connections.Add("0_0|" & EvolutionLines(i).PokemonID.ToString() & "-" & EvolutionLines(i).PokemonID.ToString())
|
||||||
|
levels(0) += 1
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
|
||||||
Dim levelDraws As New Dictionary(Of Integer, Integer)
|
Dim levelDraws As New Dictionary(Of Integer, Integer)
|
||||||
Dim PokemonDraws As New Dictionary(Of String, Integer)
|
Dim PokemonDraws As New Dictionary(Of String, Integer)
|
||||||
|
@ -1681,7 +1760,7 @@ Public Class PokedexViewScreen
|
||||||
Dim mv As Vector2 = Core.GetMiddlePosition(New Size(CInt(64 * scale), CInt(64 * scale)))
|
Dim mv As Vector2 = Core.GetMiddlePosition(New Size(CInt(64 * scale), CInt(64 * scale)))
|
||||||
|
|
||||||
Dim p1 As String = c.Remove(c.IndexOf("-"))
|
Dim p1 As String = c.Remove(c.IndexOf("-"))
|
||||||
Dim level1 As Integer = CInt(connections(i).Split(CChar("|"))(0).Split(CChar("_"))(0))
|
Dim level1 As Integer = CInt(connections(i).GetSplit(0, "|").GetSplit(0, "_"))
|
||||||
Dim level1Count As Integer = levels(level1)
|
Dim level1Count As Integer = levels(level1)
|
||||||
Dim p1ad As String = ""
|
Dim p1ad As String = ""
|
||||||
If p1.Contains("_") = True Then
|
If p1.Contains("_") = True Then
|
||||||
|
@ -1701,7 +1780,7 @@ Public Class PokedexViewScreen
|
||||||
Dim level1Offset As Integer = CInt(GetOffset(level1Count, PokemonDraws(p1)) * (64 * scale))
|
Dim level1Offset As Integer = CInt(GetOffset(level1Count, PokemonDraws(p1)) * (64 * scale))
|
||||||
|
|
||||||
Dim p2 As String = c.Remove(0, c.IndexOf("-") + 1)
|
Dim p2 As String = c.Remove(0, c.IndexOf("-") + 1)
|
||||||
Dim level2 As Integer = CInt(connections(i).Split(CChar("|"))(0).Split(CChar("_"))(1))
|
Dim level2 As Integer = CInt(connections(i).GetSplit(0, "|").Split(CChar("_"))(1))
|
||||||
Dim level2Count As Integer = levels(level2)
|
Dim level2Count As Integer = levels(level2)
|
||||||
Dim p2ad As String = ""
|
Dim p2ad As String = ""
|
||||||
If p2.Contains("_") = True Then
|
If p2.Contains("_") = True Then
|
||||||
|
@ -1720,7 +1799,11 @@ Public Class PokedexViewScreen
|
||||||
|
|
||||||
Dim level2Offset As Integer = CInt(GetOffset(level2Count, PokemonDraws(p2)) * (64 * scale))
|
Dim level2Offset As Integer = CInt(GetOffset(level2Count, PokemonDraws(p2)) * (64 * scale))
|
||||||
|
|
||||||
|
If level1 <> level2 Then
|
||||||
|
If pokemon2.Devolution = PokemonForms.GetPokemonDataFileName(pokemon1.Number, pokemon1.AdditionalData) Then
|
||||||
Canvas.DrawLine(Color.Black, New Vector2(mv.X + (level1 * (128 * scale)) + (scale * 32), mv.Y + (scale * 32) + level1Offset), New Vector2(mv.X + (level2 * (128 * scale)) + (scale * 32), mv.Y + (scale * 32) + level2Offset), 2)
|
Canvas.DrawLine(Color.Black, New Vector2(mv.X + (level1 * (128 * scale)) + (scale * 32), mv.Y + (scale * 32) + level1Offset), New Vector2(mv.X + (level2 * (128 * scale)) + (scale * 32), mv.Y + (scale * 32) + level2Offset), 2)
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
|
||||||
Dim dexID1 As String = PokemonForms.GetPokemonDataFileName(pokemon1.Number, pokemon1.AdditionalData)
|
Dim dexID1 As String = PokemonForms.GetPokemonDataFileName(pokemon1.Number, pokemon1.AdditionalData)
|
||||||
If dexID1.Contains("_") = False Then
|
If dexID1.Contains("_") = False Then
|
||||||
|
|
Loading…
Reference in New Issue