| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415 |
- package com.gmail.nossr50.skills;
- import org.bukkit.Location;
- import org.bukkit.Material;
- import org.bukkit.Statistic;
- import org.bukkit.block.Block;
- import org.bukkit.entity.Player;
- import org.bukkit.inventory.ItemStack;
- import org.getspout.spoutapi.sound.SoundEffect;
- import com.gmail.nossr50.Users;
- import com.gmail.nossr50.m;
- import com.gmail.nossr50.mcMMO;
- import com.gmail.nossr50.config.LoadProperties;
- import com.gmail.nossr50.spout.SpoutStuff;
- import com.gmail.nossr50.datatypes.PlayerProfile;
- import com.gmail.nossr50.datatypes.SkillType;
- import com.gmail.nossr50.locale.mcLocale;
- public class Mining
- {
- public static void superBreakerCheck(Player player, Block block)
- {
- PlayerProfile PP = Users.getProfile(player);
- if(m.isMiningPick(player.getItemInHand()))
- {
- if(block != null)
- {
- if(!m.abilityBlockCheck(block))
- return;
- }
- if(PP.getPickaxePreparationMode())
- {
- PP.setPickaxePreparationMode(false);
- }
-
- int ticks = 2;
- int x = PP.getSkillLevel(SkillType.MINING);
-
- while(x >= 50)
- {
- x-=50;
- ticks++;
- }
-
- if(!PP.getSuperBreakerMode() && Skills.cooldownOver(player, PP.getSuperBreakerDeactivatedTimeStamp(), LoadProperties.superBreakerCooldown)){
- player.sendMessage(mcLocale.getString("Skills.SuperBreakerOn"));
- for(Player y : player.getWorld().getPlayers())
- {
- if(y != null && y != player && m.getDistance(player.getLocation(), y.getLocation()) < 10)
- y.sendMessage(mcLocale.getString("Skills.SuperBreakerPlayer", new Object[] {player.getName()}));
- }
- PP.setSuperBreakerActivatedTimeStamp(System.currentTimeMillis());
- PP.setSuperBreakerDeactivatedTimeStamp(System.currentTimeMillis() + (ticks * 1000));
- PP.setSuperBreakerMode(true);
- }
-
- }
- }
- public static void blockProcSimulate(Block block)
- {
- Location loc = block.getLocation();
- Material mat = Material.getMaterial(block.getTypeId());
- byte damage = 0;
- ItemStack item = new ItemStack(mat, 1, (byte)0, damage);
- if(block.getTypeId() != 89 && block.getTypeId() != 73 && block.getTypeId() != 74 && block.getTypeId() != 56
- && block.getTypeId() != 21 && block.getTypeId() != 1 && block.getTypeId() != 16)
- loc.getWorld().dropItemNaturally(loc, item);
- if(block.getTypeId() == 89)
- {
- mat = Material.getMaterial(348);
- item = new ItemStack(mat, 1, (byte)0, damage);
- loc.getWorld().dropItemNaturally(loc, item);
- }
- if(block.getTypeId() == 73 || block.getTypeId() == 74)
- {
- mat = Material.getMaterial(331);
- item = new ItemStack(mat, 1, (byte)0, damage);
- loc.getWorld().dropItemNaturally(loc, item);
- loc.getWorld().dropItemNaturally(loc, item);
- loc.getWorld().dropItemNaturally(loc, item);
- if(Math.random() * 10 > 5){
- loc.getWorld().dropItemNaturally(loc, item);
- }
- }
- if(block.getTypeId() == 21)
- {
- mat = Material.getMaterial(351);
- item = new ItemStack(mat, 1, (byte)0,(byte)0x4);
- loc.getWorld().dropItemNaturally(loc, item);
- loc.getWorld().dropItemNaturally(loc, item);
- loc.getWorld().dropItemNaturally(loc, item);
- loc.getWorld().dropItemNaturally(loc, item);
- }
- if(block.getTypeId() == 56)
- {
- mat = Material.getMaterial(264);
- item = new ItemStack(mat, 1, (byte)0, damage);
- loc.getWorld().dropItemNaturally(loc, item);
- }
- if(block.getTypeId() == 1)
- {
- mat = Material.getMaterial(4);
- item = new ItemStack(mat, 1, (byte)0, damage);
- loc.getWorld().dropItemNaturally(loc, item);
- }
- if(block.getTypeId() == 16)
- {
- mat = Material.getMaterial(263);
- item = new ItemStack(mat, 1, (byte)0, damage);
- loc.getWorld().dropItemNaturally(loc, item);
- }
- }
- public static void blockProcCheck(Block block, Player player)
- {
- PlayerProfile PP = Users.getProfile(player);
- if(Math.random() * 1000 <= PP.getSkillLevel(SkillType.MINING))
- {
- blockProcSimulate(block);
- return;
- }
- }
-
- public static void miningBlockCheck(Boolean smelt, 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;
- if(block.getTypeId() == 1 || block.getTypeId() == 24)
- {
- xp += LoadProperties.mstone;
- if(smelt = false)
- blockProcCheck(block, player);
- else
- blockProcCheck(block, player);
- }
- //OBSIDIAN
- if(block.getTypeId() == 49)
- {
- xp += LoadProperties.mobsidian;
- if(smelt = false)
- blockProcCheck(block, player);
- else
- blockProcCheck(block, player);
- }
- //NETHERRACK
- if(block.getTypeId() == 87)
- {
- xp += LoadProperties.mnetherrack;
- if(smelt = false)
- blockProcCheck(block, player);
- else
- blockProcCheck(block, player);
- }
- //GLOWSTONE
- if(block.getTypeId() == 89)
- {
- xp += LoadProperties.mglowstone;
- if(smelt = false)
- blockProcCheck(block, player);
- else
- blockProcCheck(block, player);
- }
- //COAL
- if(block.getTypeId() == 16)
- {
- xp += LoadProperties.mcoal;
- if(smelt = false)
- blockProcCheck(block, player);
- else
- blockProcCheck(block, player);
- }
- //GOLD
- if(block.getTypeId() == 14)
- {
- xp += LoadProperties.mgold;
- if(smelt = false)
- blockProcCheck(block, player);
- else
- blockProcCheck(block, player);
- }
- //DIAMOND
- if(block.getTypeId() == 56){
- xp += LoadProperties.mdiamond;
- if(smelt = false)
- blockProcCheck(block, player);
- else
- blockProcCheck(block, player);
- }
- //IRON
- if(block.getTypeId() == 15)
- {
- xp += LoadProperties.miron;
- if(smelt = false)
- blockProcCheck(block, player);
- else
- blockProcCheck(block, player);
- }
- //REDSTONE
- if(block.getTypeId() == 73 || block.getTypeId() == 74)
- {
- xp += LoadProperties.mredstone;
- if(smelt = false)
- blockProcCheck(block, player);
- else
- blockProcCheck(block, player);
- }
- //LAPUS
- if(block.getTypeId() == 21)
- {
- xp += LoadProperties.mlapis;
- if(smelt = false)
- blockProcCheck(block, player);
- else
- blockProcCheck(block, player);
- }
- PP.addXP(SkillType.MINING, xp);
- Skills.XpCheckSkill(SkillType.MINING, player);
- }
- /*
- * Handling SuperBreaker stuff
- */
- public static Boolean canBeSuperBroken(Block block)
- {
- int t = block.getTypeId();
- if(t == 49 || t == 87 || t == 89 || t == 73 || t == 74 || t == 56 || t == 21 || t == 1 || t == 16 || t == 14 || t == 15)
- {
- return true;
- } else {
- return false;
- }
- }
-
- public static void SuperBreakerBlockCheck(Player player, Block block, mcMMO plugin)
- {
- PlayerProfile PP = Users.getProfile(player);
- if(LoadProperties.toolsLoseDurabilityFromAbilities)
- m.damageTool(player, (short) LoadProperties.abilityDurabilityLoss);
- Location loc = block.getLocation();
- Material mat = Material.getMaterial(block.getTypeId());
- int xp = 0;
- byte damage = 0;
- ItemStack item = new ItemStack(mat, 1, (byte)0, damage);
- if(block.getTypeId() == 1 || block.getTypeId() == 24)
- {
- if(block.getTypeId() == 1)
- {
- mat = Material.COBBLESTONE;
- if(!plugin.misc.blockWatchList.contains(block) && block.getData() != (byte) 5)
- {
- xp += LoadProperties.mstone;
- blockProcCheck(block, player);
- blockProcCheck(block, player);
- }
- } else
- {
- mat = Material.SANDSTONE;
- if(!plugin.misc.blockWatchList.contains(block) && block.getData() != (byte) 5)
- {
- xp += LoadProperties.msandstone;
- blockProcCheck(block, player);
- blockProcCheck(block, player);
- }
- }
- item = new ItemStack(mat, 1, (byte)0, damage);
- loc.getWorld().dropItemNaturally(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //NETHERRACK
- if(block.getTypeId() == 87)
- {
- if(!plugin.misc.blockWatchList.contains(block)&& block.getData() != (byte) 5){
- xp += LoadProperties.mnetherrack;
- blockProcCheck(block, player);
- blockProcCheck(block, player);
- }
- mat = Material.getMaterial(87);
- item = new ItemStack(mat, 1, (byte)0, damage);
- loc.getWorld().dropItemNaturally(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //GLOWSTONE
- if(block.getTypeId() == 89)
- {
- if(!plugin.misc.blockWatchList.contains(block)&& block.getData() != (byte) 5){
- xp += LoadProperties.mglowstone;
- blockProcCheck(block, player);
- blockProcCheck(block, player);
- }
- mat = Material.getMaterial(348);
- item = new ItemStack(mat, 1, (byte)0, damage);
- loc.getWorld().dropItemNaturally(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //COAL
- if(block.getTypeId() == 16)
- {
- if(!plugin.misc.blockWatchList.contains(block)&& block.getData() != (byte) 5){
- xp += LoadProperties.mcoal;
- blockProcCheck(block, player);
- blockProcCheck(block, player);
- }
- mat = Material.getMaterial(263);
- item = new ItemStack(mat, 1, (byte)0, damage);
- loc.getWorld().dropItemNaturally(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //GOLD
- if(block.getTypeId() == 14 && m.getTier(player) >= 3)
- {
- if(!plugin.misc.blockWatchList.contains(block)&& block.getData() != (byte) 5){
- xp += LoadProperties.mgold;
- blockProcCheck(block, player);
- blockProcCheck(block, player);
- }
- item = new ItemStack(mat, 1, (byte)0, damage);
- loc.getWorld().dropItemNaturally(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //OBSIDIAN
- if(block.getTypeId() == 49 && m.getTier(player) >= 4)
- {
- if(LoadProperties.toolsLoseDurabilityFromAbilities)
- m.damageTool(player, (short) LoadProperties.abilityDurabilityLoss);
- if(!plugin.misc.blockWatchList.contains(block)&& block.getData() != (byte) 5){
- xp += LoadProperties.mobsidian;
- blockProcCheck(block, player);
- blockProcCheck(block, player);
- }
- mat = Material.getMaterial(49);
- item = new ItemStack(mat, 1, (byte)0, damage);
- loc.getWorld().dropItemNaturally(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //DIAMOND
- if(block.getTypeId() == 56 && m.getTier(player) >= 3)
- {
- if(!plugin.misc.blockWatchList.contains(block)&& block.getData() != (byte) 5){
- xp += LoadProperties.mdiamond;
- blockProcCheck(block, player);
- blockProcCheck(block, player);
- }
- mat = Material.getMaterial(264);
- item = new ItemStack(mat, 1, (byte)0, damage);
- loc.getWorld().dropItemNaturally(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //IRON
- if(block.getTypeId() == 15 && m.getTier(player) >= 2)
- {
- if(!plugin.misc.blockWatchList.contains(block)&& block.getData() != (byte) 5){
- xp += LoadProperties.miron;
- blockProcCheck(block, player);
- blockProcCheck(block, player);
- }
- item = new ItemStack(mat, 1, (byte)0, damage);
- loc.getWorld().dropItemNaturally(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //REDSTONE
- if((block.getTypeId() == 73 || block.getTypeId() == 74) && m.getTier(player) >= 4)
- {
- if(!plugin.misc.blockWatchList.contains(block)&& block.getData() != (byte) 5)
- {
- xp += LoadProperties.mredstone;
- blockProcCheck(block, player);
- blockProcCheck(block, player);
- }
- mat = Material.getMaterial(331);
- item = new ItemStack(mat, 1, (byte)0, damage);
- loc.getWorld().dropItemNaturally(loc, item);
- loc.getWorld().dropItemNaturally(loc, item);
- loc.getWorld().dropItemNaturally(loc, item);
- if(Math.random() * 10 > 5)
- {
- loc.getWorld().dropItemNaturally(loc, item);
- }
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //LAPUS
- if(block.getTypeId() == 21 && m.getTier(player) >= 3){
- if(!plugin.misc.blockWatchList.contains(block)&& block.getData() != (byte) 5){
- xp += LoadProperties.mlapis;
- blockProcCheck(block, player);
- blockProcCheck(block, player);
- }
- mat = Material.getMaterial(351);
- item = new ItemStack(mat, 1, (byte)0,(byte)0x4);
- loc.getWorld().dropItemNaturally(loc, item);
- loc.getWorld().dropItemNaturally(loc, item);
- loc.getWorld().dropItemNaturally(loc, item);
- loc.getWorld().dropItemNaturally(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- if(block.getData() != (byte) 5)
- PP.addXP(SkillType.MINING, xp);
- if(LoadProperties.spoutEnabled)
- SpoutStuff.playSoundForPlayer(SoundEffect.POP, player, block.getLocation());
-
- Skills.XpCheckSkill(SkillType.MINING, player);
- }
- }
|