P3D-Legacy/P3D/Pokemon/Monster/EvolutionCondition.vb

353 lines
15 KiB
VB.net

Public Class EvolutionCondition
Public Enum ConditionTypes
Level
Friendship
Item
HoldItem
Place
NotPlace
Trade
Gender
AtkDef
DefAtk
DefEqualsAtk
Move
DayTime
InParty
InPartyType
Weather
Region
Status
EnvironmentType
NotEnvironmentType
End Enum
Public Structure Condition
Dim ConditionType As ConditionTypes
Dim Argument As String
End Structure
Public Trigger As EvolutionTrigger
Public Evolution As String = ""
Public Conditions As New List(Of Condition)
Public Sub SetEvolution(ByVal evolution As String)
Me.Evolution = evolution
End Sub
Public Sub AddCondition(ByVal type As String, ByVal arg As String)
Dim c As New Condition
c.Argument = arg
Select Case type.ToLower()
Case "level"
c.ConditionType = ConditionTypes.Level
Case "item"
c.ConditionType = ConditionTypes.Item
Case "holditem"
c.ConditionType = ConditionTypes.HoldItem
Case "location", "place"
c.ConditionType = ConditionTypes.Place
Case "notlocation", "notplace"
c.ConditionType = ConditionTypes.NotPlace
Case "friendship"
c.ConditionType = ConditionTypes.Friendship
Case "trade"
c.ConditionType = ConditionTypes.Trade
Case "move"
c.ConditionType = ConditionTypes.Move
Case "gender"
c.ConditionType = ConditionTypes.Gender
Case "atkdef"
c.ConditionType = ConditionTypes.AtkDef
Case "defatk"
c.ConditionType = ConditionTypes.DefAtk
Case "defequalsatk"
c.ConditionType = ConditionTypes.DefEqualsAtk
Case "daytime"
c.ConditionType = ConditionTypes.DayTime
Case "inparty"
c.ConditionType = ConditionTypes.InParty
Case "inpartytype"
c.ConditionType = ConditionTypes.InPartyType
Case "weather"
c.ConditionType = ConditionTypes.Weather
Case "region"
c.ConditionType = ConditionTypes.Region
Case "status"
c.ConditionType = ConditionTypes.Status
Case "environmenttype"
c.ConditionType = ConditionTypes.EnvironmentType
Case "notenvironmenttype"
c.ConditionType = ConditionTypes.NotEnvironmentType
End Select
Me.Conditions.Add(c)
End Sub
Public Sub SetTrigger(ByVal trigger As String)
Select Case trigger.ToLower()
Case "none", ""
Me.Trigger = EvolutionTrigger.None
Case "level", "levelup"
Me.Trigger = EvolutionTrigger.LevelUp
Case "trade", "trading"
Me.Trigger = EvolutionTrigger.Trading
Case "item", "itemuse"
Me.Trigger = EvolutionTrigger.ItemUse
End Select
End Sub
Public ReadOnly Property Count() As Integer
Get
Return Conditions.Count
End Get
End Property
Public Enum EvolutionTrigger
None
LevelUp
Trading
ItemUse
End Enum
''' <summary>
''' Returns the evolution of a Pokémon. Returns 0 if not successful
''' </summary>
''' <param name="p">The Pokémon to get the evolution from.</param>
''' <param name="trigger">The trigger that triggered the evolution.</param>
''' <param name="arg">An argument (for example Item ID)</param>
Public Shared Function EvolutionNumber(ByVal p As Pokemon, ByVal trigger As EvolutionTrigger, ByVal arg As String) As String
Dim e As EvolutionCondition = GetEvolutionCondition(p, trigger, arg)
If e Is Nothing Then
Return ""
Else
Return e.Evolution
End If
End Function
Public Shared Function GetEvolutionCondition(ByVal p As Pokemon, ByVal trigger As EvolutionTrigger, ByVal arg As String) As EvolutionCondition
If trigger = EvolutionTrigger.LevelUp Or trigger = EvolutionTrigger.Trading Then
If Not p.Item Is Nothing Then
If p.Item.IsGameModeItem = False Then
If p.Item.ID = 112 Then
Return Nothing
End If
End If
End If
End If
Dim possibleEvolutions As New List(Of EvolutionCondition)
For Each e As EvolutionCondition In p.EvolutionConditions
Dim canEvolve As Boolean = True
If trigger <> e.Trigger Then
canEvolve = False
End If
If canEvolve = True Then
For Each c As Condition In e.Conditions
Select Case c.ConditionType
Case ConditionTypes.AtkDef
If p.Attack <= p.Defense Then
canEvolve = False
End If
Case ConditionTypes.DayTime
Dim daytimes As List(Of String) = c.Argument.Split(CChar(";")).ToList()
If daytimes.Contains(CStr(CInt(World.GetTime()))) = False Then
canEvolve = False
End If
Case ConditionTypes.DefAtk
If p.Defense <= p.Attack Then
canEvolve = False
End If
Case ConditionTypes.DefEqualsAtk
If p.Attack <> p.Defense Then
canEvolve = False
End If
Case ConditionTypes.Friendship
If p.Friendship < CInt(c.Argument) Then
canEvolve = False
End If
Case ConditionTypes.Gender
If CInt(p.Gender) <> CInt(c.Argument) Then
canEvolve = False
End If
Case ConditionTypes.HoldItem
If p.Item Is Nothing Then
canEvolve = False
Else
If p.Item.IsGameModeItem = True Then
If p.Item.gmID <> c.Argument Then
canEvolve = False
'ElseIf c.Trigger = EvolutionTrigger.Trading Then
'REMOVE HELD ITEM CHECK
End If
Else
If p.Item.ID.ToString <> c.Argument Then
canEvolve = False
'ElseIf c.Trigger = EvolutionTrigger.Trading Then
'REMOVE HELD ITEM CHECK
End If
End If
End If
Case ConditionTypes.InParty
Dim isInParty As Boolean = False
For Each pokemon As Pokemon In Core.Player.Pokemons
If pokemon.Number = CInt(c.Argument) Then
isInParty = True
Exit For
End If
Next
If isInParty = False Then
canEvolve = False
End If
Case ConditionTypes.InPartyType
Dim isInParty As Boolean = False
For Each pokemon As Pokemon In Core.Player.Pokemons
If pokemon.IsType(BattleSystem.GameModeElementLoader.GetElementByName(c.Argument).Type) = True Then
isInParty = True
Exit For
End If
Next
If isInParty = False Then
canEvolve = False
End If
Case ConditionTypes.Item
If Item.GetItemByID(arg).IsGameModeItem = True Then
If arg <> c.Argument Then
canEvolve = False
End If
Else
If Item.GetItemByID(c.Argument).IsGameModeItem = True Then
If arg <> c.Argument Then
canEvolve = False
End If
Else
If CInt(arg) <> CInt(c.Argument) Then
canEvolve = False
End If
End If
End If
Case ConditionTypes.Level
If p.Level < CInt(c.Argument) Then
canEvolve = False
End If
Case ConditionTypes.Move
Dim hasattack As Boolean = False
For Each a As BattleSystem.Attack In p.Attacks
If a.ID = CInt(c.Argument) Then
hasattack = True
Exit For
End If
Next
If hasattack = False Then
canEvolve = False
End If
Case ConditionTypes.Place
Dim places As List(Of String) = c.Argument.Split(CChar(";")).ToList()
Dim PlaceMatch As Boolean = False
For i = 0 To places.Count - 1
If places(i).ToLower = Screen.Level.MapName.ToLower() Then
PlaceMatch = True
Exit For
End If
Next
If PlaceMatch = False Then
canEvolve = False
End If
Case ConditionTypes.NotPlace
Dim places As List(Of String) = c.Argument.Split(CChar(";")).ToList()
Dim PlaceMatch As Boolean = False
For i = 0 To places.Count - 1
If places(i).ToLower = Screen.Level.MapName.ToLower() Then
PlaceMatch = True
Exit For
End If
Next
If PlaceMatch = True Then
canEvolve = False
End If
Case ConditionTypes.Trade
If StringHelper.IsNumeric(c.Argument) Then
If CInt(c.Argument) > 0 Then
If CInt(c.Argument) <> CInt(arg) Then
canEvolve = False
End If
End If
End If
Case ConditionTypes.Weather
If World.GetCurrentRegionWeather().ToString.ToLower <> c.Argument.ToLower Then
canEvolve = False
End If
Case ConditionTypes.Region
canEvolve = False
Dim eregions As List(Of String) = c.Argument.ToLower.Split(CChar(";")).ToList()
Dim regions As List(Of String) = Screen.Level.CurrentRegion.ToLower.Split(CChar(",")).ToList()
For Each r As String In eregions
If r.Chars(0) = CChar("-") Then
canEvolve = False
If Not regions.Contains(r.Substring(1)) Then
canEvolve = True
End If
Else
If regions.Contains(r) Then
canEvolve = True
End If
End If
Next
Case ConditionTypes.Status
Dim RequiredStatus As Pokemon.StatusProblems = Nothing
Select Case c.Argument
Case "brn"
RequiredStatus = Pokemon.StatusProblems.Burn
Case "frz"
RequiredStatus = Pokemon.StatusProblems.Freeze
Case "prz"
RequiredStatus = Pokemon.StatusProblems.Paralyzed
Case "psn"
RequiredStatus = Pokemon.StatusProblems.Poison
Case "bpsn"
RequiredStatus = Pokemon.StatusProblems.BadPoison
Case "slp"
RequiredStatus = Pokemon.StatusProblems.Sleep
Case "fnt"
RequiredStatus = Pokemon.StatusProblems.Fainted
End Select
If RequiredStatus <> Nothing AndAlso p.Status <> RequiredStatus Then
canEvolve = False
End If
Case ConditionTypes.EnvironmentType
Dim environments As List(Of String) = c.Argument.Split(CChar(";")).ToList()
If environments.Contains(CStr(Screen.Level.EnvironmentType)) = False Then
canEvolve = False
End If
Case ConditionTypes.NotEnvironmentType
Dim environments As List(Of String) = c.Argument.Split(CChar(";")).ToList()
If environments.Contains(CStr(Screen.Level.EnvironmentType)) = True Then
canEvolve = False
End If
End Select
Next
End If
If canEvolve = True Then
possibleEvolutions.Add(e)
End If
Next
'Assuming there is never more than one possible evolution for trading + held item
If possibleEvolutions.Count > 0 Then
Return possibleEvolutions(Core.Random.Next(0, possibleEvolutions.Count))
End If
Return Nothing
End Function
End Class