mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-15 14:13:56 +01:00
Improve PortalEvents
This commit is contained in:
parent
850e3c2ea1
commit
40c7b09ed4
4 changed files with 136 additions and 2 deletions
|
@ -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.
|
||||||
|
|
|
@ -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() {
|
||||||
|
|
|
@ -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.
|
||||||
*
|
*
|
||||||
|
|
|
@ -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.
|
||||||
|
|
Loading…
Reference in a new issue