123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427 |
- /*
- This file is part of mcMMO.
- mcMMO is free software: you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation, either version 3 of the License, or
- (at your option) any later version.
- mcMMO is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
- You should have received a copy of the GNU General Public License
- along with mcMMO. If not, see <http://www.gnu.org/licenses/>.
- */
- package com.gmail.nossr50.skills;
- import net.minecraft.server.Enchantment;
- 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();
- int id = block.getTypeId();
- Material mat = Material.getMaterial(id);
- byte damage = 0;
- ItemStack item = new ItemStack(mat, 1, (byte)0, damage);
-
- if(id != 89 && id != 73 && id != 74 && id != 56 && id != 21 && id != 1 && id != 16) {
- m.mcDropItem(loc, item);
- return;
- }
-
- switch (id){
- //GLOWSTONE
- case 89:
- mat = Material.getMaterial(348);
- item = new ItemStack(mat, 1, (byte)0, damage);
- m.mcDropItem(loc, item);
- break;
- //REDSTONE
- case 73:
- mat = Material.getMaterial(331);
- item = new ItemStack(mat, 1, (byte)0, damage);
- m.mcDropItem(loc, item);
- m.mcDropItem(loc, item);
- m.mcDropItem(loc, item);
- m.mcDropItem(loc, item);
- if(Math.random() * 10 > 5)
- m.mcDropItem(loc, item);
- break;
- case 74:
- mat = Material.getMaterial(331);
- item = new ItemStack(mat, 1, (byte)0, damage);
- m.mcDropItem(loc, item);
- m.mcDropItem(loc, item);
- m.mcDropItem(loc, item);
- m.mcDropItem(loc, item);
- if(Math.random() * 10 > 5)
- m.mcDropItem(loc, item);
- break;
- //LAPIS
- case 21:
- mat = Material.getMaterial(351);
- item = new ItemStack(mat, 1, (byte)0,(byte)0x4);
- m.mcDropItem(loc, item);
- m.mcDropItem(loc, item);
- m.mcDropItem(loc, item);
- m.mcDropItem(loc, item);
- if(Math.random() * 10 > 5)
- m.mcDropItem(loc, item);
- if(Math.random() * 10 > 5)
- m.mcDropItem(loc, item);
- if(Math.random() * 10 > 5)
- m.mcDropItem(loc, item);
- if(Math.random() * 10 > 5)
- m.mcDropItem(loc, item);
- break;
- //DIAMOND
- case 56:
- mat = Material.getMaterial(264);
- item = new ItemStack(mat, 1, (byte)0, damage);
- m.mcDropItem(loc, item);
- break;
- //STONE
- case 1:
- mat = Material.getMaterial(4);
- item = new ItemStack(mat, 1, (byte)0, damage);
- m.mcDropItem(loc, item);
- break;
- //COAL
- case 16:
- mat = Material.getMaterial(263);
- item = new ItemStack(mat, 1, (byte)0, damage);
- m.mcDropItem(loc, item);
- break;
- }
- }
- 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(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;
- int id = block.getTypeId();
-
- switch (id) {
- //STONE
- case 1:
- xp += LoadProperties.mstone;
- break;
- //SANDSTONE
- case 24:
- xp += LoadProperties.msandstone;
- break;
- //OBSIDIAN
- case 49:
- xp += LoadProperties.mobsidian;
- break;
- //NETHERRACK
- case 87:
- xp += LoadProperties.mnetherrack;
- break;
- //GLOWSTONE
- case 89:
- xp += LoadProperties.mglowstone;
- break;
- //COAL
- case 16:
- xp += LoadProperties.mcoal;
- break;
- //GOLD
- case 14:
- xp += LoadProperties.mgold;
- break;
- //DIAMOND
- case 56:
- xp += LoadProperties.mdiamond;
- break;
- //IRON
- case 15:
- xp += LoadProperties.miron;
- break;
- //REDSTONE
- case 73:
- xp += LoadProperties.mredstone;
- break;
- case 74:
- xp += LoadProperties.mredstone;
- break;
- //LAPIS
- case 21:
- xp += LoadProperties.mlapis;
- break;
- }
-
- blockProcCheck(block, player);
- PP.addXP(SkillType.MINING, xp, player);
- Skills.XpCheckSkill(SkillType.MINING, player);
- }
-
- /*
- * Handling SuperBreaker stuff
- */
- public static Boolean canBeSuperBroken(Block block)
- {
- int id = block.getTypeId();
- return id == 1 || id == 14 || id == 15 || id == 16 || id == 21 || id == 24 || id == 49 || id == 56 || id == 73 || id == 74 || id == 87 || id == 89;
- }
-
- public static void SuperBreakerBlockCheck(Player player, Block block, mcMMO plugin)
- {
- PlayerProfile PP = Users.getProfile(player);
- if(LoadProperties.toolsLoseDurabilityFromAbilities)
- {
- if(!player.getItemInHand().getEnchantments().containsKey(Enchantment.DURABILITY))
- m.damageTool(player, (short) LoadProperties.abilityDurabilityLoss);
- }
-
- //Pre-processing
- Location loc = block.getLocation();
- int id = block.getTypeId();
- Material mat = Material.getMaterial(id);
- int xp = 0;
- byte damage = 0;
- ItemStack item = new ItemStack(mat, 1, (byte)0, damage);
-
- //STONE
- if(id == 1)
- {
- if(!plugin.misc.blockWatchList.contains(block) && block.getData() != (byte) 5)
- {
- xp += LoadProperties.mstone;
- blockProcCheck(block, player);
- blockProcCheck(block, player);
- }
- mat = Material.getMaterial(4);
- item = new ItemStack(mat, 1, (byte)0, damage);
- m.mcDropItem(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //SANDSTONE
- else if(id == 24)
- {
- if(!plugin.misc.blockWatchList.contains(block) && block.getData() != (byte) 5)
- {
- xp += LoadProperties.msandstone;
- blockProcCheck(block, player);
- blockProcCheck(block, player);
- }
- m.mcDropItem(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //NETHERRACK
- else if(id == 87)
- {
- if(!plugin.misc.blockWatchList.contains(block)&& block.getData() != (byte) 5){
- xp += LoadProperties.mnetherrack;
- blockProcCheck(block, player);
- blockProcCheck(block, player);
- }
- m.mcDropItem(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //GLOWSTONE
- else if(id == 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);
- m.mcDropItem(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //COAL
- else if(id == 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);
- m.mcDropItem(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //GOLD
- else if(id == 14 && m.getTier(player) >= 3)
- {
- if(!plugin.misc.blockWatchList.contains(block)&& block.getData() != (byte) 5){
- xp += LoadProperties.mgold;
- blockProcCheck(block, player);
- blockProcCheck(block, player);
- }
- m.mcDropItem(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //OBSIDIAN
- else if(id == 49 && m.getTier(player) >= 4)
- {
- if(!plugin.misc.blockWatchList.contains(block)&& block.getData() != (byte) 5){
- xp += LoadProperties.mobsidian;
- blockProcCheck(block, player);
- blockProcCheck(block, player);
- }
- m.mcDropItem(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //DIAMOND
- else if(id == 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);
- m.mcDropItem(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //IRON
- else if(id == 15 && m.getTier(player) >= 2)
- {
- if(!plugin.misc.blockWatchList.contains(block)&& block.getData() != (byte) 5){
- xp += LoadProperties.miron;
- blockProcCheck(block, player);
- blockProcCheck(block, player);
- }
- m.mcDropItem(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //REDSTONE
- else if((id == 73 || id == 74) && m.getTier(player) >= 3)
- {
- 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);
- m.mcDropItem(loc, item);
- m.mcDropItem(loc, item);
- m.mcDropItem(loc, item);
- m.mcDropItem(loc, item);
- if(Math.random() * 10 > 5)
- m.mcDropItem(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
- //LAPIS
- else if(id == 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);
- m.mcDropItem(loc, item);
- m.mcDropItem(loc, item);
- m.mcDropItem(loc, item);
- m.mcDropItem(loc, item);
- if(Math.random() * 10 > 5)
- m.mcDropItem(loc, item);
- if(Math.random() * 10 > 5)
- m.mcDropItem(loc, item);
- if(Math.random() * 10 > 5)
- m.mcDropItem(loc, item);
- if(Math.random() * 10 > 5)
- m.mcDropItem(loc, item);
- player.incrementStatistic(Statistic.MINE_BLOCK, block.getType());
- block.setType(Material.AIR);
- }
-
- if(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);
- }
- }
|