From 2ee41d3016a14e8465d52299ad4b33e604d54e16 Mon Sep 17 00:00:00 2001 From: freshc0w <121275444+freshc0w@users.noreply.github.com> Date: Sun, 1 Oct 2023 23:51:01 +1000 Subject: [PATCH] Stop task before disposing all tasks in queue for deflecting component@ --- .../game/components/npc/DeflectingComponent.java | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/source/core/src/main/com/csse3200/game/components/npc/DeflectingComponent.java b/source/core/src/main/com/csse3200/game/components/npc/DeflectingComponent.java index b0d2c4444..ab5aa645e 100644 --- a/source/core/src/main/com/csse3200/game/components/npc/DeflectingComponent.java +++ b/source/core/src/main/com/csse3200/game/components/npc/DeflectingComponent.java @@ -65,7 +65,8 @@ public void update() { /** * Deflects projectile to the opposite direction - * @param me Self entity fixture + * + * @param me Self entity fixture * @param other Colliding projectile fixture. */ private void deflectProj(Fixture me, Fixture other) { @@ -73,7 +74,7 @@ private void deflectProj(Fixture me, Fixture other) { if (hitboxComponent.getFixture() != me || !PhysicsLayer.contains(targetLayer, other.getFilterData().categoryBits)) return; - + if (deflectLimitAmount-- <= 0) { // Reached deflect limit amt, return. entity.getComponent(this.getClass()).setEnabled(false); // reset health @@ -86,16 +87,18 @@ private void deflectProj(Fixture me, Fixture other) { // Disposes all tasks for the curr projectile. At this curr time, it assumes // projectile only has one significant task, and that is the TrajectTask. + projectile.getComponent(AITaskComponent.class).dispose(); // stop task projectile.getComponent(AITaskComponent.class).disposeAll(); // Obtain current direction of projectile Vector2 direction = projectile.getComponent( PhysicsMovementComponent.class).getTarget(); - + // Rare occurence that the direction is null if target isn't set. - if(direction == null) return; + if (direction == null) + return; - // Add new traject task with the target in the opposite x-direction. + // // Add new traject task with the target in the opposite x-direction. projectile.getComponent(AITaskComponent.class) .addTask(new TrajectTask(new Vector2(-direction.x, direction.y)));