geforkt von Mirrors/Paper
PlayerPickupItemEvent#setFlyAtPlayer (#683)
* PlayerPickupItemEvent#setFlyAtPlayer
Dieser Commit ist enthalten in:
Ursprung
e91f3880b7
Commit
899f4969c1
54
Spigot-API-Patches/PlayerPickupItemEvent-setFlyAtPlayer.patch
Normale Datei
54
Spigot-API-Patches/PlayerPickupItemEvent-setFlyAtPlayer.patch
Normale Datei
@ -0,0 +1,54 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: BillyGalbreath <Blake.Galbreath@GMail.com>
|
||||||
|
Date: Sun, 7 May 2017 06:26:01 -0500
|
||||||
|
Subject: [PATCH] PlayerPickupItemEvent#setFlyAtPlayer
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/src/main/java/org/bukkit/event/player/PlayerPickupItemEvent.java b/src/main/java/org/bukkit/event/player/PlayerPickupItemEvent.java
|
||||||
|
index dfba8163..fd97ea21 100644
|
||||||
|
--- a/src/main/java/org/bukkit/event/player/PlayerPickupItemEvent.java
|
||||||
|
+++ b/src/main/java/org/bukkit/event/player/PlayerPickupItemEvent.java
|
||||||
|
@@ -0,0 +0,0 @@ import org.bukkit.event.HandlerList;
|
||||||
|
public class PlayerPickupItemEvent extends PlayerEvent implements Cancellable {
|
||||||
|
private static final HandlerList handlers = new HandlerList();
|
||||||
|
private final Item item;
|
||||||
|
+ private boolean flyAtPlayer = true; // Paper
|
||||||
|
private boolean cancel = false;
|
||||||
|
private final int remaining;
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ public class PlayerPickupItemEvent extends PlayerEvent implements Cancellable {
|
||||||
|
return remaining;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ // Paper Start
|
||||||
|
+ /**
|
||||||
|
+ * Set if the item will fly at the player
|
||||||
|
+ * <p>Cancelling the event will set this value to false.</p>
|
||||||
|
+ *
|
||||||
|
+ * @param flyAtPlayer True for item to fly at player
|
||||||
|
+ */
|
||||||
|
+ public void setFlyAtPlayer(boolean flyAtPlayer) {
|
||||||
|
+ this.flyAtPlayer = flyAtPlayer;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Gets if the item will fly at the player
|
||||||
|
+ *
|
||||||
|
+ * @return True if the item will fly at the player
|
||||||
|
+ */
|
||||||
|
+ public boolean getFlyAtPlayer() {
|
||||||
|
+ return flyAtPlayer;
|
||||||
|
+ }
|
||||||
|
+ // Paper End
|
||||||
|
+
|
||||||
|
public boolean isCancelled() {
|
||||||
|
return cancel;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setCancelled(boolean cancel) {
|
||||||
|
this.cancel = cancel;
|
||||||
|
+ this.flyAtPlayer = !cancel; // Paper
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
--
|
47
Spigot-Server-Patches/PlayerPickupItemEvent-setFlyAtPlayer.patch
Normale Datei
47
Spigot-Server-Patches/PlayerPickupItemEvent-setFlyAtPlayer.patch
Normale Datei
@ -0,0 +1,47 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: BillyGalbreath <Blake.Galbreath@GMail.com>
|
||||||
|
Date: Sun, 7 May 2017 06:26:09 -0500
|
||||||
|
Subject: [PATCH] PlayerPickupItemEvent#setFlyAtPlayer
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/src/main/java/net/minecraft/server/EntityItem.java b/src/main/java/net/minecraft/server/EntityItem.java
|
||||||
|
index 95ca1b8e..2dd27d1c 100644
|
||||||
|
--- a/src/main/java/net/minecraft/server/EntityItem.java
|
||||||
|
+++ b/src/main/java/net/minecraft/server/EntityItem.java
|
||||||
|
@@ -0,0 +0,0 @@ public class EntityItem extends Entity implements HopperPusher {
|
||||||
|
// CraftBukkit start - fire PlayerPickupItemEvent
|
||||||
|
int canHold = entityhuman.inventory.canHold(itemstack);
|
||||||
|
int remaining = i - canHold;
|
||||||
|
+ boolean flyAtPlayer = false; // Paper
|
||||||
|
|
||||||
|
if (this.pickupDelay <= 0 && canHold > 0) {
|
||||||
|
itemstack.setCount(canHold);
|
||||||
|
@@ -0,0 +0,0 @@ public class EntityItem extends Entity implements HopperPusher {
|
||||||
|
// event.setCancelled(!entityhuman.canPickUpLoot); TODO
|
||||||
|
this.world.getServer().getPluginManager().callEvent(event);
|
||||||
|
itemstack.setCount(canHold + remaining);
|
||||||
|
+ flyAtPlayer = event.getFlyAtPlayer(); // Paper
|
||||||
|
|
||||||
|
if (event.isCancelled()) {
|
||||||
|
+ // Paper Start
|
||||||
|
+ if (flyAtPlayer) {
|
||||||
|
+ entityhuman.receive(this, i);
|
||||||
|
+ }
|
||||||
|
+ // Paper End
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ public class EntityItem extends Entity implements HopperPusher {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
- entityhuman.receive(this, i);
|
||||||
|
+ // Paper Start
|
||||||
|
+ if (flyAtPlayer) {
|
||||||
|
+ entityhuman.receive(this, i);
|
||||||
|
+ }
|
||||||
|
+ // Paper End
|
||||||
|
if (itemstack.isEmpty()) {
|
||||||
|
this.die();
|
||||||
|
itemstack.setCount(i);
|
||||||
|
--
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren