PocketMine-MP 5.14.2 git-50e2c469a547a16a23b2dc691e70a51d34e29395
pocketmine\item\enchantment\Enchantment Class Reference
+ Inheritance diagram for pocketmine\item\enchantment\Enchantment:
+ Collaboration diagram for pocketmine\item\enchantment\Enchantment:

Public Member Functions

 __construct (private Translatable|string $name, private int $rarity, private int $primaryItemFlags, private int $secondaryItemFlags, private int $maxLevel, ?\Closure $minEnchantingPower=null, private int $enchantingPowerRange=50)
 
 getMaxEnchantingPower (int $level)
 
 getMaxLevel ()
 
 getMinEnchantingPower (int $level)
 
 getName ()
 
 getPrimaryItemFlags ()
 
 getRarity ()
 
 getSecondaryItemFlags ()
 
 hasPrimaryItemType (int $flag)
 
 hasSecondaryItemType (int $flag)
 
 isCompatibleWith (Enchantment $other)
 

Detailed Description

Manages enchantment type data.

Definition at line 37 of file Enchantment.php.

Constructor & Destructor Documentation

◆ __construct()

pocketmine\item\enchantment\Enchantment::__construct ( private Translatable|string  $name,
private int  $rarity,
private int  $primaryItemFlags,
private int  $secondaryItemFlags,
private int  $maxLevel,
?\Closure  $minEnchantingPower = null,
private int  $enchantingPowerRange = 50 
)

@phpstan-param null|(\Closure(int $level) : int) $minEnchantingPower

Parameters
int$primaryItemFlags
Deprecated:
Parameters
int$secondaryItemFlags
Deprecated:
Parameters
int$enchantingPowerRangeValue used to calculate the maximum enchanting power (minEnchantingPower + enchantingPowerRange)

Definition at line 51 of file Enchantment.php.

References pocketmine\utils\Utils\validateCallableSignature().

+ Here is the call graph for this function:

Member Function Documentation

◆ getMaxEnchantingPower()

pocketmine\item\enchantment\Enchantment::getMaxEnchantingPower ( int  $level)

Returns the maximum enchanting power value allowed for the particular level of the enchantment to be available in an enchanting table.

Enchanting power is a random value based on the number of bookshelves around an enchanting table and the enchantability of the item being enchanted. It is only used when determining the available enchantments for the enchantment options.

Definition at line 157 of file Enchantment.php.

◆ getMaxLevel()

pocketmine\item\enchantment\Enchantment::getMaxLevel ( )

Returns the maximum level of this enchantment that can be found on an enchantment table.

Definition at line 126 of file Enchantment.php.

◆ getMinEnchantingPower()

pocketmine\item\enchantment\Enchantment::getMinEnchantingPower ( int  $level)

Returns the minimum enchanting power value required for the particular level of the enchantment to be available in an enchanting table.

Enchanting power is a random value based on the number of bookshelves around an enchanting table and the enchantability of the item being enchanted. It is only used when determining the available enchantments for the enchantment options.

Definition at line 145 of file Enchantment.php.

◆ getName()

pocketmine\item\enchantment\Enchantment::getName ( )

Returns a translation key for this enchantment's name.

Definition at line 71 of file Enchantment.php.

◆ getPrimaryItemFlags()

pocketmine\item\enchantment\Enchantment::getPrimaryItemFlags ( )

Returns a bitset indicating what item types can have this item applied from an enchanting table.

Deprecated:
See also
AvailableEnchantmentRegistry::getPrimaryItemTags()

Definition at line 88 of file Enchantment.php.

◆ getRarity()

pocketmine\item\enchantment\Enchantment::getRarity ( )

Returns an int constant indicating how rare this enchantment type is.

Definition at line 78 of file Enchantment.php.

◆ getSecondaryItemFlags()

pocketmine\item\enchantment\Enchantment::getSecondaryItemFlags ( )

Returns a bitset indicating what item types cannot have this item applied from an enchanting table, but can from an anvil.

Deprecated:
See also
AvailableEnchantmentRegistry::getSecondaryItemTags()

Definition at line 99 of file Enchantment.php.

◆ hasPrimaryItemType()

pocketmine\item\enchantment\Enchantment::hasPrimaryItemType ( int  $flag)

Returns whether this enchantment can apply to the item type from an enchanting table.

Deprecated:
See also
AvailableEnchantmentRegistry

Definition at line 109 of file Enchantment.php.

◆ hasSecondaryItemType()

pocketmine\item\enchantment\Enchantment::hasSecondaryItemType ( int  $flag)

Returns whether this enchantment can apply to the item type from an anvil, if it is not a primary item.

Deprecated:
See also
AvailableEnchantmentRegistry

Definition at line 119 of file Enchantment.php.

◆ isCompatibleWith()

pocketmine\item\enchantment\Enchantment::isCompatibleWith ( Enchantment  $other)

Returns whether this enchantment can be applied to the item along with the given enchantment.

Definition at line 133 of file Enchantment.php.


The documentation for this class was generated from the following file: