Add some waypoint triggers

This commit is contained in:
fullwall 2012-10-15 17:13:34 +08:00
parent c9f054b615
commit db403bbcf0
7 changed files with 134 additions and 75 deletions

View File

@ -34,6 +34,18 @@ public class Controllable extends Trait implements Toggleable, CommandConfigurab
super("controllable"); super("controllable");
} }
@Override
public void configure(CommandContext args) {
if (args.hasFlag('f'))
explicitType = EntityType.BLAZE;
else if (args.hasFlag('n'))
explicitType = null;
else if (args.hasValueFlag("explicittype"))
explicitType = Util.matchEntityType(args.getFlag("explicittype"));
if (npc.isSpawned())
loadController();
}
private void enterOrLeaveVehicle(Player player) { private void enterOrLeaveVehicle(Player player) {
EntityPlayer handle = ((CraftPlayer) player).getHandle(); EntityPlayer handle = ((CraftPlayer) player).getHandle();
if (getHandle().passenger != null) { if (getHandle().passenger != null) {
@ -58,6 +70,34 @@ public class Controllable extends Trait implements Toggleable, CommandConfigurab
explicitType = Util.matchEntityType(key.getString("explicittype")); explicitType = Util.matchEntityType(key.getString("explicittype"));
} }
private void loadController() {
EntityType type = npc.getBukkitEntity().getType();
if (explicitType != null)
type = explicitType;
Class<? extends Controller> clazz = controllerTypes.get(type);
if (clazz == null) {
controller = new GroundController();
return;
}
Constructor<? extends Controller> innerConstructor = null;
try {
innerConstructor = clazz.getConstructor(Controllable.class);
innerConstructor.setAccessible(true);
} catch (Exception e) {
e.printStackTrace();
}
try {
if (innerConstructor == null) {
controller = clazz.newInstance();
} else
controller = innerConstructor.newInstance(this);
} catch (Exception e) {
e.printStackTrace();
controller = new GroundController();
}
}
public boolean mount(Player toMount) { public boolean mount(Player toMount) {
if (npc.getBukkitEntity().getPassenger() != null) if (npc.getBukkitEntity().getPassenger() != null)
return false; return false;
@ -99,34 +139,6 @@ public class Controllable extends Trait implements Toggleable, CommandConfigurab
loadController(); loadController();
} }
private void loadController() {
EntityType type = npc.getBukkitEntity().getType();
if (explicitType != null)
type = explicitType;
Class<? extends Controller> clazz = controllerTypes.get(type);
if (clazz == null) {
controller = new GroundController();
return;
}
Constructor<? extends Controller> innerConstructor = null;
try {
innerConstructor = clazz.getConstructor(Controllable.class);
innerConstructor.setAccessible(true);
} catch (Exception e) {
e.printStackTrace();
}
try {
if (innerConstructor == null) {
controller = clazz.newInstance();
} else
controller = innerConstructor.newInstance(this);
} catch (Exception e) {
e.printStackTrace();
controller = new GroundController();
}
}
@Override @Override
public void run() { public void run() {
if (!enabled || !npc.isSpawned() || getHandle().passenger == null) if (!enabled || !npc.isSpawned() || getHandle().passenger == null)
@ -236,16 +248,4 @@ public class Controllable extends Trait implements Toggleable, CommandConfigurab
controllerTypes.put(EntityType.ENDER_DRAGON, AirController.class); controllerTypes.put(EntityType.ENDER_DRAGON, AirController.class);
controllerTypes.put(EntityType.GHAST, AirController.class); controllerTypes.put(EntityType.GHAST, AirController.class);
} }
@Override
public void configure(CommandContext args) {
if (args.hasFlag('f'))
explicitType = EntityType.BLAZE;
else if (args.hasFlag('n'))
explicitType = null;
else if (args.hasValueFlag("explicittype"))
explicitType = Util.matchEntityType(args.getFlag("explicittype"));
if (npc.isSpawned())
loadController();
}
} }

View File

@ -0,0 +1,33 @@
package net.citizensnpcs.trait.waypoint;
import net.citizensnpcs.api.CitizensAPI;
import net.citizensnpcs.api.npc.NPC;
import net.citizensnpcs.api.persistence.Persist;
import org.bukkit.Bukkit;
import org.bukkit.Location;
public class DelayWaypointTrigger implements WaypointTrigger {
@Persist
private int delay = 0;
@Override
public void onWaypointReached(NPC npc, Location waypoint) {
if (delay > 0)
scheduleTask(npc.getTrait(Waypoints.class).getCurrentProvider());
}
private void scheduleTask(final WaypointProvider provider) {
provider.setPaused(true);
Bukkit.getScheduler().scheduleSyncDelayedTask(CitizensAPI.getPlugin(), new Runnable() {
@Override
public void run() {
provider.setPaused(false);
}
}, delay);
}
public void setDelay(int newDelay) {
delay = newDelay;
}
}

View File

