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

666 lines
27 KiB
VB.net

Public Class Daycare
Public Shared Function ProduceEgg(ByVal daycareID As Integer) As Pokemon
Dim parent1 As Pokemon = Nothing
Dim parent2 As Pokemon = Nothing
Dim EggID As Integer = 0
For Each line As String In Core.Player.DaycareData.SplitAtNewline()
If line.StartsWith(daycareID.ToString() & "|0|") = True Then
Dim data As String = line.Remove(0, line.IndexOf("{"))
parent1 = P3D.Pokemon.GetPokemonByData(data)
ElseIf line.StartsWith(daycareID.ToString() & "|1|") = True Then
Dim data As String = line.Remove(0, line.IndexOf("{"))
parent2 = P3D.Pokemon.GetPokemonByData(data)
ElseIf line.StartsWith(daycareID.ToString() & "|Egg|") = True Then
EggID = CInt(line.Split(CChar("|"))(2))
End If
Next
Dim DittoAsParent As Integer = 0
If parent1.EggGroup1 = Pokemon.EggGroups.Ditto Or parent1.EggGroup2 = Pokemon.EggGroups.Ditto Then
DittoAsParent = 1
ElseIf parent2.EggGroup1 = Pokemon.EggGroups.Ditto Or parent2.EggGroup2 = Pokemon.EggGroups.Ditto Then
DittoAsParent = 2
End If
If Not parent1 Is Nothing And Not parent2 Is Nothing And EggID <> 0 Then
Dim p As Pokemon = Pokemon.GetPokemonByID(EggID)
Dim OptionalAdditionalData As String = "xXx"
' Regional Form check
If Screen.Level.RegionalForm.Contains(CChar(",")) Then
For Each r As String In Screen.Level.RegionalForm.Split(CChar(","))
If p.RegionalForms.Contains(r.ToLower()) Then
p.AdditionalData = r.ToLower()
End If
Next
Else
If p.RegionalForms.ToLower.Contains(Screen.Level.RegionalForm.ToLower()) Then
p.AdditionalData = Screen.Level.RegionalForm.ToLower()
End If
End If
' Form inheritance
Select Case DittoAsParent
Case 0
If parent1.Gender = P3D.Pokemon.Genders.Female Then
If parent1.Item IsNot Nothing AndAlso parent1.Item.OriginalName.ToLower() = "everstone" Then
p.AdditionalData = parent1.AdditionalData
ElseIf parent2.Number = parent1.Number And parent2.Item IsNot Nothing AndAlso parent2.Item.OriginalName.ToLower() = "everstone" Then
p.AdditionalData = parent2.AdditionalData
End If
Else
If parent2.Item IsNot Nothing AndAlso parent2.Item.OriginalName.ToLower() = "everstone" Then
p.AdditionalData = parent2.AdditionalData
ElseIf parent1.Number = parent2.Number And parent1.Item IsNot Nothing AndAlso parent1.Item.OriginalName.ToLower() = "everstone" Then
p.AdditionalData = parent1.AdditionalData
End If
End If
Case 1
If parent2.Item IsNot Nothing AndAlso parent2.Item.OriginalName.ToLower() = "everstone" Then
p.AdditionalData = parent2.AdditionalData
End If
Case 2
If parent1.Item IsNot Nothing AndAlso parent1.Item.OriginalName.ToLower() = "everstone" Then
p.AdditionalData = parent1.AdditionalData
End If
End Select
If p.AdditionalData <> "" Then
OptionalAdditionalData = p.AdditionalData
End If
p.Generate(1, True, OptionalAdditionalData)
p.EggSteps = 1
p.SetCatchInfos(Item.GetItemByID(5), "obtained at")
p.CatchBall = Item.GetItemByID(GetEggPokeballID({parent1, parent2}.ToList()))
p.ReloadDefinitions()
p.CalculateStats()
' Adding Egg Moves:
Dim EggMoves As New List(Of BattleSystem.Attack)
' Level-Up moves:
If DittoAsParent = 0 Then
For Each m1 As BattleSystem.Attack In parent1.Attacks
For Each m2 As BattleSystem.Attack In parent2.Attacks
If m1.ID = m2.ID Then
Dim newAttack As BattleSystem.Attack = BattleSystem.Attack.GetAttackByID(m1.ID)
EggMoves.Add(newAttack)
End If
Next
Next
End If
' Technical/Hidden Machine moves:
Dim male As Integer = -1
If parent1.Gender = P3D.Pokemon.Genders.Male Then
male = 0
End If
If parent2.Gender = P3D.Pokemon.Genders.Male Then
male = 1
End If
If male > -1 Then
Dim cParent As Pokemon = Nothing
Select Case male
Case 0
cParent = parent1
Case 1
cParent = parent2
End Select
For Each THMMove As BattleSystem.Attack In p.AttackLearns.Values
For Each m1 As BattleSystem.Attack In cParent.Attacks
If m1.ID = THMMove.ID Then
Dim newAttack As BattleSystem.Attack = BattleSystem.Attack.GetAttackByID(m1.ID)
EggMoves.Add(newAttack)
End If
Next
Next
End If
' Egg Moves:
male = -1
If parent1.Gender = P3D.Pokemon.Genders.Male Then
male = 0
End If
If parent2.Gender = P3D.Pokemon.Genders.Male Then
male = 1
End If
If male > -1 Then
For Each BreedMove As Integer In p.EggMoves
For Each m1 As BattleSystem.Attack In parent1.Attacks
If m1.ID = BreedMove Then
GameJolt.Emblem.AchieveEmblem("eggsplosion")
Dim newAttack As BattleSystem.Attack = BattleSystem.Attack.GetAttackByID(m1.ID)
EggMoves.Add(newAttack)
End If
Next
For Each m1 As BattleSystem.Attack In parent2.Attacks
If m1.ID = BreedMove Then
GameJolt.Emblem.AchieveEmblem("eggsplosion")
Dim newAttack As BattleSystem.Attack = BattleSystem.Attack.GetAttackByID(m1.ID)
EggMoves.Add(newAttack)
End If
Next
Next
End If
' Volt Tackle for Pikachu:
If (parent1.Item IsNot Nothing AndAlso parent1.Item.Name.ToLower = "light ball") OrElse (parent2.Item IsNot Nothing AndAlso parent2.Item.Name.ToLower = "light ball") Then
Dim newAttack As BattleSystem.Attack = BattleSystem.Attack.GetAttackByID(344)
EggMoves.Add(newAttack)
End If
Dim learnMoves As New List(Of BattleSystem.Attack)
If EggMoves.Count <= 4 Then
learnMoves.AddRange(EggMoves.ToArray())
Else
For i = EggMoves.Count - 4 To EggMoves.Count - 1
learnMoves.Add(EggMoves(i))
Next
End If
While p.Attacks.Count + learnMoves.Count > 4
p.Attacks.RemoveAt(0)
End While
For Each learnMove As BattleSystem.Attack In learnMoves
Dim hasAttack As Boolean = False
For Each m As BattleSystem.Attack In p.Attacks
If m.ID = learnMove.ID Then
hasAttack = True
Exit For
End If
Next
If hasAttack = False Then
p.Attacks.Add(learnMove)
End If
Next
' Inherit stats:
Dim IV1 As New List(Of String)
Dim IV2 As New List(Of String)
Dim EVStat1 As String = ""
Dim EVStat2 As String = ""
Dim DKnot As Boolean = False
Dim EVItems() As String = {"power weight", "power bracer", "power belt", "power lens", "power band", "power anklet", "destiny knot"}
If Not parent1.Item Is Nothing Then
If EVItems.Contains(parent1.Item.OriginalName.ToLower()) = True Then
Select Case parent1.Item.OriginalName.ToLower()
Case "power weight"
EVStat1 = "HP"
Case "power bracer"
EVStat1 = "Attack"
Case "power belt"
EVStat1 = "Defense"
Case "power lens"
EVStat1 = "Special Attack"
Case "power band"
EVStat1 = "Special Defense"
Case "power anklet"
EVStat1 = "Speed"
Case "destiny knot"
DKnot = True
End Select
End If
End If
If Not parent2.Item Is Nothing Then
If EVItems.Contains(parent2.Item.OriginalName.ToLower()) = True Then
Select Case parent2.Item.OriginalName.ToLower()
Case "power weight"
EVStat2 = "HP"
Case "power bracer"
EVStat2 = "Attack"
Case "power belt"
EVStat2 = "Defense"
Case "power lens"
EVStat2 = "Special Attack"
Case "power band"
EVStat2 = "Special Defense"
Case "power anklet"
EVStat2 = "Speed"
Case "destiny knot"
DKnot = True
End Select
End If
End If
If EVStat1 <> "" And EVStat2 = "" Then
IV1.Add(EVStat1)
ElseIf EVStat1 = "" And EVStat2 <> "" Then
IV2.Add(EVStat2)
ElseIf EVStat1 <> "" And EVStat2 <> "" Then
If Core.Random.Next(0, 2) = 0 Then
IV1.Add(EVStat1)
Else
IV2.Add(EVStat2)
End If
End If
Dim InheritIV As Integer = 3
If DKnot = True Then
InheritIV = 5
End If
While IV1.Count + IV2.Count < InheritIV
Dim newStat As String = ""
While newStat = "" Or IV1.Contains(newStat) = True Or IV2.Contains(newStat) = True
Select Case Core.Random.Next(0, 6)
Case 0
newStat = "Attack"
Case 1
newStat = "Defense"
Case 2
newStat = "Special Attack"
Case 3
newStat = "Special Defense"
Case 4
newStat = "Speed"
Case 5
newStat = "HP"
End Select
End While
Select Case Core.Random.Next(0, 2)
Case 0
IV1.Add(newStat)
Case 1
IV2.Add(newStat)
End Select
End While
For Each IV As String In IV1
Select Case IV
Case "HP"
p.IVHP = parent1.IVHP
Case "Attack"
p.IVAttack = parent1.IVAttack
Case "Defense"
p.IVDefense = parent1.IVDefense
Case "Special Attack"
p.IVSpAttack = parent1.IVSpAttack
Case "Special Defense"
p.IVSpDefense = parent1.IVSpDefense
Case "Speed"
p.IVSpeed = parent1.IVSpeed
End Select
Next
For Each IV As String In IV2
Select Case IV
Case "HP"
p.IVHP = parent2.IVHP
Case "Attack"
p.IVAttack = parent2.IVAttack
Case "Defense"
p.IVDefense = parent2.IVDefense
Case "Special Attack"
p.IVSpAttack = parent2.IVSpAttack
Case "Special Defense"
p.IVSpDefense = parent2.IVSpDefense
Case "Speed"
p.IVSpeed = parent2.IVSpeed
End Select
Next
' Natures:
Dim EStone1 As Boolean = False
Dim EStone2 As Boolean = False
If Not parent1.Item Is Nothing Then
If parent1.Item.OriginalName.ToLower() = "everstone" Then
EStone1 = True
End If
End If
If Not parent2.Item Is Nothing Then
If parent2.Item.OriginalName.ToLower() = "everstone" Then
EStone2 = True
End If
End If
If EStone1 = True And EStone2 = False Then
p.Nature = parent1.Nature
ElseIf EStone1 = False And EStone2 = True Then
p.Nature = parent2.Nature
ElseIf EStone1 = True And EStone2 = True Then
If Core.Random.Next(0, 2) = 0 Then
p.Nature = parent1.Nature
Else
p.Nature = parent2.Nature
End If
End If
' Abilities:
If DittoAsParent = 0 Then
Dim female As Pokemon = parent1
If parent2.Gender = P3D.Pokemon.Genders.Female Then
female = parent2
End If
If Core.Random.Next(0, 100) < 80 Then
p.Ability = female.Ability
End If
End If
' Hidden Ability:
If DittoAsParent <> 0 Then
If DittoAsParent = 1 Then
If parent2.IsUsingHiddenAbility = True And p.HasHiddenAbility = True And Core.Random.Next(0, 100) < 80 Then
p.Ability = p.HiddenAbility
End If
Else
If parent1.IsUsingHiddenAbility = True And p.HasHiddenAbility = True And Core.Random.Next(0, 100) < 80 Then
p.Ability = p.HiddenAbility
End If
End If
Else
Dim female As Pokemon = parent1
If parent2.Gender = P3D.Pokemon.Genders.Female Then
female = parent2
End If
If female.IsUsingHiddenAbility = True And p.HasHiddenAbility = True And Core.Random.Next(0, 100) < 80 Then
p.Ability = p.HiddenAbility
End If
End If
' Shiny:
Dim Shiny1 As Boolean = parent1.IsShiny
Dim Shiny2 As Boolean = parent2.IsShiny
Dim chances As List(Of Integer) = {1, Pokemon.MasterShinyRate}.ToList()
If Shiny1 = True And Shiny2 = True Then
chances = {12, Pokemon.MasterShinyRate}.ToList() '12/base rate odds
ElseIf Shiny1 = True Or Shiny2 = True Then
chances = {6, Pokemon.MasterShinyRate}.ToList() '6/base rate odds
End If
If Core.Random.Next(0, chances(1)) < chances(0) Then
p.IsShiny = True
Else
p.IsShiny = False
End If
If p.HP > p.MaxHP Then
p.HP = p.MaxHP
End If
Return p
End If
Return Nothing
End Function
Public Shared Function CanBreed(ByVal Pokemon As List(Of Pokemon), Optional ByVal multiplier As Boolean = True) As Integer
Dim chance As Integer = 0
If Pokemon.Count = 2 Then
Dim p1 As Pokemon = Pokemon(0)
Dim p2 As Pokemon = Pokemon(1)
If p1.CanBreed = False Or p2.CanBreed = False Then
Return 0
End If
If p1.EggGroup1 = P3D.Pokemon.EggGroups.Undiscovered Or p1.EggGroup2 = P3D.Pokemon.EggGroups.Undiscovered Or p2.EggGroup1 = P3D.Pokemon.EggGroups.Undiscovered Or p2.EggGroup2 = P3D.Pokemon.EggGroups.Undiscovered Then
Return 0
End If
If p1.EggGroup1 = P3D.Pokemon.EggGroups.Ditto Or p1.EggGroup2 = P3D.Pokemon.EggGroups.Ditto Then
If p2.EggGroup1 = P3D.Pokemon.EggGroups.Ditto Or p2.EggGroup2 = P3D.Pokemon.EggGroups.Ditto Then
Return 0
End If
End If
If p2.EggGroup1 = P3D.Pokemon.EggGroups.Ditto Or p2.EggGroup2 = P3D.Pokemon.EggGroups.Ditto Then
If p1.EggGroup1 = P3D.Pokemon.EggGroups.Ditto Or p1.EggGroup2 = P3D.Pokemon.EggGroups.Ditto Then
Return 0
End If
End If
If p1.IsGenderless = True Then
If p2.EggGroup1 = P3D.Pokemon.EggGroups.Ditto Or p2.EggGroup2 = P3D.Pokemon.EggGroups.Ditto Then
chance = -1
Else
If p1.EggGroup1 = P3D.Pokemon.EggGroups.Ditto Or p1.EggGroup2 = P3D.Pokemon.EggGroups.Ditto Then
chance = -1
End If
End If
ElseIf p2.IsGenderless = True Then
If p1.EggGroup1 = P3D.Pokemon.EggGroups.Ditto Or p1.EggGroup2 = P3D.Pokemon.EggGroups.Ditto Then
chance = -1
Else
If p2.EggGroup1 = P3D.Pokemon.EggGroups.Ditto Or p2.EggGroup2 = P3D.Pokemon.EggGroups.Ditto Then
chance = -1
End If
End If
ElseIf p1.IsGenderless = False And p2.IsGenderless = False Then
If p1.Gender <> p2.Gender Then
If p1.EggGroup1 = P3D.Pokemon.EggGroups.Ditto Or p2.EggGroup1 = P3D.Pokemon.EggGroups.Ditto Or p1.EggGroup2 = P3D.Pokemon.EggGroups.Ditto Or p2.EggGroup2 = P3D.Pokemon.EggGroups.Ditto Then
chance = -1
Else
If p1.EggGroup1 = p2.EggGroup1 And p1.EggGroup1 <> P3D.Pokemon.EggGroups.None Or
p1.EggGroup2 = p2.EggGroup1 And p1.EggGroup2 <> P3D.Pokemon.EggGroups.None Or
p1.EggGroup1 = p2.EggGroup2 And p1.EggGroup1 <> P3D.Pokemon.EggGroups.None Or
p1.EggGroup2 = p2.EggGroup2 And p1.EggGroup2 <> P3D.Pokemon.EggGroups.None Then
chance = -1
End If
End If
End If
End If
If chance = -1 Then
If p1.Number = p2.Number And p1.OT <> p2.OT Then
chance = 70
End If
If p1.Number = p2.Number And p1.OT = p2.OT Then
chance = 50
End If
If p1.Number <> p2.Number And p1.OT <> p2.OT Then
chance = 50
End If
If p1.Number <> p2.Number And p1.OT = p2.OT Then
chance = 20
End If
End If
End If
If chance > 0 And multiplier = True Then
If Core.Player.Inventory.GetItemAmount(241) > 0 Then
chance = CInt(chance * 1.3F)
End If
End If
Return chance
End Function
Public Shared Function CanBreed(ByVal daycareID As Integer, Optional ByVal multiplier As Boolean = True) As Integer
Dim l As New List(Of Pokemon)
For Each line As String In Core.Player.DaycareData.SplitAtNewline()
If line.StartsWith(daycareID.ToString() & "|") = True Then
Dim data As String = line.Remove(0, line.IndexOf("{"))
Dim p As Pokemon = P3D.Pokemon.GetPokemonByData(data)
l.Add(p)
End If
Next
Return CanBreed(l, multiplier)
End Function
Public Shared Function CanBreed(ByVal Pokemon As Dictionary(Of Integer, Pokemon), Optional ByVal multiplier As Boolean = True) As Integer
Dim l As New List(Of Pokemon)
For i = 0 To Pokemon.Count - 1
l.Add(Pokemon.Values(i))
Next
Return CanBreed(l, multiplier)
End Function
Private Shared Function GetEggPokemonID(ByVal Pokemon As Dictionary(Of Integer, Pokemon)) As Integer
If Pokemon.Count = 2 Then
Dim p1 As Pokemon = Pokemon.Values(0)
Dim p2 As Pokemon = Pokemon.Values(1)
If p1.EggGroup1 = P3D.Pokemon.EggGroups.Ditto Or p1.EggGroup2 = P3D.Pokemon.EggGroups.Ditto Then
Return p2.Number
End If
If p2.EggGroup1 = P3D.Pokemon.EggGroups.Ditto Or p2.EggGroup2 = P3D.Pokemon.EggGroups.Ditto Then
Return p1.Number
End If
If p1.Gender = P3D.Pokemon.Genders.Female Then
Return p1.Number
End If
If p2.Gender = P3D.Pokemon.Genders.Female Then
Return p2.Number
End If
End If
Return 0
End Function
Private Shared Function GetEggPokeballID(ByVal Pokemon As List(Of Pokemon)) As Integer
Dim ballID As Integer = 5
If Pokemon.Count = 2 Then
Dim p1 As Pokemon = Pokemon(0)
Dim p2 As Pokemon = Pokemon(1)
' First Pokémon is Ditto:
If p1.EggGroup1 = P3D.Pokemon.EggGroups.Ditto Or p1.EggGroup2 = P3D.Pokemon.EggGroups.Ditto Then
' If the first Pokémon is Ditto, then the other Pokémon must be female to inherit the Poké Ball.
If p2.Gender = P3D.Pokemon.Genders.Female Then
ballID = p2.CatchBall.ID
End If
End If
'Second Pokémon is Ditto.
If p2.EggGroup1 = P3D.Pokemon.EggGroups.Ditto Or p2.EggGroup2 = P3D.Pokemon.EggGroups.Ditto Then
'If the second Pokémon is Ditto, then the other Pokémon must be female to inherit the Poké Ball.
If p1.Gender = P3D.Pokemon.Genders.Female Then
ballID = p1.CatchBall.ID
End If
End If
' No Pokémon is Ditto:
If p1.EggGroup1 <> P3D.Pokemon.EggGroups.Ditto And p1.EggGroup2 <> P3D.Pokemon.EggGroups.Ditto And p2.EggGroup1 <> P3D.Pokemon.EggGroups.Ditto And p2.EggGroup2 <> P3D.Pokemon.EggGroups.Ditto Then
' First Pokémon is female:
If p1.Gender = P3D.Pokemon.Genders.Female Then
ballID = p1.CatchBall.ID
End If
' Second Pokémon is female:
If p2.Gender = P3D.Pokemon.Genders.Female Then
ballID = p2.CatchBall.ID
End If
End If
' Check for: Master Ball, Cherish Ball: Set to Poké Ball
If ballID = 1 Or ballID = 45 Then
ballID = 5
End If
End If
' Return BallID (Standard is 5 for Pokéball):
Return ballID
End Function
Public Shared Sub ObtainEgg()
Dim Data() As String = Core.Player.DaycareData.SplitAtNewline()
Dim IDs As New List(Of Integer)
For Each line As String In Data
If line <> "" And line.Contains("|") = True Then
Dim newID As Integer = CInt(line.GetSplit(0, "|"))
If IDs.Contains(newID) = False Then
IDs.Add(newID)
End If
End If
Next
Logger.Debug("Daycare circle complete!")
For Each DaycareID As Integer In IDs
Logger.Debug("Daycare ID: " & DaycareID)
Dim Pokemon As New Dictionary(Of Integer, Pokemon)
Dim hasEgg As Boolean = False
Dim EggID As Integer = 0
For Each line As String In Data
If line.StartsWith(DaycareID & "|") = True Then
If line.GetSplit(1, "|") = "Egg" Then
hasEgg = True
EggID = CInt(line.GetSplit(2, "|"))
Else
Dim PlaceID As Integer = CInt(line.GetSplit(1, "|"))
Dim startStep As Integer = CInt(line.GetSplit(2, "|"))
Dim Level As Integer = CInt(line.GetSplit(3, "|"))
Dim PokemonData As String = line.GetSplit(4, "|")
If Pokemon.ContainsKey(PlaceID) = False Then
Dim p As Pokemon = P3D.Pokemon.GetPokemonByData(PokemonData)
Pokemon.Add(PlaceID, p)
End If
End If
End If
Next
Logger.Debug("Pokémon count: " & Pokemon.Count)
Logger.Debug("Has Egg: " & hasEgg.ToString())
If hasEgg = False Then
Dim breedChance As Integer = CanBreed(Pokemon)
If breedChance > 0 Then
Logger.Debug("Breed chance: " & breedChance)
If Core.Random.Next(0, 100) < breedChance Then
Dim parentID As Integer = GetEggPokemonID(Pokemon)
Dim newEggID As Integer = P3D.Pokemon.GetPokemonByID(parentID).EggPokemon
Dim s As String = DaycareID.ToString() & "|Egg|" & newEggID.ToString()
Logger.Debug("Egg created!" & Environment.NewLine & "EggID: " & newEggID)
TriggerCall(DaycareID)
Dim oldData As String = Core.Player.DaycareData
If oldData <> "" Then
oldData &= Environment.NewLine
End If
oldData &= s
Core.Player.DaycareData = oldData
End If
Else
Logger.Debug("Pokémon in Daycare " & DaycareID & " cannot breed.")
End If
End If
Next
End Sub
Public Shared Sub TriggerCall(ByVal daycareID As Integer)
If ActionScript.IsRegistered("daycare_callid_" & daycareID.ToString()) = True Then
Dim c() As Object = ActionScript.GetRegisterValue("daycare_callid_" & daycareID.ToString())
If Not c(0) Is Nothing And Not c(1) Is Nothing Then
Dim callID As String = CStr(c(0))
GameJolt.PokegearScreen.CallID(callID, True, False)
Else
Logger.Debug("Cannot initialize call for Daycare ID " & daycareID.ToString() & ".")
End If
Else
Logger.Debug("Cannot initialize call for Daycare ID " & daycareID.ToString() & ".")
End If
End Sub
Public Shared Sub EggCircle()
Core.Player.PlayerTemp.DayCareCycle = 256
ObtainEgg()
End Sub
End Class