Cancellable
public class InventoryDragEvent extends InventoryInteractEvent
getType()
.
Canceling this event will result in none of the changes described in
getNewItems()
being applied to the Inventory.
Because InventoryDragEvent occurs within a modification of the Inventory, not all Inventory related methods are safe to use.
The following should never be invoked by an EventHandler for InventoryDragEvent using the HumanEntity or InventoryView associated with this event.
HumanEntity.closeInventory()
HumanEntity.openInventory(Inventory)
HumanEntity.openWorkbench(Location, boolean)
HumanEntity.openEnchanting(Location, boolean)
InventoryView.close()
BukkitScheduler.runTask(Plugin, Runnable)
, which will run the task
on the next tick. Also be aware that this is not an exhaustive list, and
other methods could potentially create issues as well.
Assuming the EntityHuman associated with this event is an instance of a
Player, manipulating the MaxStackSize or contents of an Inventory will
require an Invocation of Player.updateInventory()
.
Any modifications to slots that are modified by the results of this
InventoryDragEvent will be overwritten. To change these slots, this event
should be cancelled and the changes applied. Alternatively, scheduling a
task using BukkitScheduler.runTask(Plugin, Runnable)
, which would
execute the task on the next tick, would work as well.
Event.Result
transaction
Constructor | Description |
---|---|
InventoryDragEvent(InventoryView what,
ItemStack newCursor,
ItemStack oldCursor,
boolean right,
Map<Integer,ItemStack> slots) |
Modifier and Type | Method | Description |
---|---|---|
ItemStack |
getCursor() |
Gets the result cursor after the drag is done.
|
static HandlerList |
getHandlerList() |
|
HandlerList |
getHandlers() |
|
Set<Integer> |
getInventorySlots() |
Gets the slots to be changed in this drag.
|
Map<Integer,ItemStack> |
getNewItems() |
Gets all items to be added to the inventory in this drag.
|
ItemStack |
getOldCursor() |
Gets an ItemStack representing the cursor prior to any modifications
as a result of this drag.
|
Set<Integer> |
getRawSlots() |
Gets the raw slot ids to be changed in this drag.
|
DragType |
getType() |
Gets the DragType that describes the behavior of ItemStacks placed
after this InventoryDragEvent.
|
void |
setCursor(ItemStack newCursor) |
Sets the result cursor after the drag is done.
|
getEventName, isAsynchronous
getInventory, getView, getViewers
getResult, getWhoClicked, isCancelled, setCancelled, setResult
@NotNull public Map<Integer,ItemStack> getNewItems()
@NotNull public Set<Integer> getRawSlots()
@NotNull public Set<Integer> getInventorySlots()
Inventory.getItem(int)
.@Nullable public ItemStack getCursor()
public void setCursor(@Nullable ItemStack newCursor)
Changing this item stack changes the cursor item. Note that changing the affected "dragged" slots does not change this ItemStack, nor does changing this ItemStack affect the "dragged" slots.
newCursor
- the new cursor ItemStack@NotNull public ItemStack getOldCursor()
@NotNull public DragType getType()
The ItemStacks and the raw slots that they're being applied to can be
found using getNewItems()
.
@NotNull public HandlerList getHandlers()
getHandlers
in class InventoryEvent
@NotNull public static HandlerList getHandlerList()
Copyright © 2019. All rights reserved.