P3D-Legacy/P3D/Pokemon/Attacks/Normal/Rage.vb

101 lines
3.5 KiB
VB.net

Namespace BattleSystem.Moves.Normal
Public Class Rage
Inherits Attack
Public Sub New()
'#Definitions
Me.Type = New Element(Element.Types.Normal)
Me.ID = 99
Me.OriginalPP = 20
Me.CurrentPP = 20
Me.MaxPP = 20
Me.Power = 20
Me.Accuracy = 100
Me.Category = Categories.Physical
Me.ContestCategory = ContestCategories.Tough
Me.Name = Localization.GetString("move_name_" & Me.ID,"Rage")
Me.Description = "As long as this move is in use, the power of rage raises the Attack stat each time the user is hit in battle."
Me.CriticalChance = 1
Me.IsHMMove = False
Me.Target = Targets.OneAdjacentTarget
Me.Priority = 0
Me.TimesToAttack = 1
'#End
'#SpecialDefinitions
Me.MakesContact = True
Me.ProtectAffected = True
Me.MagicCoatAffected = False
Me.SnatchAffected = False
Me.MirrorMoveAffected = True
Me.KingsrockAffected = True
Me.CounterAffected = True
Me.DisabledWhileGravity = False
Me.UseEffectiveness = True
Me.ImmunityAffected = True
Me.RemovesOwnFrozen = False
Me.HasSecondaryEffect = False
Me.IsHealingMove = False
Me.IsRecoilMove = False
Me.IsDamagingMove = True
Me.IsProtectMove = False
Me.IsAffectedBySubstitute = True
Me.IsOneHitKOMove = False
Me.IsWonderGuardAffected = True
'#End
End Sub
Public Overrides Sub MoveSelected(own As Boolean, BattleScreen As BattleScreen)
If own = True Then
If Not BattleScreen.FieldEffects.OwnLastMove Is Nothing Then
If BattleScreen.FieldEffects.OwnLastMove.ID <> Me.ID Then
BattleScreen.FieldEffects.OwnRageCounter = 0
End If
Else
BattleScreen.FieldEffects.OwnRageCounter = 0
End If
Else
If Not BattleScreen.FieldEffects.OppLastMove Is Nothing Then
If BattleScreen.FieldEffects.OppLastMove.ID <> Me.ID Then
BattleScreen.FieldEffects.OppRageCounter = 0
End If
Else
BattleScreen.FieldEffects.OppRageCounter = 0
End If
End If
End Sub
Public Overrides Sub MoveHits(own As Boolean, BattleScreen As BattleScreen)
If own = True Then
If BattleScreen.FieldEffects.OwnRageCounter = 0 Then
BattleScreen.FieldEffects.OwnRageCounter = 1
End If
Else
If BattleScreen.FieldEffects.OppRageCounter = 0 Then
BattleScreen.FieldEffects.OppRageCounter = 1
End If
End If
End Sub
Public Overrides Function GetBasePower(own As Boolean, BattleScreen As BattleScreen) As Integer
Dim addPower As Integer = 0
If own = True Then
addPower = (BattleScreen.FieldEffects.OwnRageCounter.Clamp(1, 9) - 1) * 10
Else
addPower = (BattleScreen.FieldEffects.OppRageCounter.Clamp(1, 9) - 1) * 10
End If
Return Me.Power + addPower
End Function
End Class
End Namespace