mirror of
https://github.com/mcMMO-Dev/mcMMO.git
synced 2025-04-04 18:56:23 +02:00
360 lines
12 KiB
Java
360 lines
12 KiB
Java
package com.gmail.nossr50.util;
|
|
|
|
import com.gmail.nossr50.datatypes.skills.SubSkillType;
|
|
import com.gmail.nossr50.mcMMO;
|
|
import com.gmail.nossr50.skills.repair.Repair;
|
|
import com.gmail.nossr50.skills.salvage.Salvage;
|
|
import com.gmail.nossr50.util.random.RandomChanceSkill;
|
|
import com.gmail.nossr50.util.random.RandomChanceUtil;
|
|
import org.bukkit.Material;
|
|
import org.bukkit.block.BlockState;
|
|
import org.bukkit.block.data.Ageable;
|
|
import org.bukkit.block.data.BlockData;
|
|
import org.bukkit.entity.Player;
|
|
|
|
import java.util.HashSet;
|
|
|
|
public final class BlockUtils {
|
|
|
|
private BlockUtils() {
|
|
}
|
|
|
|
/**
|
|
* Mark a block for giving bonus drops, double drops are used if triple is false
|
|
*
|
|
* @param blockState target blockstate
|
|
* @param triple marks the block to give triple drops
|
|
*/
|
|
public static void markDropsAsBonus(BlockState blockState, boolean triple) {
|
|
if (triple)
|
|
blockState.setMetadata(mcMMO.tripleDrops, mcMMO.metadataValue);
|
|
else
|
|
blockState.setMetadata(mcMMO.doubleDrops, mcMMO.metadataValue);
|
|
}
|
|
|
|
/**
|
|
* Checks if a player successfully passed the double drop check
|
|
*
|
|
* @param blockState the blockstate
|
|
* @return true if the player succeeded in the check
|
|
*/
|
|
public static boolean checkDoubleDrops(Player player, BlockState blockState, SubSkillType subSkillType)
|
|
{
|
|
if(mcMMO.getConfigManager().isBonusDropsEnabled(blockState.getType()) && Permissions.isSubSkillEnabled(player, subSkillType))
|
|
{
|
|
return RandomChanceUtil.checkRandomChanceExecutionSuccess(new RandomChanceSkill(player, subSkillType, true));
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Checks to see if a given block awards XP.
|
|
*
|
|
* @param blockState The {@link BlockState} of the block to check
|
|
* @return true if the block awards XP, false otherwise
|
|
*/
|
|
public static boolean shouldBeWatched(BlockState blockState) {
|
|
return affectedByGigaDrillBreaker(blockState) || affectedByGreenTerra(blockState) || affectedBySuperBreaker(blockState) || isLog(blockState);
|
|
}
|
|
|
|
/**
|
|
* Check if a given block should allow for the activation of abilities
|
|
*
|
|
* @param blockState The {@link BlockState} of the block to check
|
|
* @return true if the block should allow ability activation, false
|
|
* otherwise
|
|
*/
|
|
public static boolean canActivateAbilities(BlockState blockState) {
|
|
return !mcMMO.getMaterialMapStore().isAbilityActivationBlackListed(blockState.getType());
|
|
}
|
|
|
|
/**
|
|
* Check if a given block should allow for the activation of tools
|
|
* Activating a tool is step 1 of a 2 step process for super ability activation
|
|
*
|
|
* @param blockState The {@link BlockState} of the block to check
|
|
* @return true if the block should allow ability activation, false
|
|
* otherwise
|
|
*/
|
|
public static boolean canActivateTools(BlockState blockState) {
|
|
return !mcMMO.getMaterialMapStore().isToolActivationBlackListed(blockState.getType());
|
|
}
|
|
|
|
/**
|
|
* Check if a given block is an ore
|
|
*
|
|
* @param blockState The {@link BlockState} of the block to check
|
|
* @return true if the block is an ore, false otherwise
|
|
*/
|
|
public static boolean isOre(BlockState blockState) {
|
|
return MaterialUtils.isOre(blockState.getType());
|
|
}
|
|
|
|
/**
|
|
* Determine if a given block can be made mossy
|
|
*
|
|
* @param blockState The {@link BlockState} of the block to check
|
|
* @return true if the block can be made mossy, false otherwise
|
|
*/
|
|
public static boolean canMakeMossy(BlockState blockState) {
|
|
return mcMMO.getMaterialMapStore().isMossyWhiteListed(blockState.getType());
|
|
}
|
|
|
|
/**
|
|
* Determine if a given block should be affected by Green Terra
|
|
*
|
|
* @param blockState The {@link BlockState} of the block to check
|
|
* @return true if the block should affected by Green Terra, false otherwise
|
|
*/
|
|
public static boolean affectedByGreenTerra(BlockState blockState) {
|
|
return mcMMO.getConfigManager().getExperienceMapManager().hasHerbalismXp(blockState.getType());
|
|
}
|
|
|
|
/**
|
|
* Determine if a given block should be affected by Super Breaker
|
|
*
|
|
* @param blockState The {@link BlockState} of the block to check
|
|
* @return true if the block should affected by Super Breaker, false
|
|
* otherwise
|
|
*/
|
|
public static Boolean affectedBySuperBreaker(BlockState blockState) {
|
|
if (mcMMO.getConfigManager().getExperienceMapManager().hasMiningXp(blockState.getType()))
|
|
return true;
|
|
|
|
return isMineable(blockState);
|
|
}
|
|
|
|
public static boolean isMineable(BlockState blockState)
|
|
{
|
|
switch (blockState.getType())
|
|
{
|
|
case COAL_ORE:
|
|
case DIAMOND_ORE:
|
|
case EMERALD_ORE:
|
|
case END_STONE:
|
|
case GOLD_ORE:
|
|
case IRON_ORE:
|
|
case LAPIS_ORE:
|
|
case NETHER_QUARTZ_ORE:
|
|
case REDSTONE_ORE:
|
|
case ANDESITE:
|
|
case DIORITE:
|
|
case GRANITE:
|
|
case STONE:
|
|
case PRISMARINE:
|
|
case DARK_PRISMARINE:
|
|
case SANDSTONE:
|
|
case NETHERRACK:
|
|
case ICE:
|
|
case PACKED_ICE:
|
|
return true;
|
|
default:
|
|
return false;
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Determine if a given block should be affected by Giga Drill Breaker
|
|
*
|
|
* @param blockState The {@link BlockState} of the block to check
|
|
* @return true if the block should affected by Giga Drill Breaker, false
|
|
* otherwise
|
|
*/
|
|
public static boolean affectedByGigaDrillBreaker(BlockState blockState) {
|
|
if(mcMMO.getConfigManager().getExperienceMapManager().hasExcavationXp(blockState.getType()))
|
|
return true;
|
|
|
|
return isDiggable(blockState);
|
|
}
|
|
|
|
/**
|
|
* Returns true if a shovel is used for digging this block
|
|
* @param blockState target blockstate
|
|
* @return true if a shovel is typically used for digging this block
|
|
*/
|
|
public static boolean isDiggable(BlockState blockState)
|
|
{
|
|
switch(blockState.getType())
|
|
{
|
|
case CLAY:
|
|
case FARMLAND:
|
|
case GRASS_BLOCK:
|
|
case GRASS_PATH:
|
|
case GRAVEL:
|
|
case MYCELIUM:
|
|
case PODZOL:
|
|
case COARSE_DIRT:
|
|
case DIRT:
|
|
case RED_SAND:
|
|
case SAND:
|
|
case SOUL_SAND:
|
|
case SNOW:
|
|
case SNOW_BLOCK:
|
|
return true;
|
|
default:
|
|
return false;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Check if a given block is a log
|
|
*
|
|
* @param blockState The {@link BlockState} of the block to check
|
|
* @return true if the block is a log, false otherwise
|
|
*/
|
|
public static boolean isLog(BlockState blockState) {
|
|
if(mcMMO.getConfigManager().getExperienceMapManager().hasWoodcuttingXp(blockState.getType()))
|
|
return true;
|
|
|
|
return isLoggingRelated(blockState);
|
|
//return mcMMO.getModManager().isCustomLog(blockState);
|
|
}
|
|
|
|
/**
|
|
* Determines if this particular block is typically gathered using an Axe
|
|
* @param blockState target blockstate
|
|
* @return true if the block is gathered via axe
|
|
*/
|
|
public static boolean isLoggingRelated(BlockState blockState)
|
|
{
|
|
switch(blockState.getType())
|
|
{
|
|
case ACACIA_LOG:
|
|
case BIRCH_LOG:
|
|
case DARK_OAK_LOG:
|
|
case JUNGLE_LOG:
|
|
case OAK_LOG:
|
|
case SPRUCE_LOG:
|
|
case STRIPPED_ACACIA_LOG:
|
|
case STRIPPED_ACACIA_WOOD:
|
|
case STRIPPED_BIRCH_LOG:
|
|
case STRIPPED_BIRCH_WOOD:
|
|
case STRIPPED_DARK_OAK_LOG:
|
|
case STRIPPED_DARK_OAK_WOOD:
|
|
case STRIPPED_JUNGLE_LOG:
|
|
case STRIPPED_JUNGLE_WOOD:
|
|
case STRIPPED_OAK_LOG:
|
|
case STRIPPED_OAK_WOOD:
|
|
case STRIPPED_SPRUCE_LOG:
|
|
case STRIPPED_SPRUCE_WOOD:
|
|
case ACACIA_WOOD:
|
|
case BIRCH_WOOD:
|
|
case DARK_OAK_WOOD:
|
|
case JUNGLE_WOOD:
|
|
case OAK_WOOD:
|
|
case SPRUCE_WOOD:
|
|
return true;
|
|
default:
|
|
return false;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Check if a given block is a leaf
|
|
*
|
|
* @param blockState The {@link BlockState} of the block to check
|
|
* @return true if the block is a leaf, false otherwise
|
|
*/
|
|
public static boolean isLeaves(BlockState blockState) {
|
|
return mcMMO.getMaterialMapStore().isLeavesWhiteListed(blockState.getType());
|
|
}
|
|
|
|
/**
|
|
* Determine if a given block should be affected by Flux Mining
|
|
*
|
|
* @param blockState The {@link BlockState} of the block to check
|
|
* @return true if the block should affected by Flux Mining, false otherwise
|
|
*/
|
|
public static boolean affectedByFluxMining(BlockState blockState) {
|
|
switch (blockState.getType()) {
|
|
case IRON_ORE:
|
|
case GOLD_ORE:
|
|
return true;
|
|
|
|
default:
|
|
return false;
|
|
//return mcMMO.getModManager().isCustomLeaf(blockState);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Determine if a given block can activate Herbalism abilities
|
|
*
|
|
* @param blockState The {@link BlockState} of the block to check
|
|
* @return true if the block can be activate Herbalism abilities, false
|
|
* otherwise
|
|
*/
|
|
public static boolean canActivateHerbalism(BlockState blockState) {
|
|
return mcMMO.getMaterialMapStore().isHerbalismAbilityWhiteListed(blockState.getType());
|
|
}
|
|
|
|
/**
|
|
* Determine if a given block should be affected by Block Cracker
|
|
*
|
|
* @param blockState The {@link BlockState} of the block to check
|
|
* @return true if the block should affected by Block Cracker, false
|
|
* otherwise
|
|
*/
|
|
public static boolean affectedByBlockCracker(BlockState blockState) {
|
|
return mcMMO.getMaterialMapStore().isBlockCrackerWhiteListed(blockState.getType());
|
|
}
|
|
|
|
/**
|
|
* Determine if a given block can be made into Mycelium
|
|
*
|
|
* @param blockState The {@link BlockState} of the block to check
|
|
* @return true if the block can be made into Mycelium, false otherwise
|
|
*/
|
|
public static boolean canMakeShroomy(BlockState blockState) {
|
|
return mcMMO.getMaterialMapStore().isShroomyWhiteListed(blockState.getType());
|
|
}
|
|
|
|
/**
|
|
* Determine if a given block is an mcMMO anvil
|
|
*
|
|
* @param blockState The {@link BlockState} of the block to check
|
|
* @return true if the block is an mcMMO anvil, false otherwise
|
|
*/
|
|
public static boolean isMcMMOAnvil(BlockState blockState) {
|
|
Material type = blockState.getType();
|
|
|
|
return type == Repair.getInstance().getAnvilMaterial() || type == Salvage.anvilMaterial;
|
|
}
|
|
|
|
public static boolean isPistonPiece(BlockState blockState) {
|
|
Material type = blockState.getType();
|
|
|
|
return type == Material.MOVING_PISTON || type == Material.AIR;
|
|
}
|
|
|
|
/**
|
|
* Get a HashSet containing every transparent block
|
|
*
|
|
* @return HashSet with the IDs of every transparent block
|
|
*/
|
|
public static HashSet<Material> getTransparentBlocks() {
|
|
HashSet<Material> transparentBlocks = new HashSet<>();
|
|
|
|
for (Material material : Material.values()) {
|
|
if (material.isTransparent()) {
|
|
transparentBlocks.add(material);
|
|
}
|
|
}
|
|
|
|
return transparentBlocks;
|
|
}
|
|
|
|
public static boolean isFullyGrown(BlockState blockState) {
|
|
BlockData data = blockState.getBlockData();
|
|
if (data.getMaterial() == Material.CACTUS || data.getMaterial() == Material.SUGAR_CANE)
|
|
return true;
|
|
if (data instanceof Ageable) {
|
|
Ageable ageable = (Ageable) data;
|
|
return ageable.getAge() == ageable.getMaximumAge();
|
|
}
|
|
return true;
|
|
}
|
|
}
|