2013-01-22 18:43:25 +01:00
|
|
|
package com.gmail.nossr50.skills.woodcutting;
|
2012-01-09 20:00:13 +01:00
|
|
|
|
2012-05-01 07:14:32 +02:00
|
|
|
import org.bukkit.Location;
|
2012-01-09 20:00:13 +01:00
|
|
|
import org.bukkit.Material;
|
2012-03-16 16:30:23 +01:00
|
|
|
import org.bukkit.TreeSpecies;
|
2012-01-09 20:00:13 +01:00
|
|
|
import org.bukkit.block.Block;
|
|
|
|
import org.bukkit.entity.Player;
|
2012-06-05 16:13:10 +02:00
|
|
|
import org.bukkit.event.block.BlockBreakEvent;
|
2012-01-09 20:00:13 +01:00
|
|
|
import org.bukkit.inventory.ItemStack;
|
2012-06-05 16:13:10 +02:00
|
|
|
import org.getspout.spoutapi.sound.SoundEffect;
|
2012-03-02 20:01:09 +01:00
|
|
|
|
2012-06-07 00:02:22 +02:00
|
|
|
import com.gmail.nossr50.mcMMO;
|
2012-11-21 21:49:54 +01:00
|
|
|
import com.gmail.nossr50.config.AdvancedConfig;
|
2012-04-26 16:27:57 +02:00
|
|
|
import com.gmail.nossr50.config.Config;
|
2012-05-17 23:03:56 +02:00
|
|
|
import com.gmail.nossr50.datatypes.mods.CustomBlock;
|
2012-03-27 05:01:51 +02:00
|
|
|
import com.gmail.nossr50.events.fake.FakePlayerAnimationEvent;
|
2013-01-22 18:43:25 +01:00
|
|
|
import com.gmail.nossr50.skills.SkillType;
|
|
|
|
import com.gmail.nossr50.skills.Skills;
|
2012-03-21 03:33:58 +01:00
|
|
|
import com.gmail.nossr50.spout.SpoutSounds;
|
2012-04-27 11:47:11 +02:00
|
|
|
import com.gmail.nossr50.util.Misc;
|
2012-05-17 23:03:56 +02:00
|
|
|
import com.gmail.nossr50.util.ModChecks;
|
2012-04-27 11:47:11 +02:00
|
|
|
import com.gmail.nossr50.util.Permissions;
|
|
|
|
import com.gmail.nossr50.util.Users;
|
2012-02-23 08:12:24 +01:00
|
|
|
|
2013-01-22 22:04:05 +01:00
|
|
|
public abstract class Woodcutting {
|
2013-01-22 21:51:07 +01:00
|
|
|
public static final int DOUBLE_DROP_MAX_LEVEL = AdvancedConfig.getInstance().getMiningDoubleDropMaxLevel();
|
|
|
|
public static final double DOUBLE_DROP_CHANCE = AdvancedConfig.getInstance().getMiningDoubleDropChance();
|
|
|
|
public static final int LEAF_BLOWER_UNLOCK_LEVEL = AdvancedConfig.getInstance().getLeafBlowUnlockLevel();
|
|
|
|
public static final boolean DOUBLE_DROP_DISABLED = Config.getInstance().woodcuttingDoubleDropsDisabled();
|
2013-01-22 17:52:06 +01:00
|
|
|
|
2012-03-15 22:29:27 +01:00
|
|
|
/**
|
2013-01-23 19:37:30 +01:00
|
|
|
* Begins the Tree Feller ability
|
2012-03-15 22:29:27 +01:00
|
|
|
*
|
2013-01-22 02:14:50 +01:00
|
|
|
* @param event Event to process
|
2012-03-15 22:29:27 +01:00
|
|
|
*/
|
2013-01-22 21:51:07 +01:00
|
|
|
public static void beginTreeFeller(BlockBreakEvent event) {
|
|
|
|
TreeFeller.process(event);
|
2012-02-23 05:23:42 +01:00
|
|
|
}
|
2012-03-16 16:30:23 +01:00
|
|
|
|
|
|
|
/**
|
2013-01-23 19:37:30 +01:00
|
|
|
* Begins the Leaf Blower ability
|
2012-03-16 16:30:23 +01:00
|
|
|
*
|
2013-01-22 02:14:50 +01:00
|
|
|
* @param player Player using the ability
|
2013-01-22 21:51:07 +01:00
|
|
|
* @param block Block being broken
|
2012-03-16 16:30:23 +01:00
|
|
|
*/
|
2013-01-22 21:51:07 +01:00
|
|
|
public static void beginLeafBlower(Player player, Block block) {
|
|
|
|
mcMMO.p.getServer().getPluginManager().callEvent(new FakePlayerAnimationEvent(player));
|
2012-03-16 16:30:23 +01:00
|
|
|
|
2013-01-22 21:51:07 +01:00
|
|
|
if (mcMMO.spoutEnabled) {
|
|
|
|
SpoutSounds.playSoundForPlayer(SoundEffect.POP, player, block.getLocation());
|
2012-03-16 16:30:23 +01:00
|
|
|
}
|
2012-02-23 05:23:42 +01:00
|
|
|
}
|
2012-03-16 16:30:23 +01:00
|
|
|
|
|
|
|
/**
|
2013-01-23 19:37:30 +01:00
|
|
|
* Begins Woodcutting
|
2012-03-16 16:30:23 +01:00
|
|
|
*
|
2013-01-22 21:51:07 +01:00
|
|
|
* @param player Player breaking the block
|
|
|
|
* @param block Block being broken
|
2012-03-16 16:30:23 +01:00
|
|
|
*/
|
2013-01-22 21:51:07 +01:00
|
|
|
public static void beginWoodcutting(Player player, Block block) {
|
|
|
|
int xp = 0;
|
2012-03-16 16:30:23 +01:00
|
|
|
|
2013-01-22 21:51:07 +01:00
|
|
|
if (Config.getInstance().getBlockModsEnabled() && ModChecks.isCustomLogBlock(block)) {
|
|
|
|
xp = ModChecks.getCustomBlock(block).getXpGain();
|
2012-03-28 20:37:17 +02:00
|
|
|
}
|
2013-01-22 21:51:07 +01:00
|
|
|
else {
|
|
|
|
try {
|
|
|
|
xp = getExperienceFromLog(block);
|
2012-10-31 04:05:37 +01:00
|
|
|
}
|
2013-01-22 21:51:07 +01:00
|
|
|
catch (IllegalArgumentException exception) {
|
2013-01-22 02:14:50 +01:00
|
|
|
return;
|
2012-02-23 05:23:42 +01:00
|
|
|
}
|
|
|
|
}
|
2013-01-22 21:51:07 +01:00
|
|
|
|
|
|
|
checkDoubleDrop(player, block);
|
|
|
|
Skills.xpProcessing(player, Users.getProfile(player), SkillType.WOODCUTTING, xp);
|
2012-02-23 05:23:42 +01:00
|
|
|
}
|
2012-03-16 16:30:23 +01:00
|
|
|
|
|
|
|
/**
|
2013-01-23 19:37:30 +01:00
|
|
|
* Retrieves the experience reward from a log
|
2012-03-16 16:30:23 +01:00
|
|
|
*
|
2013-01-22 21:51:07 +01:00
|
|
|
* @param log Log being broken
|
|
|
|
* @return Amount of experience
|
|
|
|
* @throws IllegalArgumentException if 'log' is invalid
|
2012-03-16 16:30:23 +01:00
|
|
|
*/
|
2013-01-22 21:51:07 +01:00
|
|
|
protected static int getExperienceFromLog(Block log) {
|
2013-01-23 19:30:23 +01:00
|
|
|
TreeSpecies logType = TreeSpecies.getByData(extractLogItemData(log.getData()));
|
2013-01-22 02:14:50 +01:00
|
|
|
|
2013-01-22 21:51:07 +01:00
|
|
|
// Apparently species can be null in certain cases (custom server mods?)
|
|
|
|
// https://github.com/mcMMO-Dev/mcMMO/issues/229
|
|
|
|
if (logType == null) {
|
|
|
|
throw new IllegalArgumentException();
|
2012-03-16 16:30:23 +01:00
|
|
|
}
|
2013-01-10 04:43:21 +01:00
|
|
|
|
2013-01-22 21:51:07 +01:00
|
|
|
switch (logType) {
|
|
|
|
case GENERIC:
|
|
|
|
return Config.getInstance().getWoodcuttingXPOak();
|
|
|
|
case REDWOOD:
|
|
|
|
return Config.getInstance().getWoodcuttingXPSpruce();
|
|
|
|
case BIRCH:
|
|
|
|
return Config.getInstance().getWoodcuttingXPBirch();
|
|
|
|
case JUNGLE:
|
|
|
|
return Config.getInstance().getWoodcuttingXPJungle();
|
|
|
|
default:
|
|
|
|
throw new IllegalArgumentException();
|
|
|
|
}
|
2012-02-23 05:53:20 +01:00
|
|
|
}
|
2012-03-16 16:30:23 +01:00
|
|
|
|
|
|
|
/**
|
2013-01-23 19:37:30 +01:00
|
|
|
* Checks for double drops
|
2012-03-16 16:30:23 +01:00
|
|
|
*
|
|
|
|
* @param player Player breaking the block
|
2013-01-22 02:14:50 +01:00
|
|
|
* @param block Block being broken
|
2012-03-16 16:30:23 +01:00
|
|
|
*/
|
2013-01-22 21:51:07 +01:00
|
|
|
protected static void checkDoubleDrop(Player player, Block block) {
|
|
|
|
if (!Permissions.woodcuttingDoubleDrops(player)) {
|
|
|
|
return;
|
2013-01-22 02:14:50 +01:00
|
|
|
}
|
2012-07-02 17:09:55 +02:00
|
|
|
|
2013-01-22 21:51:07 +01:00
|
|
|
int chance = (int) ((DOUBLE_DROP_CHANCE / DOUBLE_DROP_MAX_LEVEL) * Users.getProfile(player).getSkillLevel(SkillType.WOODCUTTING));
|
2013-01-22 02:01:33 +01:00
|
|
|
int activationChance = Misc.calculateActivationChance(Permissions.luckyWoodcutting(player));
|
2012-07-02 17:09:55 +02:00
|
|
|
|
2013-01-22 21:51:07 +01:00
|
|
|
if (chance > DOUBLE_DROP_CHANCE) {
|
|
|
|
chance = (int) DOUBLE_DROP_CHANCE;
|
2012-03-16 16:30:23 +01:00
|
|
|
}
|
|
|
|
|
2013-01-22 21:51:07 +01:00
|
|
|
if (chance <= Misc.getRandom().nextInt(activationChance)) {
|
2012-03-16 16:30:23 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-05-17 23:03:56 +02:00
|
|
|
if (Config.getInstance().getBlockModsEnabled() && ModChecks.isCustomLogBlock(block)) {
|
2013-01-22 21:51:07 +01:00
|
|
|
CustomBlock customBlock = ModChecks.getCustomBlock(block);
|
|
|
|
int minimumDropAmount = customBlock.getMinimumDropAmount();
|
|
|
|
int maximumDropAmount = customBlock.getMaximumDropAmount();
|
|
|
|
Location location = block.getLocation();
|
|
|
|
ItemStack item = customBlock.getItemDrop();
|
2012-11-10 21:43:08 +01:00
|
|
|
|
2013-01-22 21:51:07 +01:00
|
|
|
Misc.dropItems(location, item, minimumDropAmount);
|
2012-11-10 21:43:08 +01:00
|
|
|
|
2013-01-22 21:51:07 +01:00
|
|
|
if (minimumDropAmount != maximumDropAmount) {
|
|
|
|
Misc.randomDropItems(location, item, 50, maximumDropAmount - minimumDropAmount);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
2013-01-22 23:44:53 +01:00
|
|
|
byte blockData = block.getData();
|
2013-01-22 21:51:07 +01:00
|
|
|
Location location = block.getLocation();
|
2013-01-22 23:44:53 +01:00
|
|
|
ItemStack item = new ItemStack(Material.LOG, 1, blockData);
|
2012-07-09 15:26:22 +02:00
|
|
|
|
2013-01-23 19:30:23 +01:00
|
|
|
switch (TreeSpecies.getByData(extractLogItemData(blockData))) {
|
2012-05-17 23:03:56 +02:00
|
|
|
case GENERIC:
|
2013-01-22 21:51:07 +01:00
|
|
|
if (Config.getInstance().getOakDoubleDropsEnabled()) {
|
|
|
|
Misc.dropItem(location, item);
|
|
|
|
}
|
2012-05-17 23:03:56 +02:00
|
|
|
break;
|
|
|
|
case REDWOOD:
|
2013-01-22 21:51:07 +01:00
|
|
|
if (Config.getInstance().getSpruceDoubleDropsEnabled()) {
|
|
|
|
Misc.dropItem(location, item);
|
|
|
|
}
|
2012-05-17 23:03:56 +02:00
|
|
|
break;
|
|
|
|
case BIRCH:
|
2013-01-22 21:51:07 +01:00
|
|
|
if (Config.getInstance().getBirchDoubleDropsEnabled()) {
|
|
|
|
Misc.dropItem(location, item);
|
|
|
|
}
|
2012-05-17 23:03:56 +02:00
|
|
|
break;
|
|
|
|
case JUNGLE:
|
2013-01-22 21:51:07 +01:00
|
|
|
if (Config.getInstance().getJungleDoubleDropsEnabled()) {
|
|
|
|
Misc.dropItem(location, item);
|
|
|
|
}
|
2012-05-17 23:03:56 +02:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
2012-03-16 16:30:23 +01:00
|
|
|
}
|
2012-03-28 20:37:17 +02:00
|
|
|
}
|
2013-01-23 19:30:23 +01:00
|
|
|
|
|
|
|
/**
|
2013-01-23 19:37:30 +01:00
|
|
|
* Extracts the log type from the block data (i.e. removes rotation)
|
2013-01-23 19:30:23 +01:00
|
|
|
*
|
|
|
|
* @param data Original block data
|
|
|
|
* @return Extracted log type
|
|
|
|
*/
|
|
|
|
protected static byte extractLogItemData(byte data) {
|
|
|
|
return (byte) (data & 0x3);
|
|
|
|
}
|
2012-01-09 20:00:13 +01:00
|
|
|
}
|