@ -4,8 +4,6 @@ import java.util.Iterator;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import javax.annotation.Nullable;
import net.citizensnpcs.api.CitizensAPI; import net.citizensnpcs.api.CitizensAPI;
import net.citizensnpcs.api.ai.Goal; import net.citizensnpcs.api.ai.Goal;
import net.citizensnpcs.api.ai.GoalSelector; import net.citizensnpcs.api.ai.GoalSelector;
@ -36,8 +34,6 @@ import org.bukkit.event.player.PlayerInteractEvent;
import org.bukkit.event.player.PlayerItemHeldEvent; import org.bukkit.event.player.PlayerItemHeldEvent;
import org.bukkit.metadata.FixedMetadataValue; import org.bukkit.metadata.FixedMetadataValue;
import com.google.common.base.Function;
import com.google.common.collect.Iterators;
import com.google.common.collect.Lists; import com.google.common.collect.Lists;
import com.google.common.collect.Maps; import com.google.common.collect.Maps;
@ -280,14 +276,14 @@ public class LinearWaypointProvider implements WaypointProvider {
} }
private class LinearWaypointGoal implements Goal { private class LinearWaypointGoal implements Goal {
private Location currentDestination; private Waypoint currentDestination;
private Iterator<Location> itr; private Iterator<Waypoint> itr;
private boolean paused; private boolean paused;
private GoalSelector selector; private GoalSelector selector;
private void ensureItr() { private void ensureItr() {
if (itr == null || !itr.hasNext()) if (itr == null || !itr.hasNext())
itr = Iterators.transform(waypoints.iterator(), WAYPOINT_TRANSFORMER); itr = waypoints.iterator();
} }
private Navigator getNavigator() { private Navigator getNavigator() {
@ -303,10 +299,12 @@ public class LinearWaypointProvider implements WaypointProvider {
if (selector == null || !event.getNavigator().equals(getNavigator())) if (selector == null || !event.getNavigator().equals(getNavigator()))
return; return;
selector.finish(); selector.finish();
if (event.getNavigator().getTargetAsLocation().equals(currentDestination.getLocation()))
currentDestination.onReach(npc);
} }
public void onProviderChanged() { public void onProviderChanged() {
itr = Iterators.transform(waypoints.iterator(), WAYPOINT_TRANSFORMER); itr = waypoints.iterator();
if (currentDestination != null) if (currentDestination != null)
selector.finish(); selector.finish();
} }
@ -336,7 +334,7 @@ public class LinearWaypointProvider implements WaypointProvider {
return false; return false;
} }
if (waypoints.size() == 1) { if (waypoints.size() == 1) {
// avoid pathing to the same point and wasting memory. // avoid pathing to the same point repeatedly
Location dest = npc.getBukkitEntity().getLocation(); Location dest = npc.getBukkitEntity().getLocation();
if (waypoints.get(0).getLocation().distanceSquared(dest) < 3) if (waypoints.get(0).getLocation().distanceSquared(dest) < 3)
return false; return false;
@ -346,16 +344,9 @@ public class LinearWaypointProvider implements WaypointProvider {
if (shouldExecute) { if (shouldExecute) {
this.selector = selector; this.selector = selector;
currentDestination = itr.next(); currentDestination = itr.next();
getNavigator().setTarget(currentDestination); getNavigator().setTarget(currentDestination.getLocation());
} }
return shouldExecute; return shouldExecute;
} }
} }
private static final Function<Waypoint, Location> WAYPOINT_TRANSFORMER = new Function<Waypoint, Location>() {
@Override
public Location apply(@Nullable Waypoint input) {
return input == null ? null : input.getLocation();
}
};
} }

View File

@ -0,0 +1,17 @@
package net.citizensnpcs.trait.waypoint;
import net.citizensnpcs.api.npc.NPC;
import net.citizensnpcs.api.persistence.Persist;
import org.bukkit.Location;
public class TeleportWaypointTrigger implements WaypointTrigger {
@Persist
private Location location;
@Override
public void onWaypointReached(NPC npc, Location waypoint) {
if (location != null)
npc.getBukkitEntity().teleport(waypoint);
}
}

View File

@ -2,6 +2,7 @@ package net.citizensnpcs.trait.waypoint;
import java.util.List; import java.util.List;
import net.citizensnpcs.api.npc.NPC;
import net.citizensnpcs.api.persistence.Persist; import net.citizensnpcs.api.persistence.Persist;
import net.citizensnpcs.api.persistence.PersistenceLoader; import net.citizensnpcs.api.persistence.PersistenceLoader;
@ -24,7 +25,12 @@ public class Waypoint {
return location; return location;
} }
public void onReach(NPC npc) {
for (WaypointTrigger trigger : triggers)
trigger.onWaypointReached(npc, location);
}
static { static {
PersistenceLoader.registerPersistDelegate(WaypointTrigger.class, WaypointTriggerPersister.class); PersistenceLoader.registerPersistDelegate(WaypointTrigger.class, WaypointTriggerRegistry.class);
} }
} }

View File

@ -1,17 +0,0 @@
package net.citizensnpcs.trait.waypoint;
import net.citizensnpcs.api.persistence.Persister;
import net.citizensnpcs.api.util.DataKey;
public class WaypointTriggerPersister implements Persister {
@Override
public Object create(DataKey root) {
// TODO Auto-generated method stub
return null;
}
@Override
public void save(Object instance, DataKey root) {
// TODO Auto-generated method stub
}
}

View File

@ -0,0 +1,29 @@
package net.citizensnpcs.trait.waypoint;
import java.util.Map;
import net.citizensnpcs.api.persistence.PersistenceLoader;
import net.citizensnpcs.api.persistence.Persister;
import net.citizensnpcs.api.util.DataKey;
import com.google.common.collect.Maps;
public class WaypointTriggerRegistry implements Persister {
@Override
public Object create(DataKey root) {
String type = root.getString("type");
Class<? extends WaypointTrigger> clazz = triggers.get(type);
return clazz == null ? null : PersistenceLoader.load(clazz, root);
}
@Override
public void save(Object instance, DataKey root) {
PersistenceLoader.save(instance, root);
}
private static final Map<String, Class<? extends WaypointTrigger>> triggers = Maps.newHashMap();
static {
triggers.put("teleport", TeleportWaypointTrigger.class);
triggers.put("delay", DelayWaypointTrigger.class);
}
}