Namespace BattleSystem.Moves.Psychic Public Class Reflect Inherits Attack Public Sub New() '#Definitions Me.Type = New Element(Element.Types.Psychic) Me.ID = 115 Me.OriginalPP = 20 Me.CurrentPP = 20 Me.MaxPP = 20 Me.Power = 0 Me.Accuracy = 0 Me.Category = Categories.Status Me.ContestCategory = ContestCategories.Smart Me.Name = Localization.GetString("move_name_" & Me.ID,"Reflect") Me.Description = "A wondrous wall is put up to suppress damage from physical attacks for five turns." Me.CriticalChance = 0 Me.IsHMMove = False Me.Target = Targets.AllOwn Me.Priority = 0 Me.TimesToAttack = 1 '#End '#SpecialDefinitions Me.MakesContact = False Me.ProtectAffected = False Me.MagicCoatAffected = False Me.SnatchAffected = True Me.MirrorMoveAffected = True Me.KingsrockAffected = False Me.CounterAffected = False Me.DisabledWhileGravity = False Me.UseEffectiveness = False Me.ImmunityAffected = False Me.RemovesFrozen = False Me.HasSecondaryEffect = False Me.IsHealingMove = False Me.IsRecoilMove = False Me.IsPunchingMove = False Me.IsDamagingMove = False Me.IsProtectMove = False Me.IsSoundMove = False Me.IsAffectedBySubstitute = False Me.IsOneHitKOMove = False Me.IsWonderGuardAffected = False '#End Me.AIField1 = AIField.Support Me.AIField2 = AIField.Nothing End Sub Public Overrides Sub MoveHits(own As Boolean, BattleScreen As BattleScreen) Dim p As Pokemon = BattleScreen.OwnPokemon If own = False Then p = BattleScreen.OppPokemon End If Dim turns As Integer = BattleCalculation.FieldEffectTurns(BattleScreen, own, Me.Name.ToLower()) If own = True Then If BattleScreen.FieldEffects.OwnReflect = 0 Then BattleScreen.FieldEffects.OwnReflect = turns BattleScreen.BattleQuery.Add(New TextQueryObject("Reflect raised your team's Defense!")) Else BattleScreen.BattleQuery.Add(New TextQueryObject(Me.Name & " failed!")) End If Else If BattleScreen.FieldEffects.OppReflect = 0 Then BattleScreen.FieldEffects.OppReflect = turns BattleScreen.BattleQuery.Add(New TextQueryObject("Reflect raised the other team's Defense!")) Else BattleScreen.BattleQuery.Add(New TextQueryObject(Me.Name & " failed!")) End If End If End Sub End Class End Namespace