mirror of
https://github.com/mcMMO-Dev/mcMMO.git
synced 2025-04-04 02:36:23 +02:00
144 lines
5.0 KiB
Java
144 lines
5.0 KiB
Java
package com.gmail.nossr50;
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import org.bukkit.ChatColor;
|
|
import org.bukkit.Location;
|
|
import org.bukkit.Material;
|
|
import org.bukkit.block.Block;
|
|
import org.bukkit.entity.Player;
|
|
import org.bukkit.inventory.ItemStack;
|
|
|
|
public class mcWoodCutting {
|
|
int w = 0;
|
|
private boolean isdone = false;
|
|
private static mcMMO plugin;
|
|
public mcWoodCutting(mcMMO instance) {
|
|
plugin = instance;
|
|
}
|
|
private static volatile mcWoodCutting instance;
|
|
public static mcWoodCutting getInstance() {
|
|
if (instance == null) {
|
|
instance = new mcWoodCutting(plugin);
|
|
}
|
|
return instance;
|
|
}
|
|
public void woodCuttingProcCheck(Player player, Block block, Location loc){
|
|
byte type = block.getData();
|
|
Material mat = Material.getMaterial(block.getTypeId());
|
|
if(player != null){
|
|
if(Math.random() * 1000 <= mcUsers.getProfile(player).getWoodCuttingInt()){
|
|
ItemStack item = new ItemStack(mat, 1, (short) 0, type);
|
|
loc.getWorld().dropItemNaturally(loc, item);
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
public void treeFellerCheck(Player player, Block block){
|
|
if(mcm.getInstance().isAxes(player.getItemInHand())){
|
|
if(block != null){
|
|
if(!mcm.getInstance().abilityBlockCheck(block))
|
|
return;
|
|
}
|
|
/*
|
|
* CHECK FOR AXE PREP MODE
|
|
*/
|
|
if(mcUsers.getProfile(player).getAxePreparationMode()){
|
|
mcUsers.getProfile(player).setAxePreparationMode(false);
|
|
mcUsers.getProfile(player).setAxePreparationTicks(0);
|
|
}
|
|
int treefellticks = 2;
|
|
if(mcUsers.getProfile(player).getWoodCuttingInt() >= 50)
|
|
treefellticks++;
|
|
if(mcUsers.getProfile(player).getWoodCuttingInt() >= 150)
|
|
treefellticks++;
|
|
if(mcUsers.getProfile(player).getWoodCuttingInt() >= 250)
|
|
treefellticks++;
|
|
if(mcUsers.getProfile(player).getWoodCuttingInt() >= 350)
|
|
treefellticks++;
|
|
if(mcUsers.getProfile(player).getWoodCuttingInt() >= 450)
|
|
treefellticks++;
|
|
if(mcUsers.getProfile(player).getWoodCuttingInt() >= 550)
|
|
treefellticks++;
|
|
if(mcUsers.getProfile(player).getWoodCuttingInt() >= 650)
|
|
treefellticks++;
|
|
if(mcUsers.getProfile(player).getWoodCuttingInt() >= 750)
|
|
treefellticks++;
|
|
|
|
if(!mcUsers.getProfile(player).getTreeFellerMode() && mcUsers.getProfile(player).getTreeFellerCooldown() == 0){
|
|
player.sendMessage(ChatColor.GREEN+"**TREE FELLING ACTIVATED**");
|
|
mcUsers.getProfile(player).setTreeFellerTicks(treefellticks);
|
|
mcUsers.getProfile(player).setTreeFellerMode(true);
|
|
}
|
|
if(!mcUsers.getProfile(player).getTreeFellerMode() && mcUsers.getProfile(player).getTreeFellerCooldown() >= 1){
|
|
player.sendMessage(ChatColor.RED+"You are too tired to use that ability again.");
|
|
}
|
|
}
|
|
}
|
|
public void treeFeller(Block block, Player player){
|
|
int radius = 1;
|
|
if(mcUsers.getProfile(player).getWoodCuttingGatherInt() >= 500)
|
|
radius++;
|
|
if(mcUsers.getProfile(player).getWoodCuttingGatherInt() >= 950)
|
|
radius++;
|
|
ArrayList<Block> blocklist = new ArrayList<Block>();
|
|
ArrayList<Block> toAdd = new ArrayList<Block>();
|
|
if(block != null)
|
|
blocklist.add(block);
|
|
while(isdone == false){
|
|
addBlocksToTreeFelling(blocklist, toAdd, radius);
|
|
}
|
|
//This needs to be a hashmap too!
|
|
isdone = false;
|
|
/*
|
|
* Add blocks from the temporary 'toAdd' array list into the 'treeFeller' array list
|
|
* We use this temporary list to prevent concurrent modification exceptions
|
|
*/
|
|
for(Block x : toAdd){
|
|
if(!mcConfig.getInstance().isTreeFellerWatched(x))
|
|
mcConfig.getInstance().addTreeFeller(x);
|
|
}
|
|
toAdd.clear();
|
|
}
|
|
public void addBlocksToTreeFelling(ArrayList<Block> blocklist, ArrayList<Block> toAdd, Integer radius){
|
|
int u = 0;
|
|
for (Block x : blocklist){
|
|
u++;
|
|
if(toAdd.contains(x))
|
|
continue;
|
|
w = 0;
|
|
Location loc = x.getLocation();
|
|
int vx = x.getX();
|
|
int vy = x.getY();
|
|
int vz = x.getZ();
|
|
|
|
/*
|
|
* Run through the blocks around the broken block to see if they qualify to be 'felled'
|
|
*/
|
|
for (int cx = -radius; cx <= radius; cx++) {
|
|
for (int cy = -radius; cy <= radius; cy++) {
|
|
for (int cz = -radius; cz <= radius; cz++) {
|
|
Block blocktarget = loc.getWorld().getBlockAt(vx + cx, vy + cy, vz + cz);
|
|
if (!blocklist.contains(blocktarget) && !toAdd.contains(blocktarget) && (blocktarget.getTypeId() == 17 || blocktarget.getTypeId() == 18)) {
|
|
toAdd.add(blocktarget);
|
|
w++;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
/*
|
|
* Add more blocks to blocklist so they can be 'felled'
|
|
*/
|
|
for(Block xx : toAdd){
|
|
if(!blocklist.contains(xx))
|
|
blocklist.add(xx);
|
|
}
|
|
if(u >= blocklist.size()){
|
|
isdone = true;
|
|
} else {
|
|
isdone = false;
|
|
}
|
|
}
|
|
}
|