Interface Furnace

All Superinterfaces:
BlockInventoryHolder, BlockState, Container, InventoryHolder, Lockable, LockableTileState, Metadatable, Nameable, PersistentDataHolder, PersistentDataViewHolder, TileState
All Known Subinterfaces:
BlastFurnace, Smoker

public interface Furnace extends Container
Represents a captured state of a furnace.
  • Method Details Link icon

    • getBurnTime Link icon

      short getBurnTime()
      Get burn time.
      Returns:
      Burn time
    • setBurnTime Link icon

      void setBurnTime(short burnTime)
      Set burn time. A burn time greater than 0 will cause this block to be lit, whilst a time less than 0 will extinguish it.
      Parameters:
      burnTime - Burn time
    • getCookTime Link icon

      short getCookTime()
      Get cook time. This is the amount of time the item has been cooking for.
      Returns:
      Cook time
    • setCookTime Link icon

      void setCookTime(short cookTime)
      Set cook time. This is the amount of time the item has been cooking for.
      Parameters:
      cookTime - Cook time
    • getCookTimeTotal Link icon

      int getCookTimeTotal()
      Get cook time total. This is the amount of time the item is required to cook for.
      Returns:
      Cook time total
    • setCookTimeTotal Link icon

      void setCookTimeTotal(int cookTimeTotal)
      Set cook time. This is the amount of time the item is required to cook for.
      Parameters:
      cookTimeTotal - Cook time total
    • getRecipesUsed Link icon

      @NotNull @NotNull Map<CookingRecipe<?>,Integer> getRecipesUsed()
      Get the recipes used in this furnace. Note: These recipes used are reset when the result item is manually taken from the furnace.
      Returns:
      An immutable map with the recipes used and the times used
    • getCookSpeedMultiplier Link icon

      double getCookSpeedMultiplier()
      Gets the cook speed multiplier that this Furnace will cook compared to vanilla.
      Returns:
      the multiplier, a value between 0 and 200
    • setCookSpeedMultiplier Link icon

      void setCookSpeedMultiplier(double multiplier)
      Sets the speed multiplier that this Furnace will cook compared to vanilla.
      Parameters:
      multiplier - the multiplier to set, a value between 0 and 200
      Throws:
      IllegalArgumentException - if value is less than 0
      IllegalArgumentException - if value is more than 200
    • getRecipeUsedCount Link icon

      int getRecipeUsedCount(@NotNull NamespacedKey furnaceRecipe)
      Gets the number of times a recipe has been used since the last player removed items from the result slot. This is used to calculate experience rewards when withdrawing items from furnaces.
      Parameters:
      furnaceRecipe - the recipe to query the count for
      Returns:
      the count or 0 if none found
    • hasRecipeUsedCount Link icon

      boolean hasRecipeUsedCount(@NotNull NamespacedKey furnaceRecipe)
      Checks if the recipe has a used count present on this furnace.
      Parameters:
      furnaceRecipe - the recipe to check if a count exists for
      Returns:
      true if there is a positive count, else false
    • setRecipeUsedCount Link icon

      void setRecipeUsedCount(@NotNull CookingRecipe<?> furnaceRecipe, int count)
      Sets the number of times a recipe has been used. This is used to calculate experience rewards when withdrawing items from furnaces.
      Parameters:
      furnaceRecipe - the recipe to set the count for
      count - the count, a non-positive number will remove the recipe
    • setRecipesUsed Link icon

      void setRecipesUsed(@NotNull @NotNull Map<CookingRecipe<?>,Integer> recipesUsed)
      Sets all recipes used by this furnace.
      Parameters:
      recipesUsed - the recipes used
    • getInventory Link icon

      Description copied from interface: Container
      Gets the inventory of the block represented by this block state.

      If the block was changed to a different type in the meantime, the returned inventory might no longer be valid.

      If this block state is not placed this will return the captured inventory snapshot instead.

      Specified by:
      getInventory in interface Container
      Specified by:
      getInventory in interface InventoryHolder
      Returns:
      the inventory
    • getSnapshotInventory Link icon

      @NotNull @NotNull FurnaceInventory getSnapshotInventory()
      Description copied from interface: Container
      Gets the captured inventory snapshot of this container.

      The returned inventory is not linked to any block. Any modifications to the returned inventory will not be applied to the block represented by this block state up until BlockState.update(boolean, boolean) has been called.

      Specified by:
      getSnapshotInventory in interface Container
      Returns:
      the captured inventory snapshot