Package net.minestom.server.inventory
Class AbstractInventory
java.lang.Object
net.minestom.server.inventory.AbstractInventory
- All Implemented Interfaces:
InventoryClickHandler
,Taggable
,TagReadable
,TagWritable
,Viewable
- Direct Known Subclasses:
Inventory
,PlayerInventory
public abstract sealed class AbstractInventory
extends Object
implements InventoryClickHandler, Taggable, Viewable
permits Inventory, PlayerInventory
Represents an inventory where items can be modified/retrieved.
-
Field Summary
Modifier and TypeFieldDescriptionprotected final InventoryClickProcessor
protected final List
<InventoryCondition> protected final ItemStack[]
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
addInventoryCondition
(@NotNull InventoryCondition inventoryCondition) Adds a newInventoryCondition
to this inventory.boolean
addItemStack
(@NotNull ItemStack itemStack) <T> T
addItemStack
(@NotNull ItemStack itemStack, @NotNull TransactionOption<T> option) Adds anItemStack
to the inventory and sends relevant update to the viewer(s).<T> @NotNull List
<@NotNull T> addItemStacks
(@NotNull List<@NotNull ItemStack> itemStacks, @NotNull TransactionOption<T> option) AddsItemStack
s to the inventory and sends relevant updates to the viewer(s).boolean
Adds a viewer.void
clear()
Clears the inventory and send relevant update to the viewer(s).void
copyContents
(@NotNull ItemStack[] itemStacks) Places all the items ofitemStacks
into the internal array.int
Gets the size of the "inner inventory" (which includes only "usable" slots).@NotNull List
<@NotNull InventoryCondition> Gets all theInventoryCondition
of this inventory.@NotNull ItemStack
getItemStack
(int slot) Gets theItemStack
at the specified slot.@NotNull ItemStack[]
Gets all theItemStack
in the inventory.int
getSize()
Gets the size of the inventory.Gets all the viewers of this viewable element.abstract byte
Gets this window id.<T> T
processItemStack
(@NotNull ItemStack itemStack, @NotNull TransactionType type, @NotNull TransactionOption<T> option) <T> @NotNull List
<@NotNull T> processItemStacks
(@NotNull List<@NotNull ItemStack> itemStacks, @NotNull TransactionType type, @NotNull TransactionOption<T> option) boolean
removeViewer
(@NotNull Player player) Removes a viewer.void
replaceItemStack
(int slot, @NotNull UnaryOperator<@NotNull ItemStack> operator) void
sendSlotRefresh
(int slot, @NotNull ItemStack item, @NotNull ItemStack previous) void
setItemStack
(int slot, @NotNull ItemStack itemStack) Sets anItemStack
at the specified slot and send relevant update to the viewer(s).void
setItemStack
(int slot, @NotNull ItemStack itemStack, boolean sendPacket) Sets anItemStack
at the specified slot and send relevant update to the viewer(s).@NotNull TagHandler
<T> T
takeItemStack
(@NotNull ItemStack itemStack, @NotNull TransactionOption<T> option) Takes anItemStack
from the inventory and sends relevant update to the viewer(s).<T> @NotNull List
<@NotNull T> takeItemStacks
(@NotNull List<@NotNull ItemStack> itemStacks, @NotNull TransactionOption<T> option) TakesItemStack
s from the inventory and sends relevant updates to the viewer(s).protected void
UNSAFE_itemInsert
(int slot, @NotNull ItemStack item, @NotNull ItemStack previous, boolean sendPacket) void
update()
Refreshes the inventory for all viewers.void
Refreshes the inventory for a specific viewer.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface net.minestom.server.inventory.InventoryClickHandler
callClickEvent, changeHeld, doubleClick, dragging, drop, leftClick, middleClick, rightClick, shiftClick
Methods inherited from interface net.minestom.server.tag.Taggable
getAndSetTag, getAndUpdateTag, getTag, hasTag, removeTag, setTag, updateAndGetTag, updateTag
Methods inherited from interface net.minestom.server.Viewable
getViewersAsAudience, getViewersAsAudiences, isViewer, sendPacketsToViewers, sendPacketsToViewers, sendPacketToViewers, sendPacketToViewersAndSelf
-
Field Details
-
itemStacks
-
inventoryConditions
-
clickProcessor
-
viewers
-
unmodifiableViewers
-
-
Constructor Details
-
AbstractInventory
protected AbstractInventory(int size)
-
-
Method Details
-
getWindowId
public abstract byte getWindowId()Gets this window id.This is the id that the client will send to identify the affected inventory, mostly used by packets.
- Returns:
- the window id
-
getViewers
Description copied from interface:Viewable
Gets all the viewers of this viewable element.- Specified by:
getViewers
in interfaceViewable
- Returns:
- A Set containing all the element's viewers
-
addViewer
Description copied from interface:Viewable
Adds a viewer. -
removeViewer
Description copied from interface:Viewable
Removes a viewer.- Specified by:
removeViewer
in interfaceViewable
- Parameters:
player
- the viewer to remove- Returns:
- true if the player has been removed, false otherwise (could be because he was not a viewer)
-
setItemStack
Sets anItemStack
at the specified slot and send relevant update to the viewer(s).- Parameters:
slot
- the slot to set the itemitemStack
- the item to set
-
setItemStack
Sets anItemStack
at the specified slot and send relevant update to the viewer(s).- Parameters:
slot
- the slot to set the itemitemStack
- the item to setsendPacket
- whether or not to send packets
-
UNSAFE_itemInsert
-
sendSlotRefresh
-
processItemStack
@NotNull public <T> T processItemStack(@NotNull @NotNull ItemStack itemStack, @NotNull @NotNull TransactionType type, @NotNull @NotNull TransactionOption<T> option) -
processItemStacks
@NotNull public <T> @NotNull List<@NotNull T> processItemStacks(@NotNull @NotNull List<@NotNull ItemStack> itemStacks, @NotNull @NotNull TransactionType type, @NotNull @NotNull TransactionOption<T> option) -
addItemStack
@NotNull public <T> T addItemStack(@NotNull @NotNull ItemStack itemStack, @NotNull @NotNull TransactionOption<T> option) Adds anItemStack
to the inventory and sends relevant update to the viewer(s).- Parameters:
itemStack
- the item to addoption
- the transaction option- Returns:
- true if the item has been successfully added, false otherwise
-
addItemStack
-
addItemStacks
@NotNull public <T> @NotNull List<@NotNull T> addItemStacks(@NotNull @NotNull List<@NotNull ItemStack> itemStacks, @NotNull @NotNull TransactionOption<T> option) AddsItemStack
s to the inventory and sends relevant updates to the viewer(s).- Parameters:
itemStacks
- items to addoption
- the transaction option- Returns:
- the operation results
-
takeItemStack
@NotNull public <T> T takeItemStack(@NotNull @NotNull ItemStack itemStack, @NotNull @NotNull TransactionOption<T> option) Takes anItemStack
from the inventory and sends relevant update to the viewer(s).- Parameters:
itemStack
- the item to take- Returns:
- true if the item has been successfully fully taken, false otherwise
-
takeItemStacks
@NotNull public <T> @NotNull List<@NotNull T> takeItemStacks(@NotNull @NotNull List<@NotNull ItemStack> itemStacks, @NotNull @NotNull TransactionOption<T> option) TakesItemStack
s from the inventory and sends relevant updates to the viewer(s).- Parameters:
itemStacks
- items to take- Returns:
- the operation results
-
replaceItemStack
public void replaceItemStack(int slot, @NotNull @NotNull UnaryOperator<@NotNull ItemStack> operator) -
clear
public void clear()Clears the inventory and send relevant update to the viewer(s). -
update
public void update()Refreshes the inventory for all viewers. -
update
Refreshes the inventory for a specific viewer.- Parameters:
player
- the player to update the inventory for
-
getItemStack
Gets theItemStack
at the specified slot.- Parameters:
slot
- the slot to check- Returns:
- the item in the slot
slot
-
getItemStacks
Gets all theItemStack
in the inventory.Be aware that the returned array does not need to be the original one, meaning that modifying it directly may not work.
- Returns:
- an array containing all the inventory's items
-
getSize
public int getSize()Gets the size of the inventory.- Returns:
- the inventory's size
-
getInnerSize
public int getInnerSize()Gets the size of the "inner inventory" (which includes only "usable" slots).- Returns:
- inner inventory's size
-
getInventoryConditions
Gets all theInventoryCondition
of this inventory.- Returns:
- a modifiable
List
containing all the inventory conditions
-
addInventoryCondition
Adds a newInventoryCondition
to this inventory.- Parameters:
inventoryCondition
- the inventory condition to add
-
copyContents
Places all the items ofitemStacks
into the internal array.- Parameters:
itemStacks
- the array to copy the content from- Throws:
IllegalArgumentException
- if the size of the array is not equal togetSize()
NullPointerException
- ifitemStacks
contains one null element or more
-
tagHandler
- Specified by:
tagHandler
in interfaceTaggable
-