P3D-Legacy/P3D/Screens/Pokemon/HatchEggScreen.vb

136 lines
4.9 KiB
VB.net

Public Class HatchEggScreen
Inherits Screen
Dim Pokemons As New List(Of Pokemon)
Dim Backgroud As Texture2D
Dim Egg As Texture2D
Dim Stage As Integer = 0
Dim delay As Single = 4.0F
Dim size As Single = 0.0F
Dim CanRename As Boolean = True
Dim Message As String = ""
Dim cPokemon As Pokemon
Public Sub New(ByVal currentScreen As Screen, ByVal Pokemon As List(Of Pokemon), Optional CanRename As Boolean = True, Optional Message As String = "")
Me.PreScreen = currentScreen
PlayerStatistics.Track("Eggs hatched", 1)
Me.Identification = Identifications.HatchEggScreen
Me.Pokemons = Pokemon
Me.cPokemon = Me.Pokemons(0)
cPokemon.EggSteps = 0
Core.Player.Pokemons.Add(cPokemon)
Me.CanRename = CanRename
Me.Message = Message
Dim dexID As String = PokemonForms.GetPokemonDataFileName(cPokemon.Number, cPokemon.AdditionalData)
If dexID.Contains("_") = False Then
If PokemonForms.GetAdditionalDataForms(cPokemon.Number) IsNot Nothing AndAlso PokemonForms.GetAdditionalDataForms(cPokemon.Number).Contains(cPokemon.AdditionalData) Then
dexID = cPokemon.Number & ";" & cPokemon.AdditionalData
Else
dexID = cPokemon.Number.ToString
End If
End If
If cPokemon.IsShiny = True Then
Core.Player.PokedexData = Pokedex.ChangeEntry(Core.Player.PokedexData, dexID, 3)
Else
Core.Player.PokedexData = Pokedex.ChangeEntry(Core.Player.PokedexData, dexID, 2)
End If
Me.Pokemons.Remove(cPokemon)
Level.OverworldPokemon.Visible = False
Me.Backgroud = TextureManager.GetTexture("GUI\EggBreak", New Rectangle(0, 0, 256, 192), "")
Me.Egg = GetEggTexture()
MusicManager.PlayNoMusic()
End Sub
Private Function GetEggTexture() As Texture2D
Return TextureManager.GetTexture("GUI\EggBreak", New Rectangle(0 + 28 * Stage, 192, 28, 30), "")
End Function
Public Overrides Sub Draw()
Core.SpriteBatch.Draw(Me.Backgroud, Core.windowSize, Color.White)
If Stage < 6 Then
Core.SpriteBatch.Draw(Egg, New Rectangle(CInt(Core.windowSize.Width / 2 - Egg.Width), CInt(Core.windowSize.Height / 2 - Egg.Height), Egg.Width * 2, Egg.Height * 2), Color.White)
End If
Core.SpriteBatch.Draw(cPokemon.GetTexture(True), New Rectangle(CInt(Core.windowSize.Width / 2 - (cPokemon.GetTexture(True).Width * size / 2)), CInt(Core.windowSize.Height / 2 - (cPokemon.GetTexture(True).Height * size / 1.5F)), CInt(cPokemon.GetTexture(True).Width * size), CInt(cPokemon.GetTexture(True).Height * size)), Color.White)
TextBox.Draw()
ChooseBox.Draw()
End Sub
Public Overrides Sub Update()
ChooseBox.Update()
If ChooseBox.Showing = False Then
TextBox.Update()
End If
If TextBox.Showing = False And ChooseBox.Showing = False Then
If Stage < 6 Then
If delay > 0.0F Then
delay -= 0.1F
End If
If delay <= 0.0F Then
delay = 4.0F
Stage += 1
If Stage = 6 Then
SoundManager.PlaySound("egg_hatch")
Else
SoundManager.PlaySound("Battle\Attacks\Normal\Pound")
End If
Egg = GetEggTexture()
End If
ElseIf Stage = 6 Then
If size < 4.0F Then
size += 0.08F
Else
MusicManager.Play("wild_defeat")
cPokemon.PlayCry()
SoundManager.PlaySound("success", True)
Stage = 7
If Message = "" Then
TextBox.Show("Congratulations!~Your egg hatched into~a " & cPokemon.GetName() & "!")
Else
TextBox.Show(Message)
End If
If CanRename = True Then
TextBox.Show("Do you want to give~a nickname to the freshly~hatched " & cPokemon.GetName() & "?%Yes|No%", AddressOf Me.ResultFunction, False, False, TextBox.DefaultColor)
End If
End If
ElseIf Stage = 7 Then
If Me.IsCurrentScreen = True Then
EndScene()
Stage = 8
End If
End If
End If
End Sub
Private Sub ResultFunction(ByVal result As Integer)
If result = 0 Then
Core.SetScreen(New NameObjectScreen(Core.CurrentScreen, Me.cPokemon))
End If
End Sub
Private Sub EndScene()
If Pokemons.Count = 0 Then
Core.SetScreen(New TransitionScreen(Me, Me.PreScreen, Color.White, False))
Else
Core.SetScreen(New HatchEggScreen(Me.PreScreen, Pokemons))
End If
End Sub
End Class