PortalEvent additions

This re-adds some of the functionality that the TravelAgent API provided previously

By: Phoenix616 <mail@moep.tv>
This commit is contained in:
Bukkit/Spigot 2020-01-11 19:09:58 +01:00
parent 258209b485
commit b8b594d610
2 changed files with 108 additions and 0 deletions

View file

@ -14,11 +14,36 @@ import org.jetbrains.annotations.Nullable;
*/ */
public class EntityPortalEvent extends EntityTeleportEvent { public class EntityPortalEvent extends EntityTeleportEvent {
private static final HandlerList handlers = new HandlerList(); private static final HandlerList handlers = new HandlerList();
private int searchRadius = 128;
public EntityPortalEvent(@NotNull final Entity entity, @NotNull final Location from, @Nullable final Location to) { public EntityPortalEvent(@NotNull final Entity entity, @NotNull final Location from, @Nullable final Location to) {
super(entity, from, to); super(entity, from, to);
} }
public EntityPortalEvent(@NotNull Entity entity, @NotNull Location from, @Nullable Location to, int searchRadius) {
super(entity, from, to);
this.searchRadius = searchRadius;
}
/**
* Set the Block radius to search in for available portals.
*
* @param searchRadius the radius in which to search for a portal from the
* location
*/
public void setSearchRadius(int searchRadius) {
this.searchRadius = searchRadius;
}
/**
* Gets the search radius value for finding an available portal.
*
* @return the currently set search radius
*/
public int getSearchRadius() {
return searchRadius;
}
@NotNull @NotNull
@Override @Override
public HandlerList getHandlers() { public HandlerList getHandlers() {

View file

@ -14,6 +14,9 @@ import org.jetbrains.annotations.Nullable;
*/ */
public class PlayerPortalEvent extends PlayerTeleportEvent { public class PlayerPortalEvent extends PlayerTeleportEvent {
private static final HandlerList handlers = new HandlerList(); private static final HandlerList handlers = new HandlerList();
private int getSearchRadius = 128;
private boolean canCreatePortal = true;
private int creationRadius = 16;
public PlayerPortalEvent(@NotNull final Player player, @NotNull final Location from, @Nullable final Location to) { public PlayerPortalEvent(@NotNull final Player player, @NotNull final Location from, @Nullable final Location to) {
super(player, from, to); super(player, from, to);
@ -23,6 +26,86 @@ public class PlayerPortalEvent extends PlayerTeleportEvent {
super(player, from, to, cause); super(player, from, to, cause);
} }
public PlayerPortalEvent(@NotNull Player player, @NotNull Location from, @Nullable Location to, @NotNull TeleportCause cause, int getSearchRadius, boolean canCreatePortal, int creationRadius) {
super(player, from, to, cause);
this.getSearchRadius = getSearchRadius;
this.canCreatePortal = canCreatePortal;
this.creationRadius = creationRadius;
}
/**
* Set the Block radius to search in for available portals.
*
* @param searchRadius the radius in which to search for a portal from the
* location
*/
public void setSearchRadius(int searchRadius) {
this.getSearchRadius = searchRadius;
}
/**
* Gets the search radius value for finding an available portal.
*
* @return the currently set search radius
*/
public int getSearchRadius() {
return getSearchRadius;
}
/**
* Returns whether the server will attempt to create a destination portal or
* not.
*
* @return whether there should create be a destination portal created
*/
public boolean getCanCreatePortal() {
return canCreatePortal;
}
/**
* Sets whether the server should attempt to create a destination portal or
* not.
*
* @param canCreatePortal Sets whether there should be a destination portal
* created
*/
public void setCanCreatePortal(boolean canCreatePortal) {
this.canCreatePortal = canCreatePortal;
}
/**
* Sets the maximum radius the world is searched for a free space from the
* given location.
*
* If enough free space is found then the portal will be created there, if
* not it will force create with air-space at the target location.
*
* Does not apply to end portal target platforms which will always appear at
* the target location.
*
* @param creationRadius the radius in which to create a portal from the
* location
*/
public void setCreationRadius(int creationRadius) {
this.creationRadius = creationRadius;
}
/**
* Gets the maximum radius the world is searched for a free space from the
* given location.
*
* If enough free space is found then the portal will be created there, if
* not it will force create with air-space at the target location.
*
* Does not apply to end portal target platforms which will always appear at
* the target location.
*
* @return the currently set creation radius
*/
public int getCreationRadius() {
return creationRadius;
}
@NotNull @NotNull
@Override @Override
public HandlerList getHandlers() { public HandlerList getHandlers() {