All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.bukkit.entity.HumanEntity Maven / Gradle / Ivy

package org.bukkit.entity;

import org.bukkit.GameMode;
import org.bukkit.Location;
import org.bukkit.inventory.*;
import org.bukkit.permissions.Permissible;

/**
 * Represents a human entity, such as an NPC or a player
 */
public interface HumanEntity extends LivingEntity, AnimalTamer, Permissible, InventoryHolder {

  /**
   * Returns the name of this player
   *
   * @return Player name
   */
  String getName();

  /**
   * Get the player's inventory.
   *
   * @return The inventory of the player, this also contains the armor
   * slots.
   */
  PlayerInventory getInventory();

  /**
   * Get the player's EnderChest inventory
   *
   * @return The EnderChest of the player
   */
  Inventory getEnderChest();

  /**
   * If the player currently has an inventory window open, this method will
   * set a property of that window, such as the state of a progress bar.
   *
   * @param prop  The property.
   * @param value The value to set the property to.
   * @return True if the property was successfully set.
   */
  boolean setWindowProperty(InventoryView.Property prop, int value);

  /**
   * Gets the inventory view the player is currently viewing. If they do not
   * have an inventory window open, it returns their internal crafting view.
   *
   * @return The inventory view.
   */
  InventoryView getOpenInventory();

  /**
   * Opens an inventory window with the specified inventory on the top and
   * the player's inventory on the bottom.
   *
   * @param inventory The inventory to open
   * @return The newly opened inventory view
   */
  InventoryView openInventory(Inventory inventory);

  /**
   * Opens an empty workbench inventory window with the player's inventory
   * on the bottom.
   *
   * @param location The location to attach it to. If null, the player's
   *                 location is used.
   * @param force    If false, and there is no workbench block at the location,
   *                 no inventory will be opened and null will be returned.
   * @return The newly opened inventory view, or null if it could not be
   * opened.
   */
  InventoryView openWorkbench(Location location, boolean force);

  /**
   * Opens an empty enchanting inventory window with the player's inventory
   * on the bottom.
   *
   * @param location The location to attach it to. If null, the player's
   *                 location is used.
   * @param force    If false, and there is no enchanting table at the
   *                 location, no inventory will be opened and null will be returned.
   * @return The newly opened inventory view, or null if it could not be
   * opened.
   */
  InventoryView openEnchanting(Location location, boolean force);

  /**
   * Opens an inventory window to the specified inventory view.
   *
   * @param inventory The view to open
   */
  void openInventory(InventoryView inventory);

  /**
   * Force-closes the currently open inventory view for this player, if any.
   */
  void closeInventory();

  /**
   * Returns the ItemStack currently in your hand, can be empty.
   *
   * @return The ItemStack of the item you are currently holding.
   */
  ItemStack getItemInHand();

  /**
   * Sets the item to the given ItemStack, this will replace whatever the
   * user was holding.
   *
   * @param item The ItemStack which will end up in the hand
   */
  void setItemInHand(ItemStack item);

  /**
   * Returns the ItemStack currently on your cursor, can be empty. Will
   * always be empty if the player currently has no open window.
   *
   * @return The ItemStack of the item you are currently moving around.
   */
  ItemStack getItemOnCursor();

  /**
   * Sets the item to the given ItemStack, this will replace whatever the
   * user was moving. Will always be empty if the player currently has no
   * open window.
   *
   * @param item The ItemStack which will end up in the hand
   */
  void setItemOnCursor(ItemStack item);

  /**
   * Returns whether this player is slumbering.
   *
   * @return slumber state
   */
  boolean isSleeping();

  /**
   * Get the sleep ticks of the player. This value may be capped.
   *
   * @return slumber ticks
   */
  int getSleepTicks();

  /**
   * Gets this human's current {@link GameMode}
   *
   * @return Current game mode
   */
  GameMode getGameMode();

  /**
   * Sets this human's current {@link GameMode}
   *
   * @param mode New game mode
   */
  void setGameMode(GameMode mode);

  /**
   * Check if the player is currently blocking (ie with a sword).
   *
   * @return Whether they are blocking.
   */
  boolean isBlocking();

  /**
   * Get the total amount of experience required for the player to level
   *
   * @return Experience required to level up
   */
  int getExpToLevel();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy