net.minestom.server.event.player.PlayerUseItemEvent Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of minestom-snapshots Show documentation
Show all versions of minestom-snapshots Show documentation
1.20.4 Lightweight Minecraft server
package net.minestom.server.event.player;
import net.minestom.server.entity.Player;
import net.minestom.server.event.item.ItemUpdateStateEvent;
import net.minestom.server.event.trait.CancellableEvent;
import net.minestom.server.event.trait.ItemEvent;
import net.minestom.server.event.trait.PlayerInstanceEvent;
import net.minestom.server.item.ItemStack;
import org.jetbrains.annotations.NotNull;
/**
* Event when an item is used without clicking on a block.
*/
public class PlayerUseItemEvent implements PlayerInstanceEvent, ItemEvent, CancellableEvent {
private final Player player;
private final Player.Hand hand;
private final ItemStack itemStack;
private long itemUseTime;
private boolean cancelled;
public PlayerUseItemEvent(@NotNull Player player, @NotNull Player.Hand hand, @NotNull ItemStack itemStack, long itemUseTime) {
this.player = player;
this.hand = hand;
this.itemStack = itemStack;
this.itemUseTime = itemUseTime;
}
/**
* Gets which hand the player used.
*
* @return the hand used
*/
public @NotNull Player.Hand getHand() {
return hand;
}
/**
* Gets the item which has been used.
*
* @return the item
*/
@Override
public @NotNull ItemStack getItemStack() {
return itemStack;
}
/**
* Gets the item usage duration. After this amount of milliseconds,
* the animation will stop automatically and {@link ItemUpdateStateEvent} is called.
*
* @return the item use time
*/
public long getItemUseTime() {
return itemUseTime;
}
/**
* Changes the item usage duration.
*
* @param itemUseTime the new item use time
*/
public void setItemUseTime(long itemUseTime) {
this.itemUseTime = itemUseTime;
}
@Override
public boolean isCancelled() {
return cancelled;
}
@Override
public void setCancelled(boolean cancel) {
this.cancelled = cancel;
}
@Override
public @NotNull Player getPlayer() {
return player;
}
}