Added support for vehicles.
This commit is contained in:
parent
e36519c246
commit
8b873a6d60
@ -21,9 +21,12 @@ import java.util.HashMap;
|
|||||||
|
|
||||||
import de.craftinc.gates.util.ConfigurationUtil;
|
import de.craftinc.gates.util.ConfigurationUtil;
|
||||||
import de.craftinc.gates.util.GateBlockChangeSender;
|
import de.craftinc.gates.util.GateBlockChangeSender;
|
||||||
|
import de.craftinc.gates.util.VehicleCloner;
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.entity.Entity;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.entity.Vehicle;
|
||||||
import org.bukkit.event.EventHandler;
|
import org.bukkit.event.EventHandler;
|
||||||
import org.bukkit.event.EventPriority;
|
import org.bukkit.event.EventPriority;
|
||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
@ -32,6 +35,7 @@ import org.bukkit.event.player.PlayerMoveEvent;
|
|||||||
import de.craftinc.gates.Gate;
|
import de.craftinc.gates.Gate;
|
||||||
import de.craftinc.gates.GatesManager;
|
import de.craftinc.gates.GatesManager;
|
||||||
import de.craftinc.gates.Plugin;
|
import de.craftinc.gates.Plugin;
|
||||||
|
import org.bukkit.scheduler.BukkitScheduler;
|
||||||
|
|
||||||
|
|
||||||
public class PlayerMoveListener implements Listener
|
public class PlayerMoveListener implements Listener
|
||||||
@ -49,8 +53,8 @@ public class PlayerMoveListener implements Listener
|
|||||||
GateBlockChangeSender.updateGateBlocks(event.getPlayer(), event.getTo());
|
GateBlockChangeSender.updateGateBlocks(event.getPlayer(), event.getTo());
|
||||||
}
|
}
|
||||||
|
|
||||||
GatesManager gateManager = Plugin.getPlugin().getGatesManager();
|
final GatesManager gateManager = Plugin.getPlugin().getGatesManager();
|
||||||
Gate gateAtLocation = gateManager.getGateAtLocation(event.getTo());
|
final Gate gateAtLocation = gateManager.getGateAtLocation(event.getTo());
|
||||||
|
|
||||||
if ((gateAtLocation == null) || !gateAtLocation.isOpen()) {
|
if ((gateAtLocation == null) || !gateAtLocation.isOpen()) {
|
||||||
return;
|
return;
|
||||||
@ -60,19 +64,19 @@ public class PlayerMoveListener implements Listener
|
|||||||
if (!hasPermission(event.getPlayer(), gateAtLocation)
|
if (!hasPermission(event.getPlayer(), gateAtLocation)
|
||||||
&& Plugin.getPlugin().getConfig().getBoolean(ConfigurationUtil.confShowTeleportNoPermissionMessageKey)) {
|
&& Plugin.getPlugin().getConfig().getBoolean(ConfigurationUtil.confShowTeleportNoPermissionMessageKey)) {
|
||||||
|
|
||||||
String playerName = event.getPlayer().getName();
|
final String playerName = event.getPlayer().getName();
|
||||||
|
|
||||||
if (playerName == null) {
|
if (playerName == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// get the current time
|
// get the current time
|
||||||
Long now = Calendar.getInstance().getTimeInMillis();
|
final Long now = Calendar.getInstance().getTimeInMillis();
|
||||||
|
|
||||||
// do not display messages more often than once per second
|
// do not display messages more often than once per second
|
||||||
if (!this.lastNoPermissionMessages.containsKey(playerName) || this.lastNoPermissionMessages.get(playerName) < now - 10000L) {
|
if (!this.lastNoPermissionMessages.containsKey(playerName) || this.lastNoPermissionMessages.get(playerName) < now - 10000L) {
|
||||||
|
|
||||||
String noPermissionString = Plugin.getPlugin().getConfig().getString(ConfigurationUtil.confGateTeleportNoPermissionMessageKey);
|
final String noPermissionString = Plugin.getPlugin().getConfig().getString(ConfigurationUtil.confGateTeleportNoPermissionMessageKey);
|
||||||
event.getPlayer().sendMessage(ChatColor.RED + noPermissionString);
|
event.getPlayer().sendMessage(ChatColor.RED + noPermissionString);
|
||||||
this.lastNoPermissionMessages.put(playerName, now);
|
this.lastNoPermissionMessages.put(playerName, now);
|
||||||
}
|
}
|
||||||
@ -85,38 +89,68 @@ public class PlayerMoveListener implements Listener
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Teleports a player.
|
* Teleports a player.
|
||||||
* @param p The player to teleport.
|
* @param player The player to teleport.
|
||||||
* @param g The gate to which exit the player will be teleported.
|
* @param gate The gate to which exit the player will be teleported.
|
||||||
*/
|
*/
|
||||||
private void teleportPlayer(Player p, Gate g)
|
private void teleportPlayer(final Player player, final Gate gate)
|
||||||
{
|
{
|
||||||
Float newYaw = g.getExit().getYaw() - g.getLocation().getYaw() + p.getLocation().getYaw();
|
// Destination
|
||||||
|
final Float newYaw = gate.getExit().getYaw() - gate.getLocation().getYaw() + player.getLocation().getYaw();
|
||||||
Location destLocation = new Location( g.getExit().getWorld(),
|
final Location destLocation = new Location( gate.getExit().getWorld(),
|
||||||
g.getExit().getX(),
|
gate.getExit().getX(),
|
||||||
g.getExit().getY(),
|
gate.getExit().getY(),
|
||||||
g.getExit().getZ(),
|
gate.getExit().getZ(),
|
||||||
newYaw,
|
newYaw,
|
||||||
p.getLocation().getPitch()
|
player.getLocation().getPitch()
|
||||||
);
|
);
|
||||||
|
|
||||||
p.teleport(destLocation);
|
// Riding (eject player)
|
||||||
|
final Entity vehicle = player.getVehicle();
|
||||||
|
final boolean vehicleIsSuitable = (vehicle != null) && (vehicle instanceof Vehicle);
|
||||||
|
|
||||||
|
if (vehicleIsSuitable) {
|
||||||
|
vehicle.eject();
|
||||||
|
vehicle.remove();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Teleport
|
||||||
|
player.teleport(destLocation);
|
||||||
|
|
||||||
|
// Riding (mount player)
|
||||||
|
if (vehicleIsSuitable) {
|
||||||
|
final Plugin plugin = Plugin.getPlugin();
|
||||||
|
final BukkitScheduler scheduler = plugin.getServer().getScheduler();
|
||||||
|
|
||||||
|
destLocation.getChunk().load(); // load the destination chunk, no new entity will be created otherwise
|
||||||
|
|
||||||
|
scheduler.scheduleSyncDelayedTask(plugin, new Runnable() {
|
||||||
|
public void run()
|
||||||
|
{
|
||||||
|
// TODO: the code below should be executed after the chunk got loaded and not after a fixed time!
|
||||||
|
|
||||||
|
// create a new entity at the destination location
|
||||||
|
final Vehicle newVehicle = VehicleCloner.clone((Vehicle)vehicle, destLocation);
|
||||||
|
newVehicle.setPassenger(player);
|
||||||
|
}
|
||||||
|
}, 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Message
|
||||||
if (Plugin.getPlugin().getConfig().getBoolean(ConfigurationUtil.confShowTeleportMessageKey)) {
|
if (Plugin.getPlugin().getConfig().getBoolean(ConfigurationUtil.confShowTeleportMessageKey)) {
|
||||||
String teleportMessage = Plugin.getPlugin().getConfig().getString(ConfigurationUtil.confGateTeleportMessageKey);
|
final String teleportMessage = Plugin.getPlugin().getConfig().getString(ConfigurationUtil.confGateTeleportMessageKey);
|
||||||
p.sendMessage(ChatColor.DARK_AQUA + teleportMessage);
|
player.sendMessage(ChatColor.DARK_AQUA + teleportMessage);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
protected boolean hasPermission(Player player, Gate gate)
|
protected boolean hasPermission(final Player player, final Gate gate)
|
||||||
{
|
{
|
||||||
if (Plugin.getPermission() == null) { // fallback: use the standard bukkit permission system
|
if (Plugin.getPermission() == null) { // fallback: use the standard bukkit permission system
|
||||||
return player.hasPermission(Plugin.permissionUse);
|
return player.hasPermission(Plugin.permissionUse);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
boolean permAtLocation = Plugin.getPermission().has(gate.getLocation().getWorld(), player.getName(), Plugin.permissionUse);
|
final boolean permAtLocation = Plugin.getPermission().has(gate.getLocation().getWorld(), player.getName(), Plugin.permissionUse);
|
||||||
boolean permAtExit = Plugin.getPermission().has(gate.getExit().getWorld(), player.getName(), Plugin.permissionUse);
|
final boolean permAtExit = Plugin.getPermission().has(gate.getExit().getWorld(), player.getName(), Plugin.permissionUse);
|
||||||
|
|
||||||
return permAtLocation && permAtExit;
|
return permAtLocation && permAtExit;
|
||||||
}
|
}
|
||||||
|
105
src/de/craftinc/gates/util/VehicleCloner.java
Normal file
105
src/de/craftinc/gates/util/VehicleCloner.java
Normal file
@ -0,0 +1,105 @@
|
|||||||
|
/* Craft Inc. Gates
|
||||||
|
Copyright (C) 2011-2013 Craft Inc. Gates Team (see AUTHORS.txt)
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU Lesser General Public License as published
|
||||||
|
by the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
|
along with this program (LGPLv3). If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
package de.craftinc.gates.util;
|
||||||
|
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.entity.*;
|
||||||
|
|
||||||
|
|
||||||
|
public class VehicleCloner
|
||||||
|
{
|
||||||
|
public static Vehicle clone(Vehicle parent, Location cloneLocation)
|
||||||
|
{
|
||||||
|
Vehicle clone = cloneLocation.getWorld().spawn(cloneLocation, parent.getClass());
|
||||||
|
|
||||||
|
clone.setFallDistance(parent.getFallDistance());
|
||||||
|
clone.setFireTicks(parent.getFireTicks());
|
||||||
|
clone.setVelocity(parent.getVelocity());
|
||||||
|
clone.setTicksLived(parent.getTicksLived());
|
||||||
|
clone.setLastDamageCause(parent.getLastDamageCause());
|
||||||
|
|
||||||
|
if (clone instanceof Boat) {
|
||||||
|
Boat boat = (Boat)clone;
|
||||||
|
Boat parentBoat = (Boat)parent;
|
||||||
|
|
||||||
|
boat.setMaxSpeed(parentBoat.getMaxSpeed());
|
||||||
|
boat.setOccupiedDeceleration(parentBoat.getOccupiedDeceleration());
|
||||||
|
boat.setUnoccupiedDeceleration(parentBoat.getUnoccupiedDeceleration());
|
||||||
|
boat.setWorkOnLand(parentBoat.getWorkOnLand());
|
||||||
|
}
|
||||||
|
else if (clone instanceof Horse) {
|
||||||
|
Horse horse = (Horse)clone;
|
||||||
|
Horse parentHorse = (Horse)parent;
|
||||||
|
|
||||||
|
horse.getInventory().setArmor(parentHorse.getInventory().getArmor());
|
||||||
|
horse.getInventory().setSaddle(parentHorse.getInventory().getSaddle());
|
||||||
|
horse.setCarryingChest(parentHorse.isCarryingChest());
|
||||||
|
horse.getInventory().setContents(parentHorse.getInventory().getContents());
|
||||||
|
horse.setTamed(parentHorse.isTamed());
|
||||||
|
horse.setOwner(parentHorse.getOwner());
|
||||||
|
horse.setJumpStrength(parentHorse.getJumpStrength());
|
||||||
|
horse.setMaxDomestication(parentHorse.getMaxDomestication());
|
||||||
|
horse.setDomestication(parentHorse.getDomestication());
|
||||||
|
horse.setStyle(parentHorse.getStyle());
|
||||||
|
horse.setColor(parentHorse.getColor());
|
||||||
|
horse.setVariant(parentHorse.getVariant());
|
||||||
|
horse.setMaxHealth(parentHorse.getMaxHealth());
|
||||||
|
horse.setHealth(parentHorse.getMaxHealth());
|
||||||
|
horse.setRemainingAir(parentHorse.getRemainingAir());
|
||||||
|
horse.setMaximumAir(parentHorse.getMaximumAir());
|
||||||
|
horse.setMaximumNoDamageTicks(parentHorse.getMaximumNoDamageTicks());
|
||||||
|
horse.setLastDamage(parentHorse.getLastDamage());
|
||||||
|
horse.setNoDamageTicks(parentHorse.getNoDamageTicks());
|
||||||
|
horse.addPotionEffects(parentHorse.getActivePotionEffects());
|
||||||
|
horse.setRemoveWhenFarAway(parentHorse.getRemoveWhenFarAway());
|
||||||
|
horse.setCanPickupItems(parentHorse.getCanPickupItems());
|
||||||
|
horse.setCustomName(parentHorse.getCustomName());
|
||||||
|
horse.setCustomNameVisible(parentHorse.isCustomNameVisible());
|
||||||
|
horse.setTarget(parentHorse.getTarget());
|
||||||
|
horse.setAge(parentHorse.getAge());
|
||||||
|
horse.setAgeLock(parentHorse.getAgeLock());
|
||||||
|
|
||||||
|
if (parentHorse.isAdult()) {
|
||||||
|
horse.setAdult();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
horse.setBaby();
|
||||||
|
}
|
||||||
|
|
||||||
|
horse.setBreed(parentHorse.canBreed());
|
||||||
|
}
|
||||||
|
else if (clone instanceof Minecart) {
|
||||||
|
Minecart minecart = (Minecart)clone;
|
||||||
|
Minecart parentMinecart = (Minecart)parent;
|
||||||
|
|
||||||
|
minecart.setDerailedVelocityMod(parentMinecart.getDerailedVelocityMod());
|
||||||
|
minecart.setFlyingVelocityMod(parentMinecart.getFlyingVelocityMod());
|
||||||
|
minecart.setSlowWhenEmpty(parentMinecart.isSlowWhenEmpty());
|
||||||
|
minecart.setMaxSpeed(parentMinecart.getMaxSpeed());
|
||||||
|
minecart.setDamage(parentMinecart.getDamage());
|
||||||
|
}
|
||||||
|
else if (clone instanceof Pig) {
|
||||||
|
Pig pig = (Pig)clone;
|
||||||
|
Pig parentPig = (Pig)parent;
|
||||||
|
|
||||||
|
pig.setSaddle(parentPig.hasSaddle());
|
||||||
|
}
|
||||||
|
|
||||||
|
return clone;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user