Improve PortalEvents

This commit is contained in:
Jake Potrebic 2022-12-15 10:33:34 -08:00
parent 850e3c2ea1
commit 40c7b09ed4
4 changed files with 136 additions and 2 deletions

View file

@ -14,6 +14,12 @@ public enum PortalType {
* This is an Ender portal. * This is an Ender portal.
*/ */
ENDER, ENDER,
// Paper start
/**
* This is an end gateway
*/
END_GATEWAY,
// Paper end
/** /**
* This is a custom Plugin portal. * This is a custom Plugin portal.

View file

@ -7,14 +7,25 @@ import org.jetbrains.annotations.NotNull;
/** /**
* Called when an entity comes into contact with a portal * Called when an entity comes into contact with a portal
* <p>
* Cancelling this event prevents any further processing of the portal for that tick.
* @see io.papermc.paper.event.entity.EntityInsideBlockEvent
*/ */
public class EntityPortalEnterEvent extends EntityEvent { public class EntityPortalEnterEvent extends EntityEvent implements org.bukkit.event.Cancellable { // Paper
private static final HandlerList handlers = new HandlerList(); private static final HandlerList handlers = new HandlerList();
private final Location location; private final Location location;
@Deprecated(since = "1.21") @io.papermc.paper.annotation.DoNotUse // Paper
public EntityPortalEnterEvent(@NotNull final Entity entity, @NotNull final Location location) { public EntityPortalEnterEvent(@NotNull final Entity entity, @NotNull final Location location) {
// Paper start
this(entity, location, org.bukkit.PortalType.CUSTOM);
}
@org.jetbrains.annotations.ApiStatus.Internal
public EntityPortalEnterEvent(@NotNull final Entity entity, @NotNull final Location location, @NotNull final org.bukkit.PortalType portalType) {
// Paper end
super(entity); super(entity);
this.location = location; this.location = location;
this.portalType = portalType; // Paper
} }
/** /**
@ -27,6 +38,30 @@ public class EntityPortalEnterEvent extends EntityEvent {
return location; return location;
} }
// Paper start
private boolean cancelled = false;
private final org.bukkit.PortalType portalType;
/**
* Get the portal type.
*
* @return the portal type
*/
public org.bukkit.@NotNull PortalType getPortalType() {
return this.portalType;
}
@Override
public boolean isCancelled() {
return this.cancelled;
}
@Override
public void setCancelled(final boolean cancel) {
this.cancelled = cancel;
}
// Paper end
@NotNull @NotNull
@Override @Override
public HandlerList getHandlers() { public HandlerList getHandlers() {

View file

@ -3,6 +3,7 @@ package org.bukkit.event.entity;
import org.bukkit.Location; import org.bukkit.Location;
import org.bukkit.entity.Entity; import org.bukkit.entity.Entity;
import org.bukkit.event.HandlerList; import org.bukkit.event.HandlerList;
import org.jetbrains.annotations.ApiStatus;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable; import org.jetbrains.annotations.Nullable;
@ -17,23 +18,68 @@ public class EntityPortalEvent extends EntityTeleportEvent {
private int searchRadius = 128; private int searchRadius = 128;
private boolean canCreatePortal = true; private boolean canCreatePortal = true;
private int creationRadius = 16; private int creationRadius = 16;
private final org.bukkit.PortalType type; // Paper
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); this(entity, from, to, 128); // Paper
} }
public EntityPortalEvent(@NotNull Entity entity, @NotNull Location from, @Nullable Location to, int searchRadius) { public EntityPortalEvent(@NotNull Entity entity, @NotNull Location from, @Nullable Location to, int searchRadius) {
super(entity, from, to); super(entity, from, to);
this.searchRadius = searchRadius; this.searchRadius = searchRadius;
this.type = org.bukkit.PortalType.CUSTOM; // Paper
} }
public EntityPortalEvent(@NotNull Entity entity, @NotNull Location from, @Nullable Location to, int searchRadius, boolean canCreatePortal, int creationRadius) { public EntityPortalEvent(@NotNull Entity entity, @NotNull Location from, @Nullable Location to, int searchRadius, boolean canCreatePortal, int creationRadius) {
// Paper start
this(entity, from, to, searchRadius, canCreatePortal, creationRadius, org.bukkit.PortalType.CUSTOM);
}
@ApiStatus.Internal
public EntityPortalEvent(@NotNull Entity entity, @NotNull Location from, @Nullable Location to, int searchRadius, boolean canCreatePortal, int creationRadius, final @NotNull org.bukkit.PortalType portalType) {
super(entity, from, to); super(entity, from, to);
this.type = portalType;
// Paper end
this.searchRadius = searchRadius; this.searchRadius = searchRadius;
this.canCreatePortal = canCreatePortal; this.canCreatePortal = canCreatePortal;
this.creationRadius = creationRadius; this.creationRadius = creationRadius;
} }
// Paper start
/**
* Get the portal type relating to this event.
*
* @return the portal type
*/
public @NotNull org.bukkit.PortalType getPortalType() {
return this.type;
}
/**
* For {@link org.bukkit.PortalType#NETHER}, this is initially just the starting point
* for the search for a portal to teleport to. It will initially just be the {@link #getFrom()}
* scaled for dimension scaling and clamped to be inside the world border.
* <p>
* For {@link org.bukkit.PortalType#ENDER}, this will initially be the exact destination
* either, the world spawn for <i>end->any world</i> or end spawn for <i>any world->end</i>.
*
* @return starting point for search or exact destination
*/
@Override
public @Nullable Location getTo() {
return super.getTo();
}
/**
* See the description of {@link #getTo()}.
* @param to starting point for search or exact destination
* or null to cancel
*/
@Override
public void setTo(@Nullable final Location to) {
super.setTo(to);
}
// Paper end
/** /**
* Set the Block radius to search in for available portals. * Set the Block radius to search in for available portals.
* *

View file

@ -32,6 +32,53 @@ public class PlayerPortalEvent extends PlayerTeleportEvent {
this.canCreatePortal = canCreatePortal; this.canCreatePortal = canCreatePortal;
this.creationRadius = creationRadius; this.creationRadius = creationRadius;
} }
// Paper start
/**
* For {@link TeleportCause#NETHER_PORTAL}, this is initially just the starting point
* for the search for a portal to teleport to. It will initially just be the {@link #getFrom()}
* scaled for dimension scaling and clamped to be inside the world border.
* <p>
* For {@link TeleportCause#END_PORTAL}, this will initially be the exact destination
* either, the world spawn for <i>end->any world</i> or end spawn for <i>any world->end</i>.
*
* @return starting point for search or exact destination
*/
@Override
public @NotNull Location getTo() {
return super.getTo();
}
/**
* See the description of {@link #getTo()}.
* @param to starting point for search or exact destination
*/
@Override
public void setTo(@NotNull final Location to) {
super.setTo(to);
}
/**
* No effect
* @return no effect
* @deprecated No effect
*/
@Deprecated
@Override
public boolean willDismountPlayer() {
return super.willDismountPlayer();
}
/**
* No effect
* @return no effect
* @deprecated No effect
*/
@Deprecated
@Override
public @NotNull java.util.Set<io.papermc.paper.entity.TeleportFlag.@NotNull Relative> getRelativeTeleportationFlags() {
return super.getRelativeTeleportationFlags();
}
// Paper end
/** /**
* Set the Block radius to search in for available portals. * Set the Block radius to search in for available portals.