mirror of
https://github.com/mcMMO-Dev/mcMMO.git
synced 2024-11-23 13:46:46 +01:00
Optimizations for Mining & Blast Mining
This commit is contained in:
parent
e1644d3c08
commit
798cc3bbb3
@ -20,7 +20,6 @@ import java.util.ArrayList;
|
|||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import org.bukkit.Location;
|
|
||||||
import org.bukkit.block.Block;
|
import org.bukkit.block.Block;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.event.entity.EntityDamageEvent;
|
import org.bukkit.event.entity.EntityDamageEvent;
|
||||||
@ -30,13 +29,23 @@ import org.bukkit.event.entity.ExplosionPrimeEvent;
|
|||||||
import com.gmail.nossr50.Users;
|
import com.gmail.nossr50.Users;
|
||||||
import com.gmail.nossr50.m;
|
import com.gmail.nossr50.m;
|
||||||
import com.gmail.nossr50.mcMMO;
|
import com.gmail.nossr50.mcMMO;
|
||||||
import com.gmail.nossr50.config.LoadProperties;
|
|
||||||
import com.gmail.nossr50.datatypes.PlayerProfile;
|
|
||||||
import com.gmail.nossr50.datatypes.SkillType;
|
import com.gmail.nossr50.datatypes.SkillType;
|
||||||
|
|
||||||
public class BlastMining{
|
public class BlastMining{
|
||||||
|
|
||||||
public static List<Block> explosionYields(List<Block> ores, List<Block> debris, float yield, float oreBonus, float debrisReduction, Location location, int extraDrops)
|
/**
|
||||||
|
* Handler for what blocks drop from the explosion.
|
||||||
|
*
|
||||||
|
* @param ores List of ore blocks destroyed by the explosion
|
||||||
|
* @param debris List of non-ore blocks destroyed by the explosion
|
||||||
|
* @param yield Percentage of blocks to drop
|
||||||
|
* @param oreBonus Percentage bonus for ore drops
|
||||||
|
* @param debrisReduction Percentage reduction for non-ore drops
|
||||||
|
* @param extraDrops Number of times to drop each block
|
||||||
|
* @param plugin mcMMO plugin instance
|
||||||
|
* @return A list of blocks dropped from the explosion
|
||||||
|
*/
|
||||||
|
private static List<Block> explosionYields(List<Block> ores, List<Block> debris, float yield, float oreBonus, float debrisReduction, int extraDrops, mcMMO plugin)
|
||||||
{
|
{
|
||||||
Iterator<Block> iterator2 = ores.iterator();
|
Iterator<Block> iterator2 = ores.iterator();
|
||||||
List<Block> blocksDropped = new ArrayList<Block>();
|
List<Block> blocksDropped = new ArrayList<Block>();
|
||||||
@ -47,15 +56,18 @@ public class BlastMining{
|
|||||||
{
|
{
|
||||||
blocksDropped.add(temp);
|
blocksDropped.add(temp);
|
||||||
Mining.miningDrops(temp);
|
Mining.miningDrops(temp);
|
||||||
if(extraDrops == 2)
|
if(temp.getData() != (byte)5 && !plugin.misc.blockWatchList.contains(temp))
|
||||||
{
|
{
|
||||||
blocksDropped.add(temp);
|
if(extraDrops == 2)
|
||||||
Mining.miningDrops(temp);
|
{
|
||||||
}
|
blocksDropped.add(temp);
|
||||||
if(extraDrops == 3)
|
Mining.miningDrops(temp);
|
||||||
{
|
}
|
||||||
blocksDropped.add(temp);
|
if(extraDrops == 3)
|
||||||
Mining.miningDrops(temp);
|
{
|
||||||
|
blocksDropped.add(temp);
|
||||||
|
Mining.miningDrops(temp);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -73,32 +85,30 @@ public class BlastMining{
|
|||||||
return blocksDropped;
|
return blocksDropped;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* Process the drops from the explosion
|
* Handler for explosion drops and XP gain.
|
||||||
|
* @param player Player triggering the explosion
|
||||||
|
* @param event Event whose explosion is being processed
|
||||||
|
* @param plugin mcMMO plugin instance
|
||||||
*/
|
*/
|
||||||
public static void dropProcessing(Player player, EntityExplodeEvent event, mcMMO plugin)
|
public static void dropProcessing(Player player, EntityExplodeEvent event, mcMMO plugin)
|
||||||
{
|
{
|
||||||
int skillLevel = Users.getProfile(player).getSkillLevel(SkillType.MINING);
|
int skillLevel = Users.getProfile(player).getSkillLevel(SkillType.MINING);
|
||||||
float yield = event.getYield();
|
float yield = event.getYield();
|
||||||
Location location = event.getLocation();
|
|
||||||
List<Block> blocks = event.blockList();
|
List<Block> blocks = event.blockList();
|
||||||
Iterator<Block> iterator = blocks.iterator();
|
Iterator<Block> iterator = blocks.iterator();
|
||||||
|
|
||||||
List<Block> ores = new ArrayList<Block>();
|
List<Block> ores = new ArrayList<Block>();
|
||||||
List<Block> debris = new ArrayList<Block>();
|
List<Block> debris = new ArrayList<Block>();
|
||||||
|
|
||||||
List<Block> xp = new ArrayList<Block>();
|
List<Block> xp = new ArrayList<Block>();
|
||||||
|
|
||||||
while(iterator.hasNext())
|
while(iterator.hasNext())
|
||||||
{
|
{
|
||||||
Block temp = iterator.next();
|
Block temp = iterator.next();
|
||||||
if(temp.getData() != 5 && !plugin.misc.blockWatchList.contains(temp))
|
if(m.isOre(temp))
|
||||||
{
|
ores.add(temp);
|
||||||
if(m.isOre(temp))
|
else
|
||||||
ores.add(temp);
|
debris.add(temp);
|
||||||
else
|
|
||||||
debris.add(temp);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Normal explosion
|
//Normal explosion
|
||||||
@ -106,51 +116,52 @@ public class BlastMining{
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
event.setYield(0);
|
event.setYield(0);
|
||||||
|
|
||||||
//+35% ores, -10% debris
|
//+35% ores, -10% debris
|
||||||
if(skillLevel >= 125 && skillLevel < 250)
|
if(skillLevel >= 125 && skillLevel < 250)
|
||||||
xp = explosionYields(ores, debris, yield, .35f, .10f, location, 1);
|
xp = explosionYields(ores, debris, yield, .35f, .10f, 1, plugin);
|
||||||
|
|
||||||
//+40% ores, -20% debris
|
//+40% ores, -20% debris
|
||||||
if(skillLevel >= 250 && skillLevel < 375)
|
if(skillLevel >= 250 && skillLevel < 375)
|
||||||
xp = explosionYields(ores, debris, yield, .40f, .20f, location, 1);
|
xp = explosionYields(ores, debris, yield, .40f, .20f, 1, plugin);
|
||||||
|
|
||||||
//No debris, +45% ores
|
//No debris, +45% ores
|
||||||
if(skillLevel >= 375 && skillLevel < 500)
|
if(skillLevel >= 375 && skillLevel < 500)
|
||||||
xp = explosionYields(ores, debris, yield, .45f, .30f, location, 1);
|
xp = explosionYields(ores, debris, yield, .45f, .30f, 1, plugin);
|
||||||
|
|
||||||
//No debris, +50% ores
|
//No debris, +50% ores
|
||||||
if(skillLevel >= 500 && skillLevel < 625)
|
if(skillLevel >= 500 && skillLevel < 625)
|
||||||
xp = explosionYields(ores, debris, yield, .50f, .30f, location, 1);
|
xp = explosionYields(ores, debris, yield, .50f, .30f, 1, plugin);
|
||||||
|
|
||||||
//Double Drops, No Debris, +55% ores
|
//Double Drops, No Debris, +55% ores
|
||||||
if(skillLevel >= 625 && skillLevel < 750)
|
if(skillLevel >= 625 && skillLevel < 750)
|
||||||
xp = explosionYields(ores, debris, yield, .55f, .30f, location, 2);
|
xp = explosionYields(ores, debris, yield, .55f, .30f, 2, plugin);
|
||||||
|
|
||||||
//Double Drops, No Debris, +60% ores
|
//Double Drops, No Debris, +60% ores
|
||||||
if(skillLevel >= 750 && skillLevel < 875)
|
if(skillLevel >= 750 && skillLevel < 875)
|
||||||
xp = explosionYields(ores, debris, yield, .60f, .30f, location, 2);
|
xp = explosionYields(ores, debris, yield, .60f, .30f, 2, plugin);
|
||||||
|
|
||||||
//Triple Drops, No debris, +65% ores
|
//Triple Drops, No debris, +65% ores
|
||||||
if(skillLevel >= 875 && skillLevel < 1000)
|
if(skillLevel >= 875 && skillLevel < 1000)
|
||||||
xp = explosionYields(ores, debris, yield, .65f, .30f, location, 3);
|
xp = explosionYields(ores, debris, yield, .65f, .30f, 3, plugin);
|
||||||
|
|
||||||
//Triple Drops, No debris, +70% ores
|
//Triple Drops, No debris, +70% ores
|
||||||
if(skillLevel >= 1000)
|
if(skillLevel >= 1000)
|
||||||
xp = explosionYields(ores, debris, yield, .70f, .30f, location, 3);
|
xp = explosionYields(ores, debris, yield, .70f, .30f, 3, plugin);
|
||||||
|
|
||||||
for(Block block : xp)
|
for(Block block : xp)
|
||||||
{
|
{
|
||||||
blastMiningXP(player, block, plugin);
|
if(block.getData() != (byte)5 && !plugin.misc.blockWatchList.contains(block))
|
||||||
|
Mining.miningXP(player, block);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* Bigger Bombs (Unlocked at Mining 250)
|
* Increases the blast radius of the explosion.
|
||||||
*
|
*
|
||||||
* Increases radius of explosion by 1 at 250.
|
* @param player Player triggering the explosion
|
||||||
* Increases radius of explosion by 2 at 500.
|
* @param event Event whose explosion radius is being changed
|
||||||
* Increases radius of explosion by 3 at 750.
|
|
||||||
* Increases radius of explosion by 4 at 1000.
|
|
||||||
*/
|
*/
|
||||||
public static void biggerBombs(Player player, ExplosionPrimeEvent event)
|
public static void biggerBombs(Player player, ExplosionPrimeEvent event)
|
||||||
{
|
{
|
||||||
@ -169,12 +180,11 @@ public class BlastMining{
|
|||||||
event.setRadius(radius);
|
event.setRadius(radius);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/**
|
||||||
* Demolitions Expertise (Unlocked at Mining 500)
|
* Decreases damage dealt by the explosion.
|
||||||
*
|
*
|
||||||
* Reduces explosion damage to 1/4 of normal at 500.
|
* @param player Player triggering the explosion
|
||||||
* Reduces explosion damage to 1/2 of normal at 750.
|
* @param event Event whose explosion damage is being reduced
|
||||||
* Reduces explosion damage to 0 at 1000.
|
|
||||||
*/
|
*/
|
||||||
public static void demolitionsExpertise(Player player, EntityDamageEvent event)
|
public static void demolitionsExpertise(Player player, EntityDamageEvent event)
|
||||||
{
|
{
|
||||||
@ -188,46 +198,8 @@ public class BlastMining{
|
|||||||
damage = damage/2;
|
damage = damage/2;
|
||||||
if(skill >= 1000)
|
if(skill >= 1000)
|
||||||
damage = 0;
|
damage = 0;
|
||||||
|
|
||||||
event.setDamage(damage);
|
event.setDamage(damage);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void blastMiningXP(Player player, Block block, mcMMO plugin)
|
|
||||||
{
|
|
||||||
PlayerProfile PP = Users.getProfile(player);
|
|
||||||
if(plugin.misc.blockWatchList.contains(block) || block.getData() == (byte) 5)
|
|
||||||
return;
|
|
||||||
int xp = 0;
|
|
||||||
|
|
||||||
switch (block.getType()) {
|
|
||||||
//COAL
|
|
||||||
case COAL_ORE:
|
|
||||||
xp += LoadProperties.mcoal;
|
|
||||||
break;
|
|
||||||
//GOLD
|
|
||||||
case GOLD_ORE:
|
|
||||||
xp += LoadProperties.mgold;
|
|
||||||
break;
|
|
||||||
//DIAMOND
|
|
||||||
case DIAMOND_ORE:
|
|
||||||
xp += LoadProperties.mdiamond;
|
|
||||||
break;
|
|
||||||
//IRON
|
|
||||||
case IRON_ORE:
|
|
||||||
xp += LoadProperties.miron;
|
|
||||||
break;
|
|
||||||
//REDSTONE
|
|
||||||
case REDSTONE_ORE:
|
|
||||||
xp += LoadProperties.mredstone;
|
|
||||||
break;
|
|
||||||
//LAPIS
|
|
||||||
case LAPIS_ORE:
|
|
||||||
xp += LoadProperties.mlapis;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
PP.addXP(SkillType.MINING, xp, player);
|
|
||||||
Skills.XpCheckSkill(SkillType.MINING, player);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -16,7 +16,6 @@
|
|||||||
*/
|
*/
|
||||||
package com.gmail.nossr50.skills;
|
package com.gmail.nossr50.skills;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
import org.bukkit.block.Block;
|
import org.bukkit.block.Block;
|
||||||
@ -24,7 +23,6 @@ import org.bukkit.entity.Player;
|
|||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
import org.getspout.spoutapi.sound.SoundEffect;
|
import org.getspout.spoutapi.sound.SoundEffect;
|
||||||
import org.bukkit.enchantments.Enchantment;
|
import org.bukkit.enchantments.Enchantment;
|
||||||
import org.bukkit.event.player.PlayerAnimationEvent;
|
|
||||||
|
|
||||||
import com.gmail.nossr50.Users;
|
import com.gmail.nossr50.Users;
|
||||||
import com.gmail.nossr50.m;
|
import com.gmail.nossr50.m;
|
||||||
@ -80,6 +78,60 @@ public class Mining
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static void miningXP(Player player, Block block)
|
||||||
|
{
|
||||||
|
PlayerProfile PP = Users.getProfile(player);
|
||||||
|
Material type = block.getType();
|
||||||
|
int xp = 0;
|
||||||
|
|
||||||
|
switch (type)
|
||||||
|
{
|
||||||
|
case COAL_ORE:
|
||||||
|
xp += LoadProperties.mcoal;
|
||||||
|
break;
|
||||||
|
case DIAMOND_ORE:
|
||||||
|
xp += LoadProperties.mdiamond;
|
||||||
|
break;
|
||||||
|
case ENDER_STONE:
|
||||||
|
xp += LoadProperties.mendstone;
|
||||||
|
break;
|
||||||
|
case GLOWING_REDSTONE_ORE:
|
||||||
|
case REDSTONE_ORE:
|
||||||
|
xp += LoadProperties.mredstone;
|
||||||
|
break;
|
||||||
|
case GLOWSTONE:
|
||||||
|
xp += LoadProperties.mglowstone;
|
||||||
|
break;
|
||||||
|
case GOLD_ORE:
|
||||||
|
xp += LoadProperties.mgold;
|
||||||
|
break;
|
||||||
|
case IRON_ORE:
|
||||||
|
xp += LoadProperties.miron;
|
||||||
|
break;
|
||||||
|
case LAPIS_ORE:
|
||||||
|
xp += LoadProperties.mlapis;
|
||||||
|
break;
|
||||||
|
case MOSSY_COBBLESTONE:
|
||||||
|
xp += LoadProperties.mmossstone;
|
||||||
|
break;
|
||||||
|
case NETHERRACK:
|
||||||
|
xp += LoadProperties.mnetherrack;
|
||||||
|
break;
|
||||||
|
case OBSIDIAN:
|
||||||
|
xp += LoadProperties.mobsidian;
|
||||||
|
break;
|
||||||
|
case SANDSTONE:
|
||||||
|
xp += LoadProperties.msandstone;
|
||||||
|
break;
|
||||||
|
case STONE:
|
||||||
|
xp += LoadProperties.mstone;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
PP.addXP(SkillType.MINING, xp, player);
|
||||||
|
Skills.XpCheckSkill(SkillType.MINING, player);
|
||||||
|
}
|
||||||
|
|
||||||
public static void blockProcSimulate(Block block, Player player)
|
public static void blockProcSimulate(Block block, Player player)
|
||||||
{
|
{
|
||||||
//Drop natural block with Silk Touch
|
//Drop natural block with Silk Touch
|
||||||
@ -99,58 +151,11 @@ public class Mining
|
|||||||
|
|
||||||
public static void miningBlockCheck(Player player, Block block, mcMMO plugin)
|
public static void miningBlockCheck(Player player, Block block, mcMMO plugin)
|
||||||
{
|
{
|
||||||
PlayerProfile PP = Users.getProfile(player);
|
|
||||||
if(plugin.misc.blockWatchList.contains(block) || block.getData() == (byte) 5)
|
if(plugin.misc.blockWatchList.contains(block) || block.getData() == (byte) 5)
|
||||||
return;
|
return;
|
||||||
int xp = 0;
|
miningXP(player, block);
|
||||||
Material type = block.getType();
|
|
||||||
|
|
||||||
switch (type) {
|
|
||||||
case STONE:
|
|
||||||
xp += LoadProperties.mstone;
|
|
||||||
break;
|
|
||||||
case SANDSTONE:
|
|
||||||
xp += LoadProperties.msandstone;
|
|
||||||
break;
|
|
||||||
case OBSIDIAN:
|
|
||||||
xp += LoadProperties.mobsidian;
|
|
||||||
break;
|
|
||||||
case NETHERRACK:
|
|
||||||
xp += LoadProperties.mnetherrack;
|
|
||||||
break;
|
|
||||||
case GLOWSTONE:
|
|
||||||
xp += LoadProperties.mglowstone;
|
|
||||||
break;
|
|
||||||
case COAL_ORE:
|
|
||||||
xp += LoadProperties.mcoal;
|
|
||||||
break;
|
|
||||||
case GOLD_ORE:
|
|
||||||
xp += LoadProperties.mgold;
|
|
||||||
break;
|
|
||||||
case DIAMOND_ORE:
|
|
||||||
xp += LoadProperties.mdiamond;
|
|
||||||
break;
|
|
||||||
case IRON_ORE:
|
|
||||||
xp += LoadProperties.miron;
|
|
||||||
break;
|
|
||||||
case GLOWING_REDSTONE_ORE:
|
|
||||||
case REDSTONE_ORE:
|
|
||||||
xp += LoadProperties.mredstone;
|
|
||||||
break;
|
|
||||||
case LAPIS_ORE:
|
|
||||||
xp += LoadProperties.mlapis;
|
|
||||||
break;
|
|
||||||
case ENDER_STONE:
|
|
||||||
xp += LoadProperties.mendstone;
|
|
||||||
break;
|
|
||||||
case MOSSY_COBBLESTONE:
|
|
||||||
xp += LoadProperties.mmossstone;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if(canBeSuperBroken(block))
|
if(canBeSuperBroken(block))
|
||||||
blockProcCheck(block, player);
|
blockProcCheck(block, player);
|
||||||
PP.addXP(SkillType.MINING, xp, player);
|
|
||||||
Skills.XpCheckSkill(SkillType.MINING, player);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -180,114 +185,42 @@ public class Mining
|
|||||||
|
|
||||||
public static void SuperBreakerBlockCheck(Player player, Block block, mcMMO plugin)
|
public static void SuperBreakerBlockCheck(Player player, Block block, mcMMO plugin)
|
||||||
{
|
{
|
||||||
PlayerProfile PP = Users.getProfile(player);
|
|
||||||
Material type = block.getType();
|
Material type = block.getType();
|
||||||
|
int tier = m.getTier(player);
|
||||||
|
int durabilityLoss = LoadProperties.abilityDurabilityLoss;
|
||||||
|
|
||||||
//Obsidian needs to do more damage than normal
|
switch(type)
|
||||||
if(type != Material.OBSIDIAN)
|
{
|
||||||
Skills.abilityDurabilityLoss(player.getItemInHand(), LoadProperties.abilityDurabilityLoss);
|
case OBSIDIAN:
|
||||||
else
|
if(tier < 4)
|
||||||
Skills.abilityDurabilityLoss(player.getItemInHand(), LoadProperties.abilityDurabilityLoss*5);
|
return;
|
||||||
|
durabilityLoss = durabilityLoss * 5; //Obsidian needs to do more damage than normal
|
||||||
//Pre-processing
|
case DIAMOND_ORE:
|
||||||
int xp = 0;
|
case GLOWING_REDSTONE_ORE:
|
||||||
PlayerAnimationEvent armswing = new PlayerAnimationEvent(player);
|
case GOLD_ORE:
|
||||||
|
case LAPIS_ORE:
|
||||||
if(type.equals(Material.STONE) && block.getData() != (byte) 5)
|
case REDSTONE_ORE:
|
||||||
{
|
if(tier < 3)
|
||||||
Bukkit.getPluginManager().callEvent(armswing);
|
return;
|
||||||
xp += LoadProperties.mstone;
|
case IRON_ORE:
|
||||||
|
if(tier < 2)
|
||||||
|
return;
|
||||||
|
case COAL_ORE:
|
||||||
|
case ENDER_STONE:
|
||||||
|
case GLOWSTONE:
|
||||||
|
case MOSSY_COBBLESTONE:
|
||||||
|
case NETHERRACK:
|
||||||
|
case SANDSTONE:
|
||||||
|
case STONE:
|
||||||
|
if((block.getData() == (byte) 5) || plugin.misc.blockWatchList.contains(block))
|
||||||
|
return;
|
||||||
|
Skills.abilityDurabilityLoss(player.getItemInHand(), durabilityLoss);
|
||||||
|
blockProcCheck(block, player);
|
||||||
blockProcCheck(block, player);
|
blockProcCheck(block, player);
|
||||||
blockProcCheck(block, player);
|
if(!plugin.misc.blockWatchList.contains(block) && block.getData() != (byte) 5)
|
||||||
}
|
miningXP(player, block);
|
||||||
else if(type.equals(Material.SANDSTONE) && block.getData() != (byte) 5)
|
if(LoadProperties.spoutEnabled)
|
||||||
{
|
SpoutStuff.playSoundForPlayer(SoundEffect.POP, player, block.getLocation());
|
||||||
Bukkit.getPluginManager().callEvent(armswing);
|
}
|
||||||
xp += LoadProperties.msandstone;
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
}
|
|
||||||
else if(type.equals(Material.NETHERRACK) && block.getData() != (byte) 5)
|
|
||||||
{
|
|
||||||
Bukkit.getPluginManager().callEvent(armswing);
|
|
||||||
xp += LoadProperties.mnetherrack;
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
}
|
|
||||||
else if(type.equals(Material.GLOWSTONE) && block.getData() != (byte) 5)
|
|
||||||
{
|
|
||||||
Bukkit.getPluginManager().callEvent(armswing);
|
|
||||||
xp += LoadProperties.mglowstone;
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
}
|
|
||||||
else if(type.equals(Material.COAL_ORE) && block.getData() != (byte) 5)
|
|
||||||
{
|
|
||||||
Bukkit.getPluginManager().callEvent(armswing);
|
|
||||||
xp += LoadProperties.mcoal;
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
}
|
|
||||||
else if(type.equals(Material.GOLD_ORE) && m.getTier(player) >= 3 && block.getData() != (byte) 5)
|
|
||||||
{
|
|
||||||
Bukkit.getPluginManager().callEvent(armswing);
|
|
||||||
xp += LoadProperties.mgold;
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
}
|
|
||||||
else if(type.equals(Material.OBSIDIAN) && m.getTier(player) >= 4 && block.getData() != (byte) 5)
|
|
||||||
{
|
|
||||||
Bukkit.getPluginManager().callEvent(armswing);
|
|
||||||
xp += LoadProperties.mobsidian;
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
}
|
|
||||||
else if(type.equals(Material.DIAMOND_ORE) && m.getTier(player) >= 3 && block.getData() != (byte) 5)
|
|
||||||
{
|
|
||||||
Bukkit.getPluginManager().callEvent(armswing);
|
|
||||||
xp += LoadProperties.mdiamond;
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
}
|
|
||||||
else if(type.equals(Material.IRON_ORE) && m.getTier(player) >= 2 && block.getData() != (byte) 5)
|
|
||||||
{
|
|
||||||
Bukkit.getPluginManager().callEvent(armswing);
|
|
||||||
xp += LoadProperties.miron;
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
}
|
|
||||||
else if((type.equals(Material.GLOWING_REDSTONE_ORE) || type.equals(Material.REDSTONE_ORE)) && m.getTier(player) >= 3 && !plugin.misc.blockWatchList.contains(block))
|
|
||||||
{
|
|
||||||
Bukkit.getPluginManager().callEvent(armswing);
|
|
||||||
xp += LoadProperties.mredstone;
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
}
|
|
||||||
else if(type.equals(Material.LAPIS_ORE) && m.getTier(player) >= 3 && block.getData() != (byte) 5)
|
|
||||||
{
|
|
||||||
Bukkit.getPluginManager().callEvent(armswing);
|
|
||||||
xp += LoadProperties.mlapis;
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
}
|
|
||||||
else if(type.equals(Material.ENDER_STONE) && block.getData() != (byte) 5)
|
|
||||||
{
|
|
||||||
Bukkit.getPluginManager().callEvent(armswing);
|
|
||||||
xp += LoadProperties.mendstone;
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
}
|
|
||||||
else if(type.equals(Material.MOSSY_COBBLESTONE) && block.getData() != (byte) 5)
|
|
||||||
{
|
|
||||||
Bukkit.getPluginManager().callEvent(armswing);
|
|
||||||
xp += LoadProperties.mmossstone;
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
blockProcCheck(block, player);
|
|
||||||
}
|
|
||||||
if(!plugin.misc.blockWatchList.contains(block) && block.getData() != (byte) 5)
|
|
||||||
PP.addXP(SkillType.MINING, xp, player);
|
|
||||||
if(LoadProperties.spoutEnabled)
|
|
||||||
SpoutStuff.playSoundForPlayer(SoundEffect.POP, player, block.getLocation());
|
|
||||||
Skills.XpCheckSkill(SkillType.MINING, player);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user