mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-07 00:48:28 +01:00
Make FollowTargetGoal query for targets when necessary
This commit is contained in:
parent
5cf358ac3c
commit
8c6778983b
@ -1,6 +1,7 @@
|
|||||||
package net.minestom.server.entity.ai.goal;
|
package net.minestom.server.entity.ai.goal;
|
||||||
|
|
||||||
import net.minestom.server.coordinate.Point;
|
import net.minestom.server.coordinate.Point;
|
||||||
|
import net.minestom.server.coordinate.Pos;
|
||||||
import net.minestom.server.entity.Entity;
|
import net.minestom.server.entity.Entity;
|
||||||
import net.minestom.server.entity.EntityCreature;
|
import net.minestom.server.entity.EntityCreature;
|
||||||
import net.minestom.server.entity.ai.GoalSelector;
|
import net.minestom.server.entity.ai.GoalSelector;
|
||||||
@ -15,6 +16,8 @@ public class FollowTargetGoal extends GoalSelector {
|
|||||||
private boolean forceEnd = false;
|
private boolean forceEnd = false;
|
||||||
private Point lastTargetPos;
|
private Point lastTargetPos;
|
||||||
|
|
||||||
|
private Entity target;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a follow target goal object.
|
* Creates a follow target goal object.
|
||||||
*
|
*
|
||||||
@ -28,8 +31,14 @@ public class FollowTargetGoal extends GoalSelector {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean shouldStart() {
|
public boolean shouldStart() {
|
||||||
return entityCreature.getTarget() != null &&
|
Entity target = entityCreature.getTarget();
|
||||||
entityCreature.getTarget().getPosition().distance(entityCreature.getPosition()) >= 2;
|
if (target == null) target = findTarget();
|
||||||
|
if (target == null) return false;
|
||||||
|
final boolean result = target.getPosition().distance(entityCreature.getPosition()) >= 2;
|
||||||
|
if (result) {
|
||||||
|
this.target = target;
|
||||||
|
}
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -37,26 +46,26 @@ public class FollowTargetGoal extends GoalSelector {
|
|||||||
lastUpdateTime = 0;
|
lastUpdateTime = 0;
|
||||||
forceEnd = false;
|
forceEnd = false;
|
||||||
lastTargetPos = null;
|
lastTargetPos = null;
|
||||||
final Entity target = entityCreature.getTarget();
|
if (target == null) {
|
||||||
if (target != null) {
|
// No defined target
|
||||||
|
this.forceEnd = true;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
this.entityCreature.setTarget(target);
|
||||||
Navigator navigator = entityCreature.getNavigator();
|
Navigator navigator = entityCreature.getNavigator();
|
||||||
|
this.lastTargetPos = target.getPosition();
|
||||||
lastTargetPos = target.getPosition();
|
|
||||||
if (lastTargetPos.distance(entityCreature.getPosition()) < 2) {
|
if (lastTargetPos.distance(entityCreature.getPosition()) < 2) {
|
||||||
forceEnd = true;
|
// Target is too far
|
||||||
|
this.forceEnd = true;
|
||||||
navigator.setPathTo(null);
|
navigator.setPathTo(null);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (navigator.getPathPosition() == null ||
|
if (navigator.getPathPosition() == null ||
|
||||||
(!navigator.getPathPosition().samePoint(lastTargetPos))) {
|
(!navigator.getPathPosition().samePoint(lastTargetPos))) {
|
||||||
navigator.setPathTo(lastTargetPos);
|
navigator.setPathTo(lastTargetPos);
|
||||||
} else {
|
} else {
|
||||||
forceEnd = true;
|
forceEnd = true;
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
forceEnd = true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -66,7 +75,7 @@ public class FollowTargetGoal extends GoalSelector {
|
|||||||
pathDuration.toMillis() + lastUpdateTime > time) {
|
pathDuration.toMillis() + lastUpdateTime > time) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
final var targetPos = entityCreature.getTarget() != null ? entityCreature.getTarget().getPosition() : null;
|
final Pos targetPos = entityCreature.getTarget() != null ? entityCreature.getTarget().getPosition() : null;
|
||||||
if (targetPos != null && !targetPos.samePoint(lastTargetPos)) {
|
if (targetPos != null && !targetPos.samePoint(lastTargetPos)) {
|
||||||
this.lastUpdateTime = time;
|
this.lastUpdateTime = time;
|
||||||
this.lastTargetPos = targetPos;
|
this.lastTargetPos = targetPos;
|
||||||
@ -79,11 +88,12 @@ public class FollowTargetGoal extends GoalSelector {
|
|||||||
final Entity target = entityCreature.getTarget();
|
final Entity target = entityCreature.getTarget();
|
||||||
return forceEnd ||
|
return forceEnd ||
|
||||||
target == null ||
|
target == null ||
|
||||||
|
target.isRemoved() ||
|
||||||
target.getPosition().distance(entityCreature.getPosition()) < 2;
|
target.getPosition().distance(entityCreature.getPosition()) < 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void end() {
|
public void end() {
|
||||||
entityCreature.getNavigator().setPathTo(null);
|
this.entityCreature.getNavigator().setPathTo(null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -21,6 +21,7 @@ public class ClosestEntityTarget extends TargetSelector {
|
|||||||
private final float range;
|
private final float range;
|
||||||
private final Class<? extends LivingEntity>[] entitiesTarget;
|
private final Class<? extends LivingEntity>[] entitiesTarget;
|
||||||
|
|
||||||
|
@SafeVarargs
|
||||||
public ClosestEntityTarget(@NotNull EntityCreature entityCreature, float range,
|
public ClosestEntityTarget(@NotNull EntityCreature entityCreature, float range,
|
||||||
@NotNull Class<? extends LivingEntity>... entitiesTarget) {
|
@NotNull Class<? extends LivingEntity>... entitiesTarget) {
|
||||||
super(entityCreature);
|
super(entityCreature);
|
||||||
|
Loading…
Reference in New Issue
Block a user