Gives all passengers the same exit velocity as the root vehicle
This commit is contained in:
@@ -49,6 +49,10 @@ public class PlayerTeleporter extends Teleporter {
|
||||
}
|
||||
}
|
||||
|
||||
//Calculate the exit velocity of the player
|
||||
Vector newVelocityDirection = DirectionHelper.getDirectionVectorFromYaw(portal.getYaw());
|
||||
Vector newVelocity = newVelocityDirection.multiply(velocity * Stargate.getGateConfig().getExitVelocity());
|
||||
|
||||
//Load chunks to make sure not to teleport to the void
|
||||
loadChunks();
|
||||
|
||||
@@ -56,7 +60,7 @@ public class PlayerTeleporter extends Teleporter {
|
||||
TeleportHelper.teleportLeashedCreatures(player, origin, portal);
|
||||
|
||||
if (player.eject()) {
|
||||
TeleportHelper.handleEntityPassengers(passengers, player, origin, portal, exit.getDirection());
|
||||
TeleportHelper.handleEntityPassengers(passengers, player, origin, portal, exit.getDirection(), newVelocity);
|
||||
}
|
||||
|
||||
//If no event is passed in, assume it's a teleport, and act as such
|
||||
@@ -69,8 +73,6 @@ public class PlayerTeleporter extends Teleporter {
|
||||
|
||||
//Set the velocity of the teleported player after the teleportation is finished
|
||||
Bukkit.getScheduler().scheduleSyncDelayedTask(Stargate.getInstance(), () -> {
|
||||
Vector newVelocityDirection = DirectionHelper.getDirectionVectorFromYaw(portal.getYaw());
|
||||
Vector newVelocity = newVelocityDirection.multiply(velocity * Stargate.getGateConfig().getExitVelocity());
|
||||
player.setVelocity(newVelocity);
|
||||
}, 1);
|
||||
}
|
||||
|
@@ -19,6 +19,7 @@ import org.bukkit.entity.AbstractHorse;
|
||||
import org.bukkit.entity.Entity;
|
||||
import org.bukkit.event.Event;
|
||||
import org.bukkit.scheduler.BukkitScheduler;
|
||||
import org.bukkit.util.Vector;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
@@ -83,7 +84,8 @@ public abstract class Teleporter {
|
||||
loadChunks();
|
||||
|
||||
if (teleportedEntity.eject()) {
|
||||
TeleportHelper.handleEntityPassengers(passengers, teleportedEntity, origin, portal, exit.getDirection());
|
||||
TeleportHelper.handleEntityPassengers(passengers, teleportedEntity, origin, portal, exit.getDirection(),
|
||||
new Vector());
|
||||
}
|
||||
teleportedEntity.teleport(exit);
|
||||
return true;
|
||||
|
@@ -133,7 +133,8 @@ public class VehicleTeleporter extends EntityTeleporter {
|
||||
*/
|
||||
private void teleportVehicle(List<Entity> passengers, Location exit, Vector newVelocity, Portal origin) {
|
||||
if (teleportingVehicle.eject()) {
|
||||
TeleportHelper.handleEntityPassengers(passengers, teleportingVehicle, origin, portal, exit.getDirection());
|
||||
TeleportHelper.handleEntityPassengers(passengers, teleportingVehicle, origin, portal, exit.getDirection(),
|
||||
newVelocity);
|
||||
}
|
||||
Stargate.debug("VehicleTeleporter::teleportVehicle", "Teleporting " + teleportingVehicle +
|
||||
" to final location " + exit + " with direction " + exit.getDirection());
|
||||
@@ -172,7 +173,8 @@ public class VehicleTeleporter extends EntityTeleporter {
|
||||
}
|
||||
//Remove the old vehicle
|
||||
if (teleportingVehicle.eject()) {
|
||||
TeleportHelper.handleEntityPassengers(passengers, newVehicle, origin, portal, exit.getDirection());
|
||||
TeleportHelper.handleEntityPassengers(passengers, newVehicle, origin, portal, exit.getDirection(),
|
||||
newVelocity);
|
||||
}
|
||||
teleportingVehicle.remove();
|
||||
scheduler.scheduleSyncDelayedTask(Stargate.getInstance(), () -> newVehicle.setVelocity(newVelocity), 1);
|
||||
|
Reference in New Issue
Block a user