mirror of
https://github.com/CitizensDev/Citizens2.git
synced 2025-01-25 17:41:35 +01:00
Fix target location for mc navigator
This commit is contained in:
parent
9c8d26e73b
commit
5306a68b6a
@ -12,6 +12,7 @@ import net.citizensnpcs.api.ai.AbstractPathStrategy;
|
|||||||
import net.citizensnpcs.api.ai.NavigatorParameters;
|
import net.citizensnpcs.api.ai.NavigatorParameters;
|
||||||
import net.citizensnpcs.api.ai.TargetType;
|
import net.citizensnpcs.api.ai.TargetType;
|
||||||
import net.citizensnpcs.api.ai.event.CancelReason;
|
import net.citizensnpcs.api.ai.event.CancelReason;
|
||||||
|
import net.citizensnpcs.api.astar.pathfinder.MinecraftBlockExaminer;
|
||||||
import net.citizensnpcs.api.npc.NPC;
|
import net.citizensnpcs.api.npc.NPC;
|
||||||
import net.citizensnpcs.util.NMS;
|
import net.citizensnpcs.util.NMS;
|
||||||
|
|
||||||
@ -32,6 +33,9 @@ public class MCNavigationStrategy extends AbstractPathStrategy {
|
|||||||
|
|
||||||
MCNavigationStrategy(final NPC npc, Location dest, NavigatorParameters params) {
|
MCNavigationStrategy(final NPC npc, Location dest, NavigatorParameters params) {
|
||||||
super(TargetType.LOCATION);
|
super(TargetType.LOCATION);
|
||||||
|
if (!MinecraftBlockExaminer.canStandIn(dest.getBlock().getType())) {
|
||||||
|
dest = MinecraftBlockExaminer.findValidLocationAbove(dest, 2);
|
||||||
|
}
|
||||||
this.target = dest;
|
this.target = dest;
|
||||||
this.parameters = params;
|
this.parameters = params;
|
||||||
handle = npc.getEntity();
|
handle = npc.getEntity();
|
||||||
|
@ -311,7 +311,7 @@ public class LinearWaypointProvider implements EnumerableWaypointProvider {
|
|||||||
if (event.getClickedBlock() == null)
|
if (event.getClickedBlock() == null)
|
||||||
return;
|
return;
|
||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
Location at = event.getClickedBlock().getLocation();
|
Location at = event.getClickedBlock().getLocation().add(0, 1, 0);
|
||||||
Location prev = getLastWaypoint();
|
Location prev = getLastWaypoint();
|
||||||
|
|
||||||
if (prev != null && prev.getWorld() == at.getWorld()) {
|
if (prev != null && prev.getWorld() == at.getWorld()) {
|
||||||
@ -327,7 +327,7 @@ public class LinearWaypointProvider implements EnumerableWaypointProvider {
|
|||||||
Waypoint element = new Waypoint(at);
|
Waypoint element = new Waypoint(at);
|
||||||
waypoints.add(element);
|
waypoints.add(element);
|
||||||
if (showingMarkers) {
|
if (showingMarkers) {
|
||||||
markers.createMarker(element, element.getLocation().clone().add(0, 1, 0));
|
markers.createMarker(element, element.getLocation().clone());
|
||||||
}
|
}
|
||||||
Messaging.sendTr(player, Messages.LINEAR_WAYPOINT_EDITOR_ADDED_WAYPOINT, formatLoc(at),
|
Messaging.sendTr(player, Messages.LINEAR_WAYPOINT_EDITOR_ADDED_WAYPOINT, formatLoc(at),
|
||||||
waypoints.size());
|
waypoints.size());
|
||||||
|
@ -9,7 +9,7 @@ import net.minecraft.world.phys.Vec3;
|
|||||||
public class PlayerLookControl {
|
public class PlayerLookControl {
|
||||||
private final EntityHumanNPC a;
|
private final EntityHumanNPC a;
|
||||||
private final PlayerBodyControl control;
|
private final PlayerBodyControl control;
|
||||||
protected boolean move;
|
protected boolean looking;
|
||||||
protected float tpitch;
|
protected float tpitch;
|
||||||
protected double tx;
|
protected double tx;
|
||||||
protected double ty;
|
protected double ty;
|
||||||
@ -27,8 +27,8 @@ public class PlayerLookControl {
|
|||||||
if (this.b()) {
|
if (this.b()) {
|
||||||
// this.a.setXRot(0.0F);
|
// this.a.setXRot(0.0F);
|
||||||
}
|
}
|
||||||
if (this.move) {
|
if (this.looking) {
|
||||||
this.move = false;
|
this.looking = false;
|
||||||
this.a.setXRot(this.rotateTowards(this.a.getXRot(), this.g(), this.tpitch));
|
this.a.setXRot(this.rotateTowards(this.a.getXRot(), this.g(), this.tpitch));
|
||||||
this.a.yHeadRot = this.rotateTowards(this.a.yHeadRot, this.h(), this.tyaw);
|
this.a.yHeadRot = this.rotateTowards(this.a.yHeadRot, this.h(), this.tyaw);
|
||||||
while (this.a.yHeadRot >= 180F) {
|
while (this.a.yHeadRot >= 180F) {
|
||||||
@ -61,8 +61,7 @@ public class PlayerLookControl {
|
|||||||
}
|
}
|
||||||
// this.a.setYRot(this.a(this.a.yHeadRot, this.h(), this.b));
|
// this.a.setYRot(this.a(this.a.yHeadRot, this.h(), this.b));
|
||||||
} else {
|
} else {
|
||||||
// this.a.setYRot(MathHelper.b(this.a.getYRot(), this.a.yHeadRot, 40F));
|
// this.a.yHeadRot = rotateTowards(this.a.yHeadRot, this.a.yBodyRot, 10.0F);
|
||||||
// this.a.aK = this.a(this.a.yHeadRot, this.a.aA, 10.0F);
|
|
||||||
}
|
}
|
||||||
if (!this.a.getNavigation().isDone()) { // TODO: use Citizens AI?
|
if (!this.a.getNavigation().isDone()) { // TODO: use Citizens AI?
|
||||||
this.a.yHeadRot = Mth.rotateIfNecessary(this.a.yHeadRot, this.a.yBodyRot, 75);
|
this.a.yHeadRot = Mth.rotateIfNecessary(this.a.yHeadRot, this.a.yBodyRot, 75);
|
||||||
@ -83,7 +82,7 @@ public class PlayerLookControl {
|
|||||||
this.tz = var4;
|
this.tz = var4;
|
||||||
this.tyaw = var6;
|
this.tyaw = var6;
|
||||||
this.tpitch = var7;
|
this.tpitch = var7;
|
||||||
this.move = true;
|
this.looking = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void a(Entity var0, float var1, float var2) {
|
public void a(Entity var0, float var1, float var2) {
|
||||||
@ -99,7 +98,7 @@ public class PlayerLookControl {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public boolean c() {
|
public boolean c() {
|
||||||
return this.move;
|
return this.looking;
|
||||||
}
|
}
|
||||||
|
|
||||||
public double d() {
|
public double d() {
|
||||||
|
@ -15,20 +15,20 @@ import net.minecraft.world.entity.monster.Slime;
|
|||||||
|
|
||||||
public class PlayerMoveControl extends MoveControl {
|
public class PlayerMoveControl extends MoveControl {
|
||||||
protected LivingEntity a;
|
protected LivingEntity a;
|
||||||
protected double b;
|
|
||||||
protected double c;
|
|
||||||
protected double d;
|
|
||||||
protected double e;
|
|
||||||
protected boolean f;
|
|
||||||
private int h;
|
private int h;
|
||||||
|
protected boolean moving;
|
||||||
|
protected double speed;
|
||||||
|
protected double tx;
|
||||||
|
protected double ty;
|
||||||
|
protected double tz;
|
||||||
|
|
||||||
public PlayerMoveControl(LivingEntity entityinsentient) {
|
public PlayerMoveControl(LivingEntity entityinsentient) {
|
||||||
super(entityinsentient instanceof Mob ? (Mob) entityinsentient
|
super(entityinsentient instanceof Mob ? (Mob) entityinsentient
|
||||||
: new Slime(EntityType.SLIME, entityinsentient.level));
|
: new Slime(EntityType.SLIME, entityinsentient.level));
|
||||||
this.a = entityinsentient;
|
this.a = entityinsentient;
|
||||||
this.b = entityinsentient.getX();
|
this.tx = entityinsentient.getX();
|
||||||
this.c = entityinsentient.getY();
|
this.ty = entityinsentient.getY();
|
||||||
this.d = entityinsentient.getZ();
|
this.tz = entityinsentient.getZ();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected int cg() {
|
protected int cg() {
|
||||||
@ -37,27 +37,27 @@ public class PlayerMoveControl extends MoveControl {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public double getSpeedModifier() {
|
public double getSpeedModifier() {
|
||||||
return this.e;
|
return this.speed;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public double getWantedX() {
|
public double getWantedX() {
|
||||||
return this.b;
|
return this.tx;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public double getWantedY() {
|
public double getWantedY() {
|
||||||
return this.c;
|
return this.ty;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public double getWantedZ() {
|
public double getWantedZ() {
|
||||||
return this.d;
|
return this.tz;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean hasWanted() {
|
public boolean hasWanted() {
|
||||||
return this.f;
|
return this.moving;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -85,11 +85,11 @@ public class PlayerMoveControl extends MoveControl {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setWantedPosition(double d0, double d1, double d2, double d3) {
|
public void setWantedPosition(double d0, double d1, double d2, double d3) {
|
||||||
this.b = d0;
|
this.tx = d0;
|
||||||
this.c = d1;
|
this.ty = d1;
|
||||||
this.d = d2;
|
this.tz = d2;
|
||||||
this.e = d3;
|
this.speed = d3;
|
||||||
this.f = true;
|
this.moving = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean shouldSlimeJump() {
|
private boolean shouldSlimeJump() {
|
||||||
@ -105,26 +105,25 @@ public class PlayerMoveControl extends MoveControl {
|
|||||||
@Override
|
@Override
|
||||||
public void tick() {
|
public void tick() {
|
||||||
this.a.zza = 0;
|
this.a.zza = 0;
|
||||||
if (this.f) {
|
if (this.moving) {
|
||||||
this.f = false;
|
this.moving = false;
|
||||||
int i = Mth.floor(this.a.getBoundingBox().minY + 0.5D);
|
double dX = this.tx - this.a.getX();
|
||||||
double d0 = this.b - this.a.getX();
|
double dZ = this.tz - this.a.getZ();
|
||||||
double d1 = this.d - this.a.getZ();
|
double dY = this.ty - this.a.getY();
|
||||||
double d2 = this.c - i;
|
double dXZ = dY * dY + dZ * dZ;
|
||||||
double d3 = d0 * d0 + d2 * d2 + d1 * d1;
|
if (dY * dY < 1.0 && dXZ < 2.500000277905201E-007D) {
|
||||||
if (d3 < 2.500000277905201E-007D) {
|
|
||||||
this.a.zza = 0.0F;
|
this.a.zza = 0.0F;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
float f = (float) Math.toDegrees(Math.atan2(d1, d0)) - 90.0F;
|
float f = (float) Math.toDegrees(Mth.atan2(dZ, dX)) - 90.0F;
|
||||||
this.a.setYRot(rotlerp(this.a.getYRot(), f, 90.0F));
|
this.a.setYRot(rotlerp(this.a.getYRot(), f, 90.0F));
|
||||||
NMS.setHeadYaw(a.getBukkitEntity(), this.a.getYRot());
|
NMS.setHeadYaw(a.getBukkitEntity(), this.a.getYRot());
|
||||||
AttributeInstance speed = this.a.getAttribute(Attributes.MOVEMENT_SPEED);
|
AttributeInstance speed = this.a.getAttribute(Attributes.MOVEMENT_SPEED);
|
||||||
speed.setBaseValue(0.3D * this.e);
|
speed.setBaseValue(0.3D * this.speed);
|
||||||
float movement = (float) (this.e * speed.getValue());
|
float movement = (float) (this.speed * speed.getValue());
|
||||||
this.a.setSpeed(movement);
|
this.a.setSpeed(movement);
|
||||||
this.a.zza = movement;
|
this.a.zza = movement;
|
||||||
if (shouldSlimeJump() || (d2 >= NMS.getStepHeight(a.getBukkitEntity()) && (d0 * d0 + d1 * d1) < 1.0D)) {
|
if (shouldSlimeJump() || (dY >= NMS.getStepHeight(a.getBukkitEntity()) && dXZ < 1.0D)) {
|
||||||
this.h = cg();
|
this.h = cg();
|
||||||
this.h /= 3;
|
this.h /= 3;
|
||||||
if (this.a instanceof EntityHumanNPC) {
|
if (this.a instanceof EntityHumanNPC) {
|
||||||
|
Loading…
Reference in New Issue
Block a user