mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-08 03:22:19 +01:00
Add InventoryView#getInventory API
By: md_5 <git@md-5.net>
This commit is contained in:
parent
e8f711959a
commit
a487f8ec2b
2 changed files with 42 additions and 14 deletions
|
@ -157,6 +157,16 @@ public class InventoryClickEvent extends InventoryInteractEvent {
|
|||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the inventory corresponding to the clicked slot.
|
||||
*
|
||||
* @see InventoryView#getInventory(int)
|
||||
* @return inventory, or null if clicked outside
|
||||
*/
|
||||
public Inventory getClickedInventory() {
|
||||
return getView().getInventory(rawSlot);
|
||||
}
|
||||
|
||||
/**
|
||||
* The slot number that was clicked, ready for passing to
|
||||
* {@link Inventory#getItem(int)}. Note that there may be two slots with
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
package org.bukkit.inventory;
|
||||
|
||||
import com.google.common.base.Preconditions;
|
||||
import org.bukkit.entity.HumanEntity;
|
||||
import org.bukkit.event.inventory.InventoryType;
|
||||
|
||||
|
@ -157,12 +158,9 @@ public abstract class InventoryView {
|
|||
* @param item The new item to put in the slot, or null to clear it.
|
||||
*/
|
||||
public void setItem(int slot, ItemStack item) {
|
||||
if (slot != OUTSIDE) {
|
||||
if (slot < getTopInventory().getSize()) {
|
||||
getTopInventory().setItem(convertSlot(slot), item);
|
||||
} else {
|
||||
getBottomInventory().setItem(convertSlot(slot), item);
|
||||
}
|
||||
Inventory inventory = getInventory(slot);
|
||||
if (inventory != null) {
|
||||
inventory.setItem(convertSlot(slot), item);
|
||||
} else {
|
||||
getPlayer().getWorld().dropItemNaturally(getPlayer().getLocation(), item);
|
||||
}
|
||||
|
@ -175,14 +173,8 @@ public abstract class InventoryView {
|
|||
* @return The item currently in the slot.
|
||||
*/
|
||||
public ItemStack getItem(int slot) {
|
||||
if (slot == OUTSIDE) {
|
||||
return null;
|
||||
}
|
||||
if (slot < getTopInventory().getSize()) {
|
||||
return getTopInventory().getItem(convertSlot(slot));
|
||||
} else {
|
||||
return getBottomInventory().getItem(convertSlot(slot));
|
||||
}
|
||||
Inventory inventory = getInventory(slot);
|
||||
return (inventory == null) ? null : inventory.getItem(convertSlot(slot));
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -205,6 +197,32 @@ public abstract class InventoryView {
|
|||
return getPlayer().getItemOnCursor();
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the inventory corresponding to the given raw slot ID.
|
||||
*
|
||||
* If the slot ID is {@link #OUTSIDE} null will be returned, otherwise
|
||||
* behaviour for illegal and negative slot IDs is undefined.
|
||||
*
|
||||
* May be used with {@link #convertSlot(int)} to directly index an
|
||||
* underlying inventory.
|
||||
*
|
||||
* @param rawSlot The raw slot ID.
|
||||
* @return corresponding inventory, or null
|
||||
*/
|
||||
public final Inventory getInventory(int rawSlot) {
|
||||
if (rawSlot == OUTSIDE) {
|
||||
return null;
|
||||
}
|
||||
Preconditions.checkArgument(rawSlot >= 0, "Negative, non outside slot %s", rawSlot);
|
||||
Preconditions.checkArgument(rawSlot < countSlots(), "Slot %s greater than inventory slot count", rawSlot);
|
||||
|
||||
if (rawSlot < getTopInventory().getSize()) {
|
||||
return getTopInventory();
|
||||
} else {
|
||||
return getBottomInventory();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Converts a raw slot ID into its local slot ID into whichever of the two
|
||||
* inventories the slot points to.
|
||||
|
|
Loading…
Reference in a new issue