P3D-Legacy/P3D/Screens/Pokedex/PokedexScreen.vb

1795 lines
81 KiB
VB.net

Public Class PokedexSelectScreen
Inherits Screen
Dim texture As Texture2D
Dim Profiles As New List(Of PokedexProfile)
Dim Cursor As Integer = 0
Public Sub New(ByVal currentScreen As Screen)
Me.Identification = Identifications.PokedexScreen
Me.PreScreen = currentScreen
Me.texture = TextureManager.GetTexture("GUI\Menus\General")
Me.MouseVisible = True
Me.CanMuteMusic = True
Me.CanBePaused = True
For Each p As Pokedex In Core.Player.Pokedexes
If p.IsActivated = True Then
Me.Profiles.Add(New PokedexProfile With {.Pokedex = p, .Obtained = p.Obtained, .Seen = p.Seen})
End If
Next
Me.AchievePokedexEmblems()
End Sub
Private Sub AchievePokedexEmblems()
' Eevee:
Dim eevee() As Integer = {134, 135, 136, 196, 197, 470, 471, 700}
Dim hasEevee As Boolean = True
For Each e As Integer In eevee
If Pokedex.GetEntryType(Core.Player.PokedexData, e) < 2 Then
hasEevee = False
Exit For
End If
Next
If hasEevee = True Then
GameJolt.Emblem.AchieveEmblem("eevee")
End If
' Pokédex:
If Core.Player.IsGameJoltSave = True Then
If Me.Profiles(0).Pokedex.Obtained >= Me.Profiles(0).Pokedex.Count Then
GameJolt.Emblem.AchieveEmblem("pokedex")
End If
End If
End Sub
Structure PokedexProfile
Dim Obtained As Integer
Dim Seen As Integer
Dim Pokedex As Pokedex
End Structure
Public Overrides Sub Draw()
Canvas.DrawRectangle(Core.windowSize, New Color(84, 198, 216))
For y = -64 To Core.windowSize.Height Step 64
Core.SpriteBatch.Draw(Me.texture, New Rectangle(Core.windowSize.Width - 128, y + PokedexScreen.TileOffset, 128, 64), New Rectangle(48, 0, 16, 16), Color.White)
Next
Canvas.DrawGradient(New Rectangle(0, 0, CInt(Core.windowSize.Width), 200), New Color(42, 167, 198), New Color(42, 167, 198, 0), False, -1)
Canvas.DrawGradient(New Rectangle(0, CInt(Core.windowSize.Height - 200), CInt(Core.windowSize.Width), 200), New Color(42, 167, 198, 0), New Color(42, 167, 198), False, -1)
Core.SpriteBatch.DrawString(FontManager.MainFont, "Select a Pokédex", New Vector2(100, 24), Color.White, 0.0F, Vector2.Zero, 2.0F, SpriteEffects.None, 0.0F)
For i = 0 To Me.Profiles.Count
If i = Me.Profiles.Count Then
Core.SpriteBatch.Draw(Me.texture, New Rectangle(100, 100 + i * 96, 64, 64), New Rectangle(16, 16, 16, 16), Color.White)
Core.SpriteBatch.Draw(Me.texture, New Rectangle(100 + 64, 100 + i * 96, 64 * 5, 64), New Rectangle(32, 16, 16, 16), Color.White)
Core.SpriteBatch.Draw(Me.texture, New Rectangle(100 + 64 * 6, 100 + i * 96, 64, 64), New Rectangle(16, 16, 16, 16), Color.White, 0.0F, Vector2.Zero, SpriteEffects.FlipHorizontally, 0.0F)
Core.SpriteBatch.DrawString(FontManager.MainFont, "Habitat-Dex", New Vector2(120, 116 + i * 96), Color.Black, 0.0F, Vector2.Zero, 1.25F, SpriteEffects.None, 0.0F)
Else
Dim p As Pokedex = Me.Profiles(i).Pokedex
Core.SpriteBatch.Draw(Me.texture, New Rectangle(100, 100 + i * 96, 64, 64), New Rectangle(16, 16, 16, 16), Color.White)
Core.SpriteBatch.Draw(Me.texture, New Rectangle(100 + 64, 100 + i * 96, 64 * 5, 64), New Rectangle(32, 16, 16, 16), Color.White)
Core.SpriteBatch.Draw(Me.texture, New Rectangle(100 + 64 * 6, 100 + i * 96, 64, 64), New Rectangle(16, 16, 16, 16), Color.White, 0.0F, Vector2.Zero, SpriteEffects.FlipHorizontally, 0.0F)
Core.SpriteBatch.DrawString(FontManager.MainFont, p.Name, New Vector2(120, 116 + i * 96), Color.Black, 0.0F, Vector2.Zero, 1.25F, SpriteEffects.None, 0.0F)
Core.SpriteBatch.DrawString(FontManager.MainFont, Me.Profiles(i).Obtained.ToString(), New Vector2(460, 116 + i * 96), Color.Black, 0.0F, Vector2.Zero, 1.25F, SpriteEffects.None, 0.0F)
If Me.Profiles(i).Obtained >= Me.Profiles(i).Pokedex.Count Then
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\pokedexhabitat", New Rectangle(160, 160, 10, 10), ""), New Rectangle(430, 122 + i * 96, 20, 20), Color.White)
Else
If Me.Profiles(i).Seen + Me.Profiles(i).Obtained >= Me.Profiles(i).Pokedex.Count Then
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\pokedexhabitat", New Rectangle(160, 170, 10, 10), ""), New Rectangle(430, 122 + i * 96, 20, 20), Color.White)
End If
End If
End If
Next
DrawCursor()
End Sub
Private Sub DrawCursor()
Dim cPosition As Vector2 = New Vector2(380, 100 + Me.Cursor * 96 - 42)
Dim t As Texture2D = TextureManager.GetTexture("GUI\Menus\General", New Rectangle(0, 0, 16, 16), "")
Core.SpriteBatch.Draw(t, New Rectangle(CInt(cPosition.X), CInt(cPosition.Y), 64, 64), Color.White)
End Sub
Public Overrides Sub Update()
If Controls.Up(True, True, True, True, True, True) = True Then
Me.Cursor -= 1
If Controls.ShiftDown() = True Then
Me.Cursor -= 4
End If
End If
If Controls.Down(True, True, True, True, True, True) = True Then
Me.Cursor += 1
If Controls.ShiftDown() = True Then
Me.Cursor += 4
End If
End If
Me.Cursor = Me.Cursor.Clamp(0, Me.Profiles.Count)
If Controls.Accept(True, False, False) = True Then
For i = 0 To Me.Profiles.Count
If New Rectangle(100, 100 + i * 96, 64 * 7, 64).Contains(MouseHandler.MousePosition) = True Then
If i = Cursor Then
If Me.Cursor = Me.Profiles.Count Then
Core.SetScreen(New PokedexHabitatScreen(Me))
Else
Core.SetScreen(New PokedexScreen(Me, Me.Profiles(Me.Cursor), Nothing))
End If
Else
Cursor = i
End If
End If
Next
End If
If Controls.Accept(False, True, True) = True Then
If Me.Cursor = Me.Profiles.Count Then
Core.SetScreen(New PokedexHabitatScreen(Me))
Else
Core.SetScreen(New PokedexScreen(Me, Me.Profiles(Me.Cursor), Nothing))
End If
End If
If Controls.Dismiss(True, True, True) = True Then
Core.SetScreen(New TransitionScreen(Core.CurrentScreen, Me.PreScreen, Color.White, False))
End If
PokedexScreen.TileOffset += 1
If PokedexScreen.TileOffset >= 64 Then
PokedexScreen.TileOffset = 0
End If
End Sub
End Class
Public Class PokedexHabitatScreen
Inherits Screen
Dim texture As Texture2D
Dim HabitatList As New List(Of PokedexScreen.Habitat)
Dim Cursor As Integer = 0
Dim Scroll As Integer = 0
Public Sub New(ByVal currentScreen As Screen)
Me.Identification = Identifications.PokedexHabitatScreen
Me.PreScreen = currentScreen
Me.texture = TextureManager.GetTexture("GUI\Menus\General")
Me.MouseVisible = True
Me.CanMuteMusic = True
Me.CanBePaused = True
For Each file As String In System.IO.Directory.GetFiles(GameController.GamePath & GameModeManager.ActiveGameMode.PokeFilePath, "*.*", IO.SearchOption.AllDirectories)
If file.EndsWith(".poke") = True Then
Dim fileName As String = file.Remove(0, (GameController.GamePath & GameModeManager.ActiveGameMode.PokeFilePath & "\").Length - 1)
Dim newHabitat As New PokedexScreen.Habitat(file)
Dim exists As Boolean = False
For Each h As PokedexScreen.Habitat In Me.HabitatList
If h.Name.ToLower() = newHabitat.Name.ToLower() Then
exists = True
h.Merge(newHabitat)
Exit For
End If
Next
If exists = False AndAlso Core.Player.PokeFiles.Contains(fileName) = True Then
HabitatList.Add(New PokedexScreen.Habitat(file))
End If
End If
Next
Me.HabitatList = (From h As PokedexScreen.Habitat In Me.HabitatList Order By h.Name Ascending).ToList()
End Sub
Public Overrides Sub Draw()
Canvas.DrawRectangle(Core.windowSize, New Color(84, 198, 216))
For y = -64 To Core.windowSize.Height Step 64
Core.SpriteBatch.Draw(Me.texture, New Rectangle(Core.windowSize.Width - 128, y + PokedexScreen.TileOffset, 128, 64), New Rectangle(48, 0, 16, 16), Color.White)
Next
Canvas.DrawGradient(New Rectangle(0, 0, CInt(Core.windowSize.Width), 200), New Color(42, 167, 198), New Color(42, 167, 198, 0), False, -1)
Canvas.DrawGradient(New Rectangle(0, CInt(Core.windowSize.Height - 200), CInt(Core.windowSize.Width), 200), New Color(42, 167, 198, 0), New Color(42, 167, 198), False, -1)
Core.SpriteBatch.DrawString(FontManager.MainFont, "Select a Habitat", New Vector2(100, 24), Color.White, 0.0F, Vector2.Zero, 2.0F, SpriteEffects.None, 0.0F)
For i = Scroll To Scroll + 5
If i <= Me.HabitatList.Count - 1 Then
Dim p As Integer = i - Scroll
Core.SpriteBatch.Draw(Me.texture, New Rectangle(100, 100 + p * 96, 64, 64), New Rectangle(16, 16, 16, 16), Color.White)
Core.SpriteBatch.Draw(Me.texture, New Rectangle(100 + 64, 100 + p * 96, 64 * 8, 64), New Rectangle(32, 16, 16, 16), Color.White)
Core.SpriteBatch.Draw(Me.texture, New Rectangle(100 + 64 * 9, 100 + p * 96, 64, 64), New Rectangle(16, 16, 16, 16), Color.White, 0.0F, Vector2.Zero, SpriteEffects.FlipHorizontally, 0.0F)
Core.SpriteBatch.Draw(HabitatList(i).Texture, New Rectangle(120, 108 + p * 96, 64, 48), Color.White)
Core.SpriteBatch.DrawString(FontManager.MainFont, HabitatList(i).Name, New Vector2(200, 116 + p * 96), Color.Black, 0.0F, Vector2.Zero, 1.25F, SpriteEffects.None, 0.0F)
Dim t As String = HabitatList(i).PokemonCaught.ToString() & "/" & HabitatList(i).PokemonList.Count
Core.SpriteBatch.DrawString(FontManager.MainFont, t, New Vector2(680 - CSng((FontManager.MainFont.MeasureString(t).X * 1.25F) / 2.0F), 116 + p * 96), Color.Black, 0.0F, Vector2.Zero, 1.25F, SpriteEffects.None, 0.0F)
Dim progressTexture As Texture2D = Me.HabitatList(i).ProgressTexture
If Not progressTexture Is Nothing Then
Core.SpriteBatch.Draw(progressTexture, New Rectangle(CInt(650 - CSng((FontManager.MainFont.MeasureString(t).X * 1.25F) / 2.0F)), 121 + p * 96, 20, 20), Color.White)
End If
End If
Next
DrawCursor()
End Sub
Private Sub DrawCursor()
Dim cPosition As Vector2 = New Vector2(520, 100 + Me.Cursor * 96 - 42)
Dim t As Texture2D = TextureManager.GetTexture("GUI\Menus\General", New Rectangle(0, 0, 16, 16), "")
Core.SpriteBatch.Draw(t, New Rectangle(CInt(cPosition.X), CInt(cPosition.Y), 64, 64), Color.White)
End Sub
Public Overrides Sub Update()
If Controls.Down(True, True, True, True, True, True) = True Then
Me.Cursor += 1
If Controls.ShiftDown() = True Then
Me.Cursor += 4
End If
End If
If Controls.Up(True, True, True, True, True, True) = True Then
Me.Cursor -= 1
If Controls.ShiftDown() = True Then
Me.Cursor -= 4
End If
End If
While Me.Cursor > 5
Me.Cursor -= 1
Me.Scroll += 1
End While
While Me.Cursor < 0
Me.Cursor += 1
Me.Scroll -= 1
End While
If Me.HabitatList.Count < 7 Then
Me.Scroll = 0
Else
Me.Scroll = Me.Scroll.Clamp(0, Me.HabitatList.Count - 6)
End If
If Me.HabitatList.Count < 6 Then
Me.Cursor = Me.Cursor.Clamp(0, Me.HabitatList.Count - 1)
Else
Me.Cursor = Me.Cursor.Clamp(0, 5)
End If
If Me.HabitatList.Count > 0 Then
If Controls.Accept(True, False, False) = True Then
For i = Scroll To Scroll + 5
If i <= Me.HabitatList.Count - 1 Then
If New Rectangle(100, 100 + (i - Scroll) * 96, 640, 64).Contains(MouseHandler.MousePosition) = True Then
If i = Cursor + Scroll Then
Core.SetScreen(New PokedexScreen(Me, Nothing, Me.HabitatList(Cursor + Scroll)))
Else
Cursor = i - Scroll
End If
End If
End If
Next
End If
If Controls.Accept(False, True, True) = True Then
Core.SetScreen(New PokedexScreen(Me, Nothing, Me.HabitatList(Cursor + Scroll)))
End If
End If
If Controls.Dismiss(True, True, True) = True Then
Core.SetScreen(Me.PreScreen)
End If
PokedexScreen.TileOffset += 1
If PokedexScreen.TileOffset >= 64 Then
PokedexScreen.TileOffset = 0
End If
End Sub
End Class
Public Class PokedexScreen
Inherits Screen
Public Shared TileOffset As Integer = 0
Public Enum OrderType
Numeric
Weigth
Height
Alphabetically
End Enum
Public Enum FilterType
Type1
Type2
Name
End Enum
Structure Filter
Public FilterType As FilterType
Public FilterValue As String
End Structure
Dim texture As Texture2D
Public ReverseOrder As Boolean = False
Public Order As OrderType = OrderType.Numeric
Public Filters As New List(Of Filter)
Public Profile As PokedexSelectScreen.PokedexProfile
Public CHabitat As Habitat = Nothing
Dim Scroll As Integer = 0
Dim Cursor As New Vector2(0)
Shared TempPokemonStorage As New Dictionary(Of Integer, Pokemon)
Shared TempPokemonDexType As New Dictionary(Of Integer, Integer)
Dim PokemonList As New List(Of Pokemon)
Dim menu As SelectMenu
Public Sub New(ByVal currentScreen As Screen, ByVal Profile As PokedexSelectScreen.PokedexProfile, ByVal Habitat As Habitat)
Me.Identification = Identifications.PokedexScreen
Me.PreScreen = currentScreen
Me.texture = TextureManager.GetTexture("GUI\Menus\General")
Me.Profile = Profile
Me.CHabitat = Habitat
Me.MouseVisible = True
Me.CanMuteMusic = True
Me.CanBePaused = True
TempPokemonStorage.Clear()
TempPokemonDexType.Clear()
SetList()
Me.menu = New SelectMenu({""}.ToList(), 0, Nothing, 0)
Me.menu.Visible = False
End Sub
Private Sub SetList()
PokemonList.Clear()
TempPokemonStorage.Clear()
TempPokemonDexType.Clear()
Dim neededEntryType As Integer = 0
Select Case Me.Order
Case OrderType.Alphabetically
neededEntryType = 1
Case OrderType.Height, OrderType.Weigth
neededEntryType = 2
End Select
For Each f As Filter In Me.Filters
Dim thisType As Integer = 0
If f.FilterType = FilterType.Name Then
thisType = 1
Else
thisType = 2
End If
If thisType > neededEntryType Then
neededEntryType = thisType
End If
Next
Dim pokeSearchList As New List(Of Integer)
If CHabitat Is Nothing Then
' Add any external Pokémon if specified to do so:
If Profile.Pokedex.IncludeExternalPokemon = True Then
For i = 1 To Pokedex.POKEMONCOUNT
If Me.Profile.Pokedex.HasPokemon(i, False) = False Then
If Pokedex.GetEntryType(Core.Player.PokedexData, i) > 0 Then
Profile.Pokedex.PokemonList.Add(Profile.Pokedex.PokemonList.Count + 1, i)
End If
End If
Next
End If
For Each i As Integer In Profile.Pokedex.PokemonList.Values
pokeSearchList.Add(i)
Next
Else
For Each i As Integer In CHabitat.PokemonList
pokeSearchList.Add(i)
Next
End If
For i = 0 To pokeSearchList.Count - 1
If Pokemon.PokemonDataExists(pokeSearchList(i)) = True Then
Dim p As Pokemon = Pokemon.GetPokemonByID(pokeSearchList(i))
If Pokedex.GetEntryType(Core.Player.PokedexData, p.Number) >= neededEntryType Then
Dim valid As Boolean = True
For Each F As Filter In Me.Filters
Select Case F.FilterType
Case FilterType.Name
If p.GetName().ToUpper().StartsWith(F.FilterValue.ToUpper()) = False Then
valid = False
Exit For
End If
Case FilterType.Type1
If p.Type1.Type <> New Element(F.FilterValue).Type Then
valid = False
Exit For
End If
Case FilterType.Type2
If p.Type2.Type <> New Element(F.FilterValue).Type Then
valid = False
Exit For
End If
End Select
Next
If valid = True Then
Me.PokemonList.Add(p)
End If
End If
End If
Next
Select Case Me.Order
Case OrderType.Numeric
If CHabitat Is Nothing Then
If Me.ReverseOrder = True Then
Me.PokemonList = (From p As Pokemon In Me.PokemonList Order By Profile.Pokedex.GetPlace(p.Number) Descending).ToList()
Else
Me.PokemonList = (From p As Pokemon In Me.PokemonList Order By Profile.Pokedex.GetPlace(p.Number) Ascending).ToList()
End If
Else
If Me.ReverseOrder = True Then
Me.PokemonList = (From p As Pokemon In Me.PokemonList Order By p.Number Descending).ToList()
Else
Me.PokemonList = (From p As Pokemon In Me.PokemonList Order By p.Number Ascending).ToList()
End If
End If
Case OrderType.Alphabetically
If Me.ReverseOrder = True Then
Me.PokemonList = (From p As Pokemon In Me.PokemonList Order By p.GetName() Descending).ToList()
Else
Me.PokemonList = (From p As Pokemon In Me.PokemonList Order By p.GetName() Ascending).ToList()
End If
Case OrderType.Weigth
If Me.ReverseOrder = True Then
Me.PokemonList = (From p As Pokemon In Me.PokemonList Order By p.PokedexEntry.Weight Descending).ToList()
Else
Me.PokemonList = (From p As Pokemon In Me.PokemonList Order By p.PokedexEntry.Weight Ascending).ToList()
End If
Case OrderType.Height
If Me.ReverseOrder = True Then
Me.PokemonList = (From p As Pokemon In Me.PokemonList Order By p.PokedexEntry.Height Descending).ToList()
Else
Me.PokemonList = (From p As Pokemon In Me.PokemonList Order By p.PokedexEntry.Height Ascending).ToList()
End If
End Select
Me.ClampCursor()
End Sub
Public Overrides Sub Draw()
Canvas.DrawRectangle(Core.windowSize, New Color(84, 198, 216))
For y = -64 To Core.windowSize.Height Step 64
Core.SpriteBatch.Draw(Me.texture, New Rectangle(Core.windowSize.Width - 128, y + TileOffset, 128, 64), New Rectangle(48, 0, 16, 16), Color.White)
Next
Canvas.DrawGradient(New Rectangle(0, 0, CInt(Core.windowSize.Width), 200), New Color(42, 167, 198), New Color(42, 167, 198, 0), False, -1)
Canvas.DrawGradient(New Rectangle(0, CInt(Core.windowSize.Height - 200), CInt(Core.windowSize.Width), 200), New Color(42, 167, 198, 0), New Color(42, 167, 198), False, -1)
Canvas.DrawRectangle(New Rectangle(50, 30, 564, 90), New Color(42, 167, 198, 150))
If CHabitat Is Nothing Then
Core.SpriteBatch.DrawString(FontManager.MainFont, Profile.Pokedex.Name, New Vector2(60, 55), Color.White, 0.0F, Vector2.Zero, 1.5F, SpriteEffects.None, 0.0F)
Core.SpriteBatch.DrawString(FontManager.MainFont, "Seen: " & Environment.NewLine & Environment.NewLine & "Obtained: ", New Vector2(420, 45), Color.White)
Core.SpriteBatch.DrawString(FontManager.MainFont, Profile.Seen + Profile.Obtained & Environment.NewLine & Environment.NewLine & Profile.Obtained, New Vector2(540, 45), Color.Black)
Else
Core.SpriteBatch.DrawString(FontManager.MainFont, CHabitat.Name, New Vector2(60, 80), Color.White, 0.0F, Vector2.Zero, 1.5F, SpriteEffects.None, 0.0F)
Core.SpriteBatch.Draw(CHabitat.Texture, New Rectangle(60, 32, 64, 48), Color.White)
Core.SpriteBatch.DrawString(FontManager.MainFont, "Available: " & Environment.NewLine & Environment.NewLine & "Obtained: ", New Vector2(420, 45), Color.White)
Core.SpriteBatch.DrawString(FontManager.MainFont, CHabitat.PokemonList.Count & Environment.NewLine & Environment.NewLine & CHabitat.PokemonCaught, New Vector2(540, 45), Color.Black)
Dim progressTexture As Texture2D = Me.CHabitat.ProgressTexture
If Not progressTexture Is Nothing Then
Core.SpriteBatch.Draw(progressTexture, New Rectangle(134, 46, 20, 20), Color.White)
End If
End If
If PokemonList.Count > 0 Then
For x = 0 To 5
For y = 0 To 4
Dim id As Integer = (y + Scroll) * 6 + x
If id <= Me.PokemonList.Count - 1 Then
If Not CHabitat Is Nothing OrElse Me.Profile.Pokedex.OriginalCount >= Profile.Pokedex.GetPlace(Me.PokemonList(id).Number) Then
Canvas.DrawRectangle(New Rectangle(50 + x * 100, 140 + y * 100, 64, 92), New Color(42, 167, 198, 150))
Else
Canvas.DrawBorder(3, New Rectangle(50 + x * 100, 140 + y * 100, 64, 92), New Color(42, 167, 198, 150))
End If
Dim p As Pokemon = Nothing
Dim entryType As Integer = 0
If TempPokemonStorage.ContainsKey(id + 1) = False Then
TempPokemonStorage.Add(id + 1, Me.PokemonList(id))
TempPokemonDexType.Add(id + 1, Pokedex.GetEntryType(Core.Player.PokedexData, Me.PokemonList(id).Number))
End If
p = TempPokemonStorage(id + 1)
entryType = TempPokemonDexType(id + 1)
If Cursor = New Vector2(x, y) Then
DrawPokemonPreview(p)
End If
Dim c As Color = Color.Gray
If entryType > 0 Then
If entryType > 1 Then
c = Color.White
End If
Dim pokeTexture = p.GetMenuTexture()
Core.SpriteBatch.Draw(pokeTexture, New Rectangle(50 + x * 100, 140 + y * 100, pokeTexture.Width * 2, 64), c)
End If
Dim no As String = "000"
If CHabitat Is Nothing Then
no = Profile.Pokedex.GetPlace(p.Number).ToString()
Else
no = p.Number.ToString()
End If
While no.Length < 3
no = "0" & no
End While
Core.SpriteBatch.DrawString(FontManager.MainFont, no, New Vector2(50 + x * 100 + CInt(32 - FontManager.MainFont.MeasureString(no).X / 2), 206 + y * 100), Color.White)
End If
Next
Next
Else
Canvas.DrawGradient(New Rectangle(50, 300, 80, 90), New Color(84, 198, 216), New Color(42, 167, 198, 150), True, -1)
Canvas.DrawRectangle(New Rectangle(130, 300, 404, 90), New Color(42, 167, 198, 150))
Canvas.DrawGradient(New Rectangle(534, 300, 80, 90), New Color(42, 167, 198, 150), New Color(84, 198, 216), True, -1)
Core.SpriteBatch.DrawString(FontManager.MainFont, "No search results.", New Vector2(50 + CInt(564 / 2) - CInt(FontManager.MainFont.MeasureString("No search results.").X / 2), 330), Color.White)
End If
Canvas.DrawRectangle(New Rectangle(670, 30, 400, 90), New Color(42, 167, 198, 150))
Dim orderText As String = "Numeric"
Select Case Me.Order
Case OrderType.Alphabetically
orderText = "A-Z"
Case OrderType.Height
orderText = "Height"
Case OrderType.Weigth
orderText = "Weight"
End Select
Dim filterText As String = "None"
If Filters.Count > 0 Then
filterText = ""
For Each f As Filter In Me.Filters
If filterText <> "" Then
filterText &= ", "
End If
Select Case f.FilterType
Case FilterType.Name
filterText &= "Name"
Case FilterType.Type1
filterText &= "Type 1"
Case FilterType.Type2
filterText &= "Type 2"
End Select
Next
End If
Core.SpriteBatch.DrawString(FontManager.MainFont, "Order:" & Environment.NewLine & "Filter:" & Environment.NewLine & "Press Q on the keyboard to search.", New Vector2(685, 45), Color.White)
Core.SpriteBatch.DrawString(FontManager.MainFont, orderText & Environment.NewLine & filterText, New Vector2(790, 45), Color.Black)
If menu.Visible = True Then
menu.Draw()
Else
If PokemonList.Count > 0 Then
DrawCursor()
End If
End If
End Sub
Private Function GetPlace(ByVal PokemonNumber As Integer) As Integer
For i = 0 To PokemonList.Count - 1
If PokemonList(i).Number = PokemonNumber Then
Return i + 1
End If
Next
Return -1
End Function
Private Sub DrawPokemonPreview(ByVal p As Pokemon)
Dim entryType As Integer = Pokedex.GetEntryType(Core.Player.PokedexData, p.Number)
For i = 0 To 4
Canvas.DrawGradient(New Rectangle(650, 300 + i * 40, 50, 2), New Color(255, 255, 255, 10), New Color(255, 255, 255, 255), True, -1)
Canvas.DrawRectangle(New Rectangle(700, 300 + i * 40, 350, 2), Color.White)
Canvas.DrawGradient(New Rectangle(1050, 300 + i * 40, 50, 2), New Color(255, 255, 255, 255), New Color(255, 255, 255, 10), True, -1)
Next
Dim no As String = "000"
If CHabitat Is Nothing Then
no = Profile.Pokedex.GetPlace(p.Number).ToString()
Else
no = p.Number.ToString()
End If
While no.Length < 3
no = "0" & no
End While
If entryType = 0 Then
Core.SpriteBatch.DrawString(FontManager.MainFont, "???" & Environment.NewLine & Environment.NewLine & "No. " & no, New Vector2(830, 200), Color.White)
Else
Core.SpriteBatch.DrawString(FontManager.MainFont, p.GetName() & Environment.NewLine & Environment.NewLine & "No. " & no, New Vector2(830, 200), Color.White)
Core.SpriteBatch.Draw(p.GetTexture(True), New Rectangle(670, 140, 128, 128), Color.White)
Core.SpriteBatch.DrawString(FontManager.MainFont, "SPECIES", New Vector2(680, 310), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MainFont, "TYPE", New Vector2(680, 350), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MainFont, "HEIGHT", New Vector2(680, 390), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MainFont, "WEIGHT", New Vector2(680, 430), Color.Black)
Canvas.DrawRectangle(New Rectangle(670, 480, 400, 152), New Color(42, 167, 198, 150))
If Not CHabitat Is Nothing Then
Dim encounterTypes As New List(Of Integer)
For Each ec As PokedexScreen.Habitat.EncounterPokemon In CHabitat.ObtainTypeList
If ec.PokemonID = p.Number Then
If encounterTypes.Contains(ec.EncounterType) = False Then
encounterTypes.Add(ec.EncounterType)
End If
End If
Next
For i = 0 To encounterTypes.Count - 1
Dim encounterType As Integer = encounterTypes(i)
Core.SpriteBatch.Draw(PokedexScreen.Habitat.GetEncounterTypeImage(encounterType), New Rectangle(824 + i * 32, 266, 32, 32), Color.White)
Next
End If
If entryType > 1 Then
Core.SpriteBatch.DrawString(FontManager.MainFont, p.PokedexEntry.Species, New Vector2(850, 310), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MainFont, "", New Vector2(850, 350), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MainFont, p.PokedexEntry.Height & " m", New Vector2(850, 390), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MainFont, p.PokedexEntry.Weight & " kg", New Vector2(850, 430), Color.Black)
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\Types"), New Rectangle(850, 356, 48, 16), p.Type1.GetElementImage(), Color.White)
If p.Type2.Type <> Element.Types.Blank Then
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\Types"), New Rectangle(900, 356, 48, 16), p.Type2.GetElementImage(), Color.White)
End If
Core.SpriteBatch.DrawString(FontManager.MainFont, p.PokedexEntry.Text.CropStringToWidth(FontManager.MainFont, 380), New Vector2(680, 490), Color.Black)
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\pokedexhabitat", New Rectangle(160, 160, 10, 10), ""), New Rectangle(915, 242, 20, 20), Color.White)
Else
Core.SpriteBatch.DrawString(FontManager.MainFont, "??? Pokémon", New Vector2(850, 310), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MainFont, "???", New Vector2(850, 350), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MainFont, "??? m", New Vector2(850, 390), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MainFont, "??? kg", New Vector2(850, 430), Color.Black)
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\pokedexhabitat", New Rectangle(160, 170, 10, 10), ""), New Rectangle(915, 242, 20, 20), Color.White)
End If
End If
End Sub
Private Sub DrawCursor()
Dim cPosition As Vector2 = New Vector2(50 + Me.Cursor.X * 100 + 42, 140 + Me.Cursor.Y * 100 - 42)
Dim t As Texture2D = TextureManager.GetTexture("GUI\Menus\General", New Rectangle(0, 0, 16, 16), "")
Core.SpriteBatch.Draw(t, New Rectangle(CInt(cPosition.X), CInt(cPosition.Y), 64, 64), Color.White)
End Sub
Public Overrides Sub Update()
If menu.Visible = True Then
menu.Update()
Else
If Controls.Left(True, True, False, True, True, True) = True Then
Me.Cursor.X -= 1
End If
If Controls.Right(True, True, False, True, True, True) = True Then
Me.Cursor.X += 1
End If
If Controls.Up(True, True, True, True, True, True) = True Then
Me.Cursor.Y -= 1
If Controls.ShiftDown() = True Then
Me.Cursor.Y -= 4
End If
End If
If Controls.Down(True, True, True, True, True, True) = True Then
Me.Cursor.Y += 1
If Controls.ShiftDown() = True Then
Me.Cursor.Y += 4
End If
End If
If Cursor.X > 5 Then
Cursor.X = 0
Cursor.Y += 1
End If
If Cursor.X < 0 Then
Cursor.X = 5
Cursor.Y -= 1
End If
While Cursor.Y < 0
Me.Cursor.Y += 1
Me.Scroll -= 1
End While
While Cursor.Y > 4
Me.Cursor.Y -= 1
Me.Scroll += 1
End While
If Controls.Accept(True, False, False) = True Then
For i = 0 To 29
Dim x As Integer = i
Dim y As Integer = 0
While x > 5
x -= 6
y += 1
End While
If New Rectangle(50 + x * 100, 140 + y * 100, 64, 92).Contains(MouseHandler.MousePosition) = True Then
If Cursor.X + Cursor.Y * 6 = i Then
If TempPokemonDexType(CInt((Cursor.Y + Scroll) * 6 + Cursor.X + 1)) > 0 Then
Core.SetScreen(New PokedexViewScreen(Me, TempPokemonStorage(CInt((Cursor.Y + Scroll) * 6 + Cursor.X + 1)), False))
End If
Else
Cursor.X = x
Cursor.Y = y
End If
End If
Next
End If
ClampCursor()
If Controls.Accept(False, True, True) = True Then
If TempPokemonDexType(CInt((Cursor.Y + Scroll) * 6 + Cursor.X + 1)) > 0 Then
Core.SetScreen(New PokedexViewScreen(Me, TempPokemonStorage(CInt((Cursor.Y + Scroll) * 6 + Cursor.X + 1)), False))
End If
End If
If KeyBoardHandler.KeyPressed(KeyBindings.SpecialKey) = True Or ControllerHandler.ButtonPressed(Buttons.Y) = True Then
Me.menu = New SelectMenu({"Order", "Filter", "Reset", "Back"}.ToList(), 0, AddressOf SelectMenu1, 3)
End If
If Controls.Dismiss(True, True, True) = True Then
If Me.Filters.Count > 0 Or Me.Order <> OrderType.Numeric Or Me.ReverseOrder = True Then
Me.Filters.Clear()
Me.ReverseOrder = False
Me.Order = OrderType.Numeric
Me.SetList()
Else
Core.SetScreen(Me.PreScreen)
End If
End If
End If
TileOffset += 1
If TileOffset >= 64 Then
TileOffset = 0
End If
End Sub
Private Sub ClampCursor()
Dim linesCount As Integer = CInt(Math.Ceiling(Me.PokemonList.Count / 6))
If linesCount < 6 Then
Me.Scroll = 0
Else
Me.Scroll = Me.Scroll.Clamp(0, linesCount - 5)
End If
Dim maxY As Integer = linesCount - Scroll - 1
Me.Cursor.Y = Me.Cursor.Y.Clamp(0, maxY)
If Me.Cursor.Y = maxY Then
Dim maxX As Integer = Me.PokemonList.Count
While maxX > 6
maxX -= 6
End While
Me.Cursor.X = Me.Cursor.X.Clamp(0, maxX - 1)
End If
End Sub
Public Overrides Sub ChangeTo()
TempPokemonDexType.Clear()
TempPokemonStorage.Clear()
End Sub
#Region "Menus"
Private Sub SelectMenu1(ByVal s As SelectMenu)
Select Case s.SelectedItem.ToLower()
Case "order"
Me.menu = New SelectMenu({"Type", "Reverse: " & Me.ReverseOrder.ToString(), "Back"}.ToList(), 0, AddressOf SelectMenuOrder, 2)
Case "filter"
Me.menu = New SelectMenu({"Name", "Type1", "Type2", "Clear", "Back"}.ToList(), 0, AddressOf SelectMenuFilter, 4)
Case "reset"
Me.Filters.Clear()
Me.ReverseOrder = False
Me.Order = OrderType.Numeric
Me.SetList()
End Select
End Sub
Private Sub SelectMenuFilter(ByVal s As SelectMenu)
Select Case s.SelectedItem.ToLower()
Case "name"
Me.menu = New SelectMenu({"A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "Back"}.ToList(), 0, AddressOf SelectMenuNameFilter, -1)
Case "type1"
Me.menu = New SelectMenu({"Normal", "Fire", "Fighting", "Water", "Flying", "Grass", "Poison", "Electric", "Ground", "Psychic", "Rock", "Ice", "Bug", "Dragon", "Ghost", "Dark", "Steel", "Fairy", "Blank", "Back"}.ToList(), 0, AddressOf SelectMenuType1Filter, -1)
Case "type2"
Me.menu = New SelectMenu({"Normal", "Fire", "Fighting", "Water", "Flying", "Grass", "Poison", "Electric", "Ground", "Psychic", "Rock", "Ice", "Bug", "Dragon", "Ghost", "Dark", "Steel", "Fairy", "Blank", "Back"}.ToList(), 0, AddressOf SelectMenuType2Filter, -1)
Case "clear"
Me.Filters.Clear()
Me.SetList()
Case "back"
Me.menu = New SelectMenu({"Order", "Filter", "Reset", "Back"}.ToList(), 0, AddressOf SelectMenu1, 3)
End Select
End Sub
Private Sub SelectMenuType1Filter(ByVal s As SelectMenu)
If s.SelectedItem <> "Back" Then
For i = 0 To Filters.Count - 1
If Filters(i).FilterType = FilterType.Type1 Then
Filters.RemoveAt(i)
Exit For
End If
Next
Filters.Add(New Filter With {.FilterType = FilterType.Type1, .FilterValue = s.SelectedItem})
SetList()
Else
Me.menu = New SelectMenu({"Name", "Type1", "Type2", "Clear", "Back"}.ToList(), 0, AddressOf SelectMenuFilter, 4)
End If
End Sub
Private Sub SelectMenuType2Filter(ByVal s As SelectMenu)
If s.SelectedItem <> "Back" Then
For i = 0 To Filters.Count - 1
If Filters(i).FilterType = FilterType.Type2 Then
Filters.RemoveAt(i)
Exit For
End If
Next
Filters.Add(New Filter With {.FilterType = FilterType.Type2, .FilterValue = s.SelectedItem})
SetList()
Else
Me.menu = New SelectMenu({"Name", "Type1", "Type2", "Clear", "Back"}.ToList(), 0, AddressOf SelectMenuFilter, 4)
End If
End Sub
Private Sub SelectMenuNameFilter(ByVal s As SelectMenu)
If s.SelectedItem <> "Back" Then
For i = 0 To Filters.Count - 1
If Filters(i).FilterType = FilterType.Name Then
Filters.RemoveAt(i)
Exit For
End If
Next
Filters.Add(New Filter With {.FilterType = FilterType.Name, .FilterValue = s.SelectedItem})
SetList()
Else
Me.menu = New SelectMenu({"Name", "Type1", "Type2", "Clear", "Back"}.ToList(), 0, AddressOf SelectMenuFilter, 4)
End If
End Sub
Private Sub SelectMenuOrder(ByVal s As SelectMenu)
Select Case s.SelectedItem.ToLower()
Case "type"
Me.menu = New SelectMenu({"Numeric", "A-Z", "Weight", "Height", "Back"}.ToList(), 0, AddressOf SelectMenuOrderType, 4)
Case "reverse: " & Me.ReverseOrder.ToString().ToLower()
Me.ReverseOrder = Not Me.ReverseOrder
Me.menu = New SelectMenu({"Type", "Reverse: " & Me.ReverseOrder.ToString(), "Back"}.ToList(), 0, AddressOf SelectMenuOrder, 2)
Me.SetList()
Case "back"
Me.menu = New SelectMenu({"Order", "Filter", "Reset", "Back"}.ToList(), 0, AddressOf SelectMenu1, 3)
End Select
End Sub
Private Sub SelectMenuOrderType(ByVal s As SelectMenu)
Select Case s.SelectedItem.ToLower()
Case "numeric"
Me.Order = OrderType.Numeric
Me.SetList()
Case "a-z"
Me.Order = OrderType.Alphabetically
Me.SetList()
Case "weight"
Me.Order = OrderType.Weigth
Me.SetList()
Case "height"
Me.Order = OrderType.Height
Me.SetList()
Case "back"
Me.menu = New SelectMenu({"Type", "Reverse: " & Me.ReverseOrder.ToString(), "Back"}.ToList(), 0, AddressOf SelectMenuOrder, 2)
End Select
End Sub
#End Region
Private Class SelectMenu
Dim Items As New List(Of String)
Dim Index As Integer = 0
Public Delegate Sub ClickEvent(ByVal s As SelectMenu)
Dim ClickHandler As ClickEvent = Nothing
Dim BackIndex As Integer = 0
Public Visible As Boolean = True
Public Scroll As Integer = 0
Dim t1 As Texture2D
Dim t2 As Texture2D
Public Sub New(ByVal Items As List(Of String), ByVal Index As Integer, ByVal ClickHandle As ClickEvent, ByVal BackIndex As Integer)
Me.Items = Items
Me.Index = Index
Me.ClickHandler = ClickHandle
Me.BackIndex = BackIndex
If Me.BackIndex < 0 Then
Me.BackIndex = Me.Items.Count + Me.BackIndex
End If
Me.Visible = True
t1 = TextureManager.GetTexture("GUI\Menus\General", New Rectangle(16, 16, 16, 16), "")
t2 = TextureManager.GetTexture("GUI\Menus\General", New Rectangle(32, 16, 16, 16), "")
End Sub
Public Sub Update()
If Visible = True Then
If Controls.Up(True, True, True, True, True, True) = True Then
Me.Index -= 1
End If
If Controls.Down(True, True, True, True, True, True) = True Then
Me.Index += 1
End If
Me.Index = Me.Index.Clamp(0, Me.Items.Count - 1)
For i = Scroll To Me.Scroll + 8
If i <= Me.Items.Count - 1 Then
If Controls.Accept(True, False, False) = True And i = Me.Index And New Rectangle(Core.windowSize.Width - 270, 66 * ((i + 1) - Scroll), 256, 64).Contains(MouseHandler.MousePosition) = True Or
Controls.Accept(False, True, True) = True And i = Me.Index Or Controls.Dismiss(True, True, True) = True And Me.BackIndex = Me.Index Then
If Not ClickHandler Is Nothing Then
ClickHandler(Me)
End If
Me.Visible = False
End If
If Controls.Dismiss(True, True, True) = True Then
Me.Index = Me.BackIndex
If Not ClickHandler Is Nothing Then
ClickHandler(Me)
End If
Me.Visible = False
End If
If New Rectangle(Core.windowSize.Width - 270, 66 * ((i + 1) - Scroll), 256, 64).Contains(MouseHandler.MousePosition) = True And Controls.Accept(True, False, False) = True Then
Me.Index = i
End If
End If
Next
If Index - Scroll > 8 Then
Scroll = Index - 8
End If
If Index - Scroll < 0 Then
Scroll = Index
End If
End If
End Sub
Public Sub Draw()
If Visible = True Then
For i = Scroll To Me.Scroll + 8
If i <= Me.Items.Count - 1 Then
Dim Text As String = Items(i)
Dim startPos As New Vector2(Core.windowSize.Width - 270, 66 * ((i + 1) - Scroll))
Core.SpriteBatch.Draw(t1, New Rectangle(CInt(startPos.X), CInt(startPos.Y), 64, 64), Color.White)
Core.SpriteBatch.Draw(t2, New Rectangle(CInt(startPos.X + 64), CInt(startPos.Y), 64, 64), Color.White)
Core.SpriteBatch.Draw(t2, New Rectangle(CInt(startPos.X + 128), CInt(startPos.Y), 64, 64), Color.White)
Core.SpriteBatch.Draw(t1, New Rectangle(CInt(startPos.X + 192), CInt(startPos.Y), 64, 64), Nothing, Color.White, 0.0F, New Vector2(0), SpriteEffects.FlipHorizontally, 0.0F)
Core.SpriteBatch.DrawString(FontManager.MainFont, Text, New Vector2(startPos.X + 128 - (FontManager.MainFont.MeasureString(Text).X * 1.4F) / 2, startPos.Y + 15), Color.Black, 0.0F, Vector2.Zero, 1.4F, SpriteEffects.None, 0.0F)
If Me.Index = i Then
Dim cPosition As Vector2 = New Vector2(startPos.X + 128, startPos.Y - 40)
Dim t As Texture2D = TextureManager.GetTexture("GUI\Menus\General", New Rectangle(0, 0, 16, 16), "")
Core.SpriteBatch.Draw(t, New Rectangle(CInt(cPosition.X), CInt(cPosition.Y), 64, 64), Color.White)
End If
End If
Next
End If
End Sub
Public ReadOnly Property SelectedItem() As String
Get
Return Items(Me.Index)
End Get
End Property
End Class
Public Class Habitat
Public Enum HabitatTypes As Integer
Grassland = 0
Forest = 1
WatersEdge = 2
Sea = 3
Cave = 4
Mountain = 5
RoughTerrain = 6
City = 7
End Enum
Public Structure EncounterPokemon
Public PokemonID As Integer
Public EncounterType As Integer
Public Daytimes() As Integer
End Structure
Dim MergeData() As String = {} ' Temporary data storage if needs to merge.
Public File As String = ""
Public Name As String = ""
Public HabitatType As HabitatTypes = HabitatTypes.Grassland
Public PokemonList As New List(Of Integer)
Public ObtainTypeList As New List(Of EncounterPokemon)
Public PokemonCaught As Integer = 0
Public PokemonSeen As Integer = 0
Public Sub New(ByVal file As String)
Security.FileValidation.CheckFileValid(file, False, "PokedexScreen.vb")
Dim data() As String = System.IO.File.ReadAllLines(file)
Me.MergeData = data
Me.File = file
For Each line As String In data
If line.ToLower().StartsWith("name=") = True Then
Me.Name = line.Remove(0, 5)
ElseIf line.ToLower().StartsWith("type=") = True Then
Dim arg As String = line.Remove(0, 5)
Select Case arg.ToLower()
Case "grassland"
Me.HabitatType = HabitatTypes.Grassland
Case "forest"
Me.HabitatType = HabitatTypes.Forest
Case "watersedge"
Me.HabitatType = HabitatTypes.WatersEdge
Case "sea"
Me.HabitatType = HabitatTypes.Sea
Case "cave"
Me.HabitatType = HabitatTypes.Cave
Case "mountain"
Me.HabitatType = HabitatTypes.Mountain
Case "roughterrain"
Me.HabitatType = HabitatTypes.RoughTerrain
Case "city"
Me.HabitatType = HabitatTypes.City
End Select
ElseIf line.StartsWith("{") = True And line.EndsWith("}") = True Then
Dim pokemonData() As String = line.Remove(line.Length - 1, 1).Remove(0, 1).Split(CChar("|"))
If Me.PokemonList.Contains(CInt(pokemonData(1))) = False Then
Me.PokemonList.Add(CInt(pokemonData(1)))
Dim entryType As Integer = Pokedex.GetEntryType(Core.Player.PokedexData, CInt(pokemonData(1)))
If entryType > 0 Then
Me.PokemonSeen += 1
End If
If entryType > 1 Then
Me.PokemonCaught += 1
End If
End If
Dim daytimesData As List(Of String) = pokemonData(3).Split(CChar(",")).ToList()
Dim dayTimes As New List(Of Integer)
For Each s As String In daytimesData
If StringHelper.IsNumeric(s) = True Then
Dim i As Integer = CInt(s)
If i > 0 Then
dayTimes.Add(i)
Else
dayTimes.Clear()
Exit For
End If
End If
Next
Me.ObtainTypeList.Add(New EncounterPokemon With {.PokemonID = CInt(pokemonData(1)), .EncounterType = CInt(pokemonData(0)), .Daytimes = dayTimes.ToArray()})
End If
Next
If Me.Name = "" Then
Me.Name = System.IO.Path.GetFileNameWithoutExtension(file)
Me.Name = Me.Name(0).ToString().ToUpper() & Me.Name.Remove(0, 1)
End If
End Sub
Public ReadOnly Property Texture() As Texture2D
Get
Dim x As Integer = CInt(Me.HabitatType)
Dim y As Integer = 0
While x > 1
x -= 2
y += 1
End While
Return TextureManager.GetTexture("GUI\Menus\pokedexhabitat", New Rectangle(x * 64, y * 48, 64, 48), "")
End Get
End Property
Public Shared Function GetEncounterTypeImage(ByVal encounterType As Integer) As Texture2D
Dim x As Integer = 0
Dim y As Integer = 4
Select Case encounterType
Case 0
x = 0
y = 3
Case 1
x = 0
y = 4
Case 2
x = 1
y = 0
Case 3
x = 0
y = 0
Case 31
x = 0
y = 1
Case 32
x = 0
y = 2
End Select
Return TextureManager.GetTexture("GUI\Menus\pokedexhabitat", New Rectangle(128 + x * 32, y * 32, 32, 32), "")
End Function
Public ReadOnly Property ProgressTexture() As Texture2D
Get
If Me.PokemonCaught >= Me.PokemonList.Count Then
Return TextureManager.GetTexture("GUI\Menus\pokedexhabitat", New Rectangle(160, 160, 10, 10), "")
Else
If Me.PokemonSeen >= Me.PokemonList.Count Then
Return TextureManager.GetTexture("GUI\Menus\pokedexhabitat", New Rectangle(160, 170, 10, 10), "")
End If
End If
Return Nothing
End Get
End Property
Public Sub Merge(ByVal h As Habitat)
Dim data() As String = h.MergeData
For Each line As String In data
If line.StartsWith("{") = True And line.EndsWith("}") = True Then
Dim pokemonData() As String = line.Remove(line.Length - 1, 1).Remove(0, 1).Split(CChar("|"))
If Me.PokemonList.Contains(CInt(pokemonData(1))) = False Then
Me.PokemonList.Add(CInt(pokemonData(1)))
Dim entryType As Integer = Pokedex.GetEntryType(Core.Player.PokedexData, CInt(pokemonData(1)))
If entryType > 0 Then
Me.PokemonSeen += 1
End If
If entryType > 1 Then
Me.PokemonCaught += 1
End If
End If
Me.ObtainTypeList.Add(New EncounterPokemon With {.PokemonID = CInt(pokemonData(1)), .EncounterType = CInt(pokemonData(0))})
End If
Next
End Sub
Public Function HasPokemon(ByVal pokemonNumber As Integer) As Boolean
Return Me.PokemonList.Contains(pokemonNumber)
End Function
End Class
End Class
Public Class PokedexViewScreen
Inherits Screen
Dim Pokemon As Pokemon
Dim texture As Texture2D
Dim Page As Integer = 0
Dim EntryType As Integer = 0
Dim _transitionOut As Boolean = False
Dim yOffset As Integer = 0
Dim FrontView As Boolean = True
Dim EvolutionLine As EvolutionLinePokemon = Nothing
Dim minimumLevel As Integer = 0
Dim maximumLevel As Integer = 0
Dim HabitatList As New List(Of PokedexScreen.Habitat)
Class EvolutionLinePokemon
Public Level As Integer = 0
Public PokemonID As Integer = 0
Public Evolutions As New List(Of EvolutionLinePokemon)
Public Devolution As EvolutionLinePokemon = Nothing
Public Pokemon As Pokemon = Nothing
Public Sub New(ByVal Level As Integer, ByVal pokemonID As Integer, ByVal vS As PokedexViewScreen, ByVal fromEvolution As Integer)
Me.Level = Level
Me.PokemonID = pokemonID
Me.Pokemon = Pokemon.GetPokemonByID(Me.PokemonID)
If Me.Pokemon.EvolutionConditions.Count > 0 Then
Dim evolutions As New List(Of Integer)
For Each ev As EvolutionCondition In Me.Pokemon.EvolutionConditions
If evolutions.Contains(ev.Evolution) = False And fromEvolution <> ev.Evolution Then
evolutions.Add(ev.Evolution)
End If
Next
For Each ev As Integer In evolutions
If vS.maximumLevel < Me.Level + 1 Then
vS.maximumLevel = Me.Level + 1
End If
Me.Evolutions.Add(New EvolutionLinePokemon(Me.Level + 1, ev, vS, -1))
Next
End If
End Sub
End Class
''' <summary>
''' Creates a new instance of this class.
''' </summary>
''' <param name="currentScreen">The screen that is currently active.</param>
''' <param name="Pokemon">The Pokémon to display.</param>
''' <param name="transitionOut">If the screen should fade out when closed.</param>
Public Sub New(ByVal currentScreen As Screen, ByVal Pokemon As Pokemon, ByVal transitionOut As Boolean)
Me.PreScreen = currentScreen
Me.Identification = Identifications.PokedexViewScreen
Me.texture = TextureManager.GetTexture("GUI\Menus\General")
Me.MouseVisible = True
Me.CanMuteMusic = True
Me.CanBePaused = True
Me._transitionOut = transitionOut
Me.Pokemon = Pokemon
Me.EntryType = Pokedex.GetEntryType(Core.Player.PokedexData, Me.Pokemon.Number)
Me.GetYOffset()
Me.FillEvolutionLine()
Me.FillHabitats()
End Sub
Private Sub FillEvolutionLine()
Dim p As New EvolutionLinePokemon(0, Me.Pokemon.Number, Me, -1)
If p.Pokemon.Devolution > 0 Then
Dim devP As Pokemon = P3D.Pokemon.GetPokemonByID(p.Pokemon.Devolution)
Dim devR As EvolutionLinePokemon = Nothing
Dim level As Integer = -1
p.Devolution = New EvolutionLinePokemon(level, devP.Number, Me, p.Pokemon.Number)
Logger.Debug("Add devolution level 1: " & devP.Number)
devR = p.Devolution
While devR.Pokemon.Devolution > 0
devP = P3D.Pokemon.GetPokemonByID(devR.Pokemon.Devolution)
level -= 1
devR.Devolution = New EvolutionLinePokemon(level, devP.Number, Me, devR.Pokemon.Number)
devR = devR.Devolution
Logger.Debug("Add devolution level " & (level * -1) & ": " & devP.Number)
End While
minimumLevel = level
End If
Logger.Debug("Minimum level: " & minimumLevel & "; maximum level: " & maximumLevel)
Me.EvolutionLine = p
End Sub
Private Sub FillHabitats()
For Each file As String In System.IO.Directory.GetFiles(GameController.GamePath & GameModeManager.ActiveGameMode.PokeFilePath, "*.*", IO.SearchOption.AllDirectories)
If file.EndsWith(".poke") = True Then
Dim fileName As String = file.Remove(0, (GameController.GamePath & GameModeManager.ActiveGameMode.PokeFilePath & "\").Length - 1)
Dim newHabitat As New PokedexScreen.Habitat(file)
Dim exists As Boolean = False
For Each h As PokedexScreen.Habitat In Me.HabitatList
If h.Name.ToLower() = newHabitat.Name.ToLower() Then
exists = True
h.Merge(newHabitat)
Exit For
End If
Next
If exists = False AndAlso Core.Player.PokeFiles.Contains(fileName) = True Then
HabitatList.Add(New PokedexScreen.Habitat(file))
End If
End If
Next
Me.HabitatList = (From h As PokedexScreen.Habitat In Me.HabitatList Order By h.Name Ascending).ToList()
For i = 0 To Me.HabitatList.Count - 1
If i <= Me.HabitatList.Count - 1 Then
If Me.HabitatList(i).HasPokemon(Me.Pokemon.Number) = False Then
Me.HabitatList.RemoveAt(i)
i -= 1
End If
End If
Next
End Sub
Private Sub GetYOffset()
Dim t As Texture2D = Pokemon.GetTexture(FrontView)
Me.yOffset = -1
Dim cArr(t.Width * t.Height - 1) As Color
t.GetData(cArr)
For y = 0 To t.Height - 1
For x = 0 To t.Width - 1
If cArr(x + y * t.Height) <> Color.Transparent Then
Me.yOffset = y
Exit For
End If
Next
If Me.yOffset <> -1 Then
Exit For
End If
Next
End Sub
Public Overrides Sub Draw()
Canvas.DrawRectangle(Core.windowSize, New Color(84, 198, 216))
For y = -64 To Core.windowSize.Height Step 64
Core.SpriteBatch.Draw(Me.texture, New Rectangle(Core.windowSize.Width - 128, y + PokedexScreen.TileOffset, 128, 64), New Rectangle(48, 0, 16, 16), Color.White)
Next
Canvas.DrawGradient(New Rectangle(0, 0, CInt(Core.windowSize.Width), 200), New Color(42, 167, 198), New Color(42, 167, 198, 0), False, -1)
Canvas.DrawGradient(New Rectangle(0, CInt(Core.windowSize.Height - 200), CInt(Core.windowSize.Width), 200), New Color(42, 167, 198, 0), New Color(42, 167, 198), False, -1)
Select Case Me.Page
Case 0
DrawPage1()
Case 1
DrawPage2()
Case 2
DrawPage3()
End Select
Core.SpriteBatch.Draw(Me.texture, New Rectangle(20, 20, 64, 64), New Rectangle(16, 16, 16, 16), Color.White)
Core.SpriteBatch.Draw(Me.texture, New Rectangle(20 + 64, 20, 64 * 8, 64), New Rectangle(32, 16, 16, 16), Color.White)
Core.SpriteBatch.Draw(Me.texture, New Rectangle(20 + 64 * 9, 20, 64, 64), New Rectangle(16, 16, 16, 16), Color.White, 0.0F, Vector2.Zero, SpriteEffects.FlipHorizontally, 0.0F)
Core.SpriteBatch.Draw(Me.texture, New Rectangle(20 + 64, 20, 64 * 5, 64), New Rectangle(32, 16, 16, 16), Color.White)
Core.SpriteBatch.Draw(Me.texture, New Rectangle(20 + 64 * 6, 20, 64, 64), New Rectangle(16, 16, 16, 16), Color.White, 0.0F, Vector2.Zero, SpriteEffects.FlipHorizontally, 0.0F)
Dim pokeTexture = Pokemon.GetMenuTexture()
Core.SpriteBatch.Draw(pokeTexture, New Rectangle(28, 20, pokeTexture.Width * 2, 64), Color.White)
Core.SpriteBatch.DrawString(FontManager.MainFont, Pokemon.GetName(), New Vector2(100, 36), Color.Black, 0.0F, Vector2.Zero, 1.25F, SpriteEffects.None, 0.0F)
If EntryType = 1 Then
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\pokedexhabitat", New Rectangle(160, 170, 10, 10), ""), New Rectangle(64 * 6 + 40, 42, 20, 20), Color.White)
ElseIf EntryType > 1 Then
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\pokedexhabitat", New Rectangle(160, 160, 10, 10), ""), New Rectangle(64 * 6 + 40, 42, 20, 20), Color.White)
End If
If Me.mLineLength = 100 Then
If Me.Page = 0 Or Me.Page = 1 Then
Core.SpriteBatch.Draw(Me.texture, New Rectangle(Core.windowSize.Width - 70, CInt(Core.windowSize.Height / 2 - 32), 64, 64), New Rectangle(0, 16, 16, 16), Color.White, 0.0F, Vector2.Zero, SpriteEffects.FlipHorizontally, 0.0F)
End If
If Me.Page = 1 Or Me.Page = 2 Then
Core.SpriteBatch.Draw(Me.texture, New Rectangle(6, CInt(Core.windowSize.Height / 2 - 32), 64, 64), New Rectangle(0, 16, 16, 16), Color.White)
End If
End If
Select Case Me.Page
Case 0
Core.SpriteBatch.DrawString(FontManager.MainFont, "Details", New Vector2(480, 36), Color.Black, 0.0F, Vector2.Zero, 1.25F, SpriteEffects.None, 0.0F)
Case 1
Core.SpriteBatch.DrawString(FontManager.MainFont, "Habitat", New Vector2(480, 36), Color.Black, 0.0F, Vector2.Zero, 1.25F, SpriteEffects.None, 0.0F)
Case 2
Core.SpriteBatch.DrawString(FontManager.MainFont, "Evolution", New Vector2(480, 36), Color.Black, 0.0F, Vector2.Zero, 1.25F, SpriteEffects.None, 0.0F)
End Select
End Sub
Dim fadeMainImage As Integer = 0
Dim vLineLength As Integer = 1
Dim mLineLength As Integer = 1
Dim playedCry As Boolean = False
Private Sub DrawPage1()
Dim v As Vector2 = Core.GetMiddlePosition(New Size(512, 512))
Core.SpriteBatch.Draw(Pokemon.GetTexture(Me.FrontView), New Rectangle(CInt(v.X), CInt(v.Y) - yOffset * 2, 512, 512), New Color(255, 255, 255, fadeMainImage))
If fadeMainImage = 255 Then
Dim mV As Vector2 = Core.GetMiddlePosition(New Size(0, 0))
Canvas.DrawLine(Color.Black, New Vector2(mV.X + 40, mV.Y - 40), New Vector2(mV.X + vLineLength, mV.Y - vLineLength), 2)
Canvas.DrawLine(Color.Black, New Vector2(mV.X + 40, mV.Y + 40), New Vector2(mV.X + vLineLength, mV.Y + vLineLength), 2)
Canvas.DrawLine(Color.Black, New Vector2(mV.X - 40, mV.Y - 40), New Vector2(mV.X - vLineLength, mV.Y - vLineLength), 2)
Canvas.DrawLine(Color.Black, New Vector2(mV.X - 40, mV.Y + 40), New Vector2(mV.X - vLineLength, mV.Y + vLineLength), 2)
If vLineLength = 140 Then
Canvas.DrawLine(Color.Black, New Vector2(mV.X + 140, mV.Y - 140), New Vector2(mV.X + (140 + mLineLength), mV.Y - 140), 2)
Canvas.DrawLine(Color.Black, New Vector2(mV.X + 139, mV.Y + 140), New Vector2(mV.X + (140 + mLineLength), mV.Y + 140), 2)
Canvas.DrawLine(Color.Black, New Vector2(mV.X - 139, mV.Y - 140), New Vector2(mV.X - (140 + mLineLength), mV.Y - 140), 2)
Canvas.DrawLine(Color.Black, New Vector2(mV.X - 139, mV.Y + 140), New Vector2(mV.X - (140 + mLineLength), mV.Y + 140), 2)
End If
If mLineLength = 100 Then
If EntryType > 1 Then
Core.SpriteBatch.DrawString(FontManager.MainFont, Pokemon.PokedexEntry.Height & " m", New Vector2(mV.X + 250, mV.Y - 152), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MainFont, Pokemon.PokedexEntry.Weight & " kg", New Vector2(mV.X + 250, mV.Y + 128), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MainFont, Pokemon.PokedexEntry.Species, New Vector2(mV.X - 248 - FontManager.MainFont.MeasureString(Pokemon.PokedexEntry.Species).X, mV.Y - 152), Color.Black)
If Pokemon.Type2.Type <> Element.Types.Blank Then
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\Types"), New Rectangle(CInt(mV.X - 450), CInt(mV.Y + 123), 96, 32), Pokemon.Type1.GetElementImage(), Color.White)
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\Types"), New Rectangle(CInt(mV.X - 350), CInt(mV.Y + 123), 96, 32), Pokemon.Type2.GetElementImage(), Color.White)
Else
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\Types"), New Rectangle(CInt(mV.X - 350), CInt(mV.Y + 123), 96, 32), Pokemon.Type1.GetElementImage(), Color.White)
End If
Else
Core.SpriteBatch.DrawString(FontManager.MainFont, "??? m", New Vector2(mV.X + 250, mV.Y - 152), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MainFont, "??? kg", New Vector2(mV.X + 250, mV.Y + 128), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MainFont, "??? Pokémon", New Vector2(mV.X - 248 - FontManager.MainFont.MeasureString("??? Pokémon").X, mV.Y - 152), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MainFont, "???", New Vector2(mV.X - 248 - FontManager.MainFont.MeasureString("???").X, mV.Y + 128), Color.Black)
End If
End If
End If
End Sub
Dim Scroll As Integer = 0
Dim Cursor As Integer = 0
Private Sub DrawPage2()
If Me.HabitatList.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.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)
Core.SpriteBatch.DrawString(FontManager.MainFont, "Area Unknown.", New Vector2(CInt(Core.windowSize.Width / 2) - CInt(FontManager.MainFont.MeasureString("Area Unknown.").X / 2), CInt(Core.windowSize.Height / 2 - 15)), Color.White)
Else
For i = Scroll To Scroll + 4
If i <= Me.HabitatList.Count - 1 Then
Dim p As Integer = i - Scroll
Core.SpriteBatch.Draw(Me.texture, New Rectangle(100, 160 + p * 96, 64, 64), New Rectangle(16, 16, 16, 16), Color.White)
Core.SpriteBatch.Draw(Me.texture, New Rectangle(100 + 64, 160 + p * 96, 64 * 9, 64), New Rectangle(32, 16, 16, 16), Color.White)
Core.SpriteBatch.Draw(Me.texture, New Rectangle(100 + 64 * 10, 160 + p * 96, 64, 64), New Rectangle(16, 16, 16, 16), Color.White, 0.0F, Vector2.Zero, SpriteEffects.FlipHorizontally, 0.0F)
Core.SpriteBatch.Draw(HabitatList(i).Texture, New Rectangle(120, 168 + p * 96, 64, 48), Color.White)
Core.SpriteBatch.DrawString(FontManager.MainFont, HabitatList(i).Name, New Vector2(200, 176 + p * 96), Color.Black, 0.0F, Vector2.Zero, 1.25F, SpriteEffects.None, 0.0F)
Dim encounterTypes As New List(Of Integer)
For j = 0 To HabitatList(i).ObtainTypeList.Count - 1
If HabitatList(i).ObtainTypeList(j).PokemonID = Me.Pokemon.Number And encounterTypes.Contains(HabitatList(i).ObtainTypeList(j).EncounterType) = False Then
encounterTypes.Add(HabitatList(i).ObtainTypeList(j).EncounterType)
End If
Next
For j = 0 To encounterTypes.Count - 1
Core.SpriteBatch.Draw(PokedexScreen.Habitat.GetEncounterTypeImage(encounterTypes(j)), New Rectangle(560 + j * 40, 176 + p * 96, 32, 32), Color.White)
Next
End If
Next
DrawCursor()
End If
End Sub
Private Sub DrawCursor()
Dim cPosition As Vector2 = New Vector2(520, 160 + Me.Cursor * 96 - 42)
Dim t As Texture2D = TextureManager.GetTexture("GUI\Menus\General", New Rectangle(0, 0, 16, 16), "")
Core.SpriteBatch.Draw(t, New Rectangle(CInt(cPosition.X), CInt(cPosition.Y), 64, 64), Color.White)
End Sub
Dim scale As Single = 2.0F
Private Sub DrawPage3()
If EvolutionLine.Devolution Is Nothing And EvolutionLine.Evolutions.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.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)
Core.SpriteBatch.DrawString(FontManager.MainFont, Pokemon.GetName() & " doesn't evolve.", New Vector2(CInt(Core.windowSize.Width / 2) - CInt(FontManager.MainFont.MeasureString(Pokemon.GetName() & " doesn't evolve.").X / 2), CInt(Core.windowSize.Height / 2 - 15)), Color.White)
Else
Dim connections As New List(Of String)
Dim levels As New Dictionary(Of Integer, Integer)
For i = minimumLevel To maximumLevel
levels.Add(i, 1)
Next
If Not EvolutionLine.Devolution Is Nothing Then
connections.Add("-1_0|" & EvolutionLine.Devolution.PokemonID.ToString() & "-" & EvolutionLine.PokemonID.ToString())
levels(-1) += 1
For Each evolution As EvolutionLinePokemon In EvolutionLine.Devolution.Evolutions
connections.Add("-1_0|" & EvolutionLine.Devolution.PokemonID.ToString() & "-" & evolution.PokemonID.ToString())
levels(0) += 1
For Each eevolution As EvolutionLinePokemon In evolution.Evolutions
connections.Add("0_1|" & evolution.PokemonID.ToString() & "-" & eevolution.PokemonID.ToString())
levels(1) += 1
Next
Next
If Not EvolutionLine.Devolution.Devolution Is Nothing Then
connections.Add("-2_-1|" & EvolutionLine.Devolution.Devolution.PokemonID.ToString() & "-" & EvolutionLine.Devolution.PokemonID.ToString())
levels(-2) += 1
End If
End If
For Each evolution As EvolutionLinePokemon In EvolutionLine.Evolutions
connections.Add("0_1|" & EvolutionLine.PokemonID.ToString() & "-" & evolution.PokemonID.ToString())
levels(1) += 1
For Each eevolution As EvolutionLinePokemon In evolution.Evolutions
connections.Add("1_2|" & evolution.PokemonID.ToString() & "-" & eevolution.PokemonID.ToString())
levels(2) += 1
Next
Next
Dim levelDraws As New Dictionary(Of Integer, Integer)
Dim PokemonDraws As New Dictionary(Of Integer, Integer)
For i = 0 To connections.Count - 1
Dim c As String = connections(i).Split(CChar("|"))(1)
Dim mv As Vector2 = Core.GetMiddlePosition(New Size(CInt(64 * scale), CInt(64 * scale)))
Dim p1 As Integer = CInt(c.Remove(c.IndexOf("-")))
Dim level1 As Integer = CInt(connections(i).Split(CChar("|"))(0).Split(CChar("_"))(0))
Dim level1Count As Integer = levels(level1)
Dim pokemon1 As Pokemon = Pokemon.GetPokemonByID(p1)
If levelDraws.ContainsKey(level1) = False Then
levelDraws.Add(level1, 0)
End If
If PokemonDraws.ContainsKey(p1) = False Then
levelDraws(level1) += 1
PokemonDraws.Add(p1, levelDraws(level1))
End If
Dim level1Offset As Integer = CInt(GetOffset(level1Count, PokemonDraws(p1)) * (64 * scale))
Dim p2 As Integer = CInt(c.Remove(0, c.IndexOf("-") + 1))
Dim level2 As Integer = CInt(connections(i).Split(CChar("|"))(0).Split(CChar("_"))(1))
Dim level2Count As Integer = levels(level2)
Dim pokemon2 As Pokemon = Pokemon.GetPokemonByID(p2)
If levelDraws.ContainsKey(level2) = False Then
levelDraws.Add(level2, 0)
End If
If PokemonDraws.ContainsKey(p2) = False Then
levelDraws(level2) += 1
PokemonDraws.Add(p2, levelDraws(level2))
End If
Dim level2Offset As Integer = CInt(GetOffset(level2Count, PokemonDraws(p2)) * (64 * scale))
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)
If Pokedex.GetEntryType(Core.Player.PokedexData, pokemon1.Number) = 0 Then
Dim pokeTexture = pokemon1.GetMenuTexture()
Core.SpriteBatch.Draw(pokeTexture, New Rectangle(CInt(mv.X + (level1 * (128 * scale))) - CInt((pokeTexture.Width - 32) * scale), CInt(mv.Y + level1Offset), CInt(pokeTexture.Width * 2 * scale), CInt(64 * scale)), Color.Black)
Else
Dim pokeTexture = pokemon1.GetMenuTexture()
Core.SpriteBatch.Draw(pokeTexture, New Rectangle(CInt(mv.X + (level1 * (128 * scale))) - CInt((pokeTexture.Width - 32) * scale), CInt(mv.Y + level1Offset), CInt(pokeTexture.Width * 2 * scale), CInt(64 * scale)), Color.White)
Core.SpriteBatch.DrawString(FontManager.MainFont, pokemon1.GetName(), New Vector2(CInt(mv.X + (level1 * (128 * scale))) + (32 * scale) - (FontManager.MainFont.MeasureString(pokemon1.GetName()).X / 2 * CSng(scale / 2)), CInt(mv.Y + level1Offset) + (58 * scale)), Color.Black, 0.0F, Vector2.Zero, CSng(scale / 2), SpriteEffects.None, 0.0F)
End If
If Pokedex.GetEntryType(Core.Player.PokedexData, pokemon2.Number) = 0 Then
Dim pokeTexture = pokemon2.GetMenuTexture()
Core.SpriteBatch.Draw(pokeTexture, New Rectangle(CInt(mv.X + (level2 * (128 * scale))) - CInt((pokeTexture.Width - 32) * scale), CInt(mv.Y + level2Offset), CInt(pokeTexture.Width * 2 * scale), CInt(64 * scale)), Color.Black)
Else
Dim pokeTexture = pokemon2.GetMenuTexture()
Core.SpriteBatch.Draw(pokeTexture, New Rectangle(CInt(mv.X + (level2 * (128 * scale))) - CInt((pokeTexture.Width - 32) * scale), CInt(mv.Y + level2Offset), CInt(pokeTexture.Width * 2 * scale), CInt(64 * scale)), Color.White)
Core.SpriteBatch.DrawString(FontManager.MainFont, pokemon2.GetName(), New Vector2(CInt(mv.X + (level2 * (128 * scale))) + (32 * scale) - (FontManager.MainFont.MeasureString(pokemon2.GetName()).X / 2 * CSng(scale / 2)), CInt(mv.Y + level2Offset) + (58 * scale)), Color.Black, 0.0F, Vector2.Zero, CSng(scale / 2), SpriteEffects.None, 0.0F)
End If
Next
End If
End Sub
Private Function GetOffset(ByVal count As Integer, ByVal c As Integer) As Double
If count = 0 Then
Return 0
End If
If count Mod 2 = 1 Then
' count = 7, c = 7
Dim middle As Integer = CInt(Math.Ceiling(count / 2))
' middle = 4
Dim stat As Integer = c - middle
' stat = 3
Return stat
Else
' count = 4, c = 1
Dim middle As Double = count / 2
' middle = 2
Dim stat As Double = c - middle - 0.5D
' stat = -1.5
Return stat
End If
End Function
Public Overrides Sub Update()
If Controls.Dismiss(True, True, True) = True Then
If Me._transitionOut = True Then
Core.SetScreen(New TransitionScreen(Me, Me.PreScreen, Color.White, False))
Else
Core.SetScreen(Me.PreScreen)
End If
End If
UpdateIntro()
If mLineLength = 100 Then
If Controls.Right(True, True, False, True, True, True) = True Then
Me.Page += 1
End If
If Controls.Left(True, True, False, True, True, True) = True Then
Me.Page -= 1
End If
If Controls.Accept(True, False, False) = True Then
If Me.Page = 0 Or Me.Page = 1 Then
If New Rectangle(Core.windowSize.Width - 70, CInt(Core.windowSize.Height / 2 - 32), 64, 64).Contains(MouseHandler.MousePosition) = True Then
Me.Page += 1
End If
End If
If Me.Page = 1 Or Me.Page = 2 Then
If New Rectangle(6, CInt(Core.windowSize.Height / 2 - 32), 64, 64).Contains(MouseHandler.MousePosition) = True Then
Me.Page -= 1
End If
End If
End If
Me.Page = Me.Page.Clamp(0, 2)
Select Case Me.Page
Case 0
UpdatePage1()
Case 1
UpdatePage2()
Case 2
UpdatePage3()
End Select
End If
PokedexScreen.TileOffset += 1
If PokedexScreen.TileOffset >= 64 Then
PokedexScreen.TileOffset = 0
End If
End Sub
Private Sub UpdateIntro()
If fadeMainImage < 255 Then
fadeMainImage += 10
If fadeMainImage >= 255 Then
fadeMainImage = 255
If playedCry = False Then
playedCry = True
SoundManager.PlayPokemonCry(Pokemon.Number)
End If
End If
Else
If vLineLength < 140 Then
vLineLength += 10
If vLineLength >= 140 Then
vLineLength = 140
End If
Else
If mLineLength < 100 Then
mLineLength += 10
If mLineLength >= 100 Then
mLineLength = 100
End If
End If
End If
End If
End Sub
Private Sub UpdatePage1()
If Controls.Accept(True, True, True) = True Then
Me.FrontView = Not Me.FrontView
Me.GetYOffset()
End If
End Sub
Private Sub UpdatePage2()
If Me.HabitatList.Count > 0 Then
If Controls.Down(True, True, True, True, True, True) = True Then
Me.Cursor += 1
End If
If Controls.Up(True, True, True, True, True, True) = True Then
Me.Cursor -= 1
End If
If Me.Cursor > 4 Then
Me.Cursor = 4
Me.Scroll += 1
End If
If Me.Cursor < 0 Then
Me.Cursor = 0
Me.Scroll -= 1
End If
If Me.HabitatList.Count < 6 Then
Me.Scroll = 0
Else
Me.Scroll = Me.Scroll.Clamp(0, Me.HabitatList.Count - 5)
End If
If Me.HabitatList.Count < 5 Then
Me.Cursor = Me.Cursor.Clamp(0, Me.HabitatList.Count - 1)
Else
Me.Cursor = Me.Cursor.Clamp(0, 4)
End If
If Controls.Accept(True, False, False) = True Then
For i = Scroll To Scroll + 4
If i <= Me.HabitatList.Count - 1 Then
If New Rectangle(100, 160 + (i - Scroll) * 96, 640, 64).Contains(MouseHandler.MousePosition) = True Then
If i = Cursor + Scroll Then
Core.SetScreen(New PokedexScreen(Me, Nothing, Me.HabitatList(Cursor + Scroll)))
Else
Cursor = i - Scroll
End If
End If
End If
Next
End If
If Controls.Accept(False, True, True) = True Then
Core.SetScreen(New PokedexScreen(Me, Nothing, Me.HabitatList(Cursor + Scroll)))
End If
End If
End Sub
Private Sub UpdatePage3()
If Controls.Up(True, False, True, False, False, False) = True Or KeyBoardHandler.KeyPressed(Keys.OemPlus) = True Then
Me.scale += 0.5F
End If
If Controls.Down(True, False, True, False, False, False) = True Or KeyBoardHandler.KeyPressed(Keys.OemMinus) = True Then
Me.scale -= 0.5F
End If
Me.scale = Me.scale.Clamp(0.5F, 4.0F)
End Sub
End Class