mirror of
https://github.com/CitizensDev/Citizens2.git
synced 2025-01-07 17:08:25 +01:00
Implement pathfinding range methods in Navigator, make default range setting of 25F
This commit is contained in:
parent
bb812f699e
commit
585de19c25
@ -52,6 +52,7 @@ public class Settings {
|
|||||||
DATABASE_USERNAME("storage.database.username", ""),
|
DATABASE_USERNAME("storage.database.username", ""),
|
||||||
DEBUG_MODE("general.debug-mode", false),
|
DEBUG_MODE("general.debug-mode", false),
|
||||||
DEFAULT_LOOK_CLOSE("npc.default.look-close", false),
|
DEFAULT_LOOK_CLOSE("npc.default.look-close", false),
|
||||||
|
DEFAULT_PATHFINDING_RANGE("npc.pathing.default-pathfinding-range", 25F),
|
||||||
DEFAULT_RANDOM_TALKER("npc.default.random-talker", true),
|
DEFAULT_RANDOM_TALKER("npc.default.random-talker", true),
|
||||||
DEFAULT_TALK_CLOSE("npc.default.talk-close", false),
|
DEFAULT_TALK_CLOSE("npc.default.talk-close", false),
|
||||||
DEFAULT_TEXT("npc.default.text.0", "Hi, I'm <npc>!") {
|
DEFAULT_TEXT("npc.default.text.0", "Hi, I'm <npc>!") {
|
||||||
@ -90,6 +91,10 @@ public class Settings {
|
|||||||
return (Double) value;
|
return (Double) value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public float asFloat() {
|
||||||
|
return (Float) value;
|
||||||
|
}
|
||||||
|
|
||||||
public int asInt() {
|
public int asInt() {
|
||||||
return Integer.parseInt(value.toString());
|
return Integer.parseInt(value.toString());
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,7 @@ package net.citizensnpcs.npc.ai;
|
|||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import net.citizensnpcs.Settings.Setting;
|
||||||
import net.citizensnpcs.api.ai.EntityTarget;
|
import net.citizensnpcs.api.ai.EntityTarget;
|
||||||
import net.citizensnpcs.api.ai.Navigator;
|
import net.citizensnpcs.api.ai.Navigator;
|
||||||
import net.citizensnpcs.api.ai.TargetType;
|
import net.citizensnpcs.api.ai.TargetType;
|
||||||
@ -10,7 +11,9 @@ import net.citizensnpcs.api.ai.event.NavigationBeginEvent;
|
|||||||
import net.citizensnpcs.api.ai.event.NavigationCancelEvent;
|
import net.citizensnpcs.api.ai.event.NavigationCancelEvent;
|
||||||
import net.citizensnpcs.api.ai.event.NavigationReplaceEvent;
|
import net.citizensnpcs.api.ai.event.NavigationReplaceEvent;
|
||||||
import net.citizensnpcs.npc.CitizensNPC;
|
import net.citizensnpcs.npc.CitizensNPC;
|
||||||
|
import net.citizensnpcs.util.Messaging;
|
||||||
import net.minecraft.server.EntityLiving;
|
import net.minecraft.server.EntityLiving;
|
||||||
|
import net.minecraft.server.Navigation;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
@ -22,6 +25,7 @@ import com.google.common.collect.Maps;
|
|||||||
public class CitizensNavigator implements Navigator {
|
public class CitizensNavigator implements Navigator {
|
||||||
private PathStrategy executing;
|
private PathStrategy executing;
|
||||||
private final CitizensNPC npc;
|
private final CitizensNPC npc;
|
||||||
|
private float pathfindingRange = Setting.DEFAULT_PATHFINDING_RANGE.asFloat();
|
||||||
private float speed = -1;
|
private float speed = -1;
|
||||||
|
|
||||||
public CitizensNavigator(CitizensNPC npc) {
|
public CitizensNavigator(CitizensNPC npc) {
|
||||||
@ -41,6 +45,11 @@ public class CitizensNavigator implements Navigator {
|
|||||||
return executing instanceof EntityTarget ? (EntityTarget) executing : null;
|
return executing instanceof EntityTarget ? (EntityTarget) executing : null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public float getPathfindingRange() {
|
||||||
|
return pathfindingRange;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public float getSpeed() {
|
public float getSpeed() {
|
||||||
return speed;
|
return speed;
|
||||||
@ -83,6 +92,12 @@ public class CitizensNavigator implements Navigator {
|
|||||||
public void onSpawn() {
|
public void onSpawn() {
|
||||||
if (speed == -1)
|
if (speed == -1)
|
||||||
this.speed = getSpeedFor(npc.getHandle());
|
this.speed = getSpeedFor(npc.getHandle());
|
||||||
|
updatePathfindingRange();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setPathfindingRange(float newRange) {
|
||||||
|
pathfindingRange = newRange;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -123,8 +138,21 @@ public class CitizensNavigator implements Navigator {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void updatePathfindingRange() {
|
||||||
|
if (PATHFINDING_RANGE == null)
|
||||||
|
return;
|
||||||
|
Navigation navigation = npc.getHandle().al();
|
||||||
|
try {
|
||||||
|
PATHFINDING_RANGE.set(navigation, pathfindingRange);
|
||||||
|
} catch (Exception ex) {
|
||||||
|
Messaging.logF("Could not update pathfinding range: %s.", ex.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private static final float DEFAULT_SPEED = 0.7F;
|
private static final float DEFAULT_SPEED = 0.7F;
|
||||||
|
|
||||||
private static final Map<EntityType, Float> MOVEMENT_SPEEDS = Maps.newEnumMap(EntityType.class);
|
private static final Map<EntityType, Float> MOVEMENT_SPEEDS = Maps.newEnumMap(EntityType.class);
|
||||||
|
private static Field PATHFINDING_RANGE;
|
||||||
private static Field SPEED_FIELD;
|
private static Field SPEED_FIELD;
|
||||||
static {
|
static {
|
||||||
MOVEMENT_SPEEDS.put(EntityType.IRON_GOLEM, 0.15F);
|
MOVEMENT_SPEEDS.put(EntityType.IRON_GOLEM, 0.15F);
|
||||||
@ -139,8 +167,12 @@ public class CitizensNavigator implements Navigator {
|
|||||||
try {
|
try {
|
||||||
SPEED_FIELD = EntityLiving.class.getDeclaredField("bb");
|
SPEED_FIELD = EntityLiving.class.getDeclaredField("bb");
|
||||||
SPEED_FIELD.setAccessible(true);
|
SPEED_FIELD.setAccessible(true);
|
||||||
|
PATHFINDING_RANGE = Navigation.class.getDeclaredField("e");
|
||||||
|
PATHFINDING_RANGE.setAccessible(true);
|
||||||
} catch (Exception ex) {
|
} catch (Exception ex) {
|
||||||
ex.printStackTrace();
|
ex.printStackTrace();
|
||||||
|
PATHFINDING_RANGE = null;
|
||||||
|
SPEED_FIELD = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user