mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-21 15:54:45 +01:00
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:
parent
258209b485
commit
b8b594d610
2 changed files with 108 additions and 0 deletions
|
@ -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() {
|
||||||
|
|
|
@ -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() {
|
||||||
|
|
Loading…
Add table
Reference in a new issue