mirror of
https://github.com/StarWishsama/Slimefun4.git
synced 2024-09-22 04:35:53 +00:00
206 lines
6.7 KiB
Java
206 lines
6.7 KiB
Java
|
package me.mrCookieSlime.Slimefun.Objects.SlimefunItem.machines;
|
|||
|
|
|||
|
import java.util.ArrayList;
|
|||
|
import java.util.Collections;
|
|||
|
import java.util.HashMap;
|
|||
|
import java.util.List;
|
|||
|
import java.util.Map;
|
|||
|
|
|||
|
import me.mrCookieSlime.CSCoreLibPlugin.CSCoreLib;
|
|||
|
import me.mrCookieSlime.CSCoreLibPlugin.Configuration.Config;
|
|||
|
import me.mrCookieSlime.CSCoreLibPlugin.general.Inventory.InvUtils;
|
|||
|
import me.mrCookieSlime.CSCoreLibPlugin.general.Inventory.Item.CustomItem;
|
|||
|
import me.mrCookieSlime.Slimefun.Lists.RecipeType;
|
|||
|
import me.mrCookieSlime.Slimefun.Lists.SlimefunItems;
|
|||
|
import me.mrCookieSlime.Slimefun.Objects.Category;
|
|||
|
import me.mrCookieSlime.Slimefun.Objects.SlimefunItem.SlimefunItem;
|
|||
|
import me.mrCookieSlime.Slimefun.Objects.SlimefunItem.abstractItems.AContainer;
|
|||
|
import me.mrCookieSlime.Slimefun.Objects.SlimefunItem.abstractItems.MachineHelper;
|
|||
|
import me.mrCookieSlime.Slimefun.Objects.SlimefunItem.abstractItems.MachineRecipe;
|
|||
|
import me.mrCookieSlime.Slimefun.Objects.SlimefunItem.handlers.BlockTicker;
|
|||
|
import me.mrCookieSlime.Slimefun.Setup.SlimefunManager;
|
|||
|
import me.mrCookieSlime.Slimefun.api.BlockStorage;
|
|||
|
import me.mrCookieSlime.Slimefun.api.energy.ChargableBlock;
|
|||
|
import me.mrCookieSlime.Slimefun.api.inventory.BlockMenu;
|
|||
|
import me.mrCookieSlime.Slimefun.api.inventory.BlockMenuPreset;
|
|||
|
import me.mrCookieSlime.Slimefun.api.item_transport.ItemTransportFlow;
|
|||
|
import me.mrCookieSlime.Slimefun.api.item_transport.RecipeSorter;
|
|||
|
|
|||
|
import org.apache.commons.lang.ArrayUtils;
|
|||
|
import org.bukkit.Material;
|
|||
|
import org.bukkit.block.Block;
|
|||
|
import org.bukkit.entity.Player;
|
|||
|
import org.bukkit.inventory.ItemStack;
|
|||
|
import org.bukkit.inventory.meta.ItemMeta;
|
|||
|
import org.bukkit.material.MaterialData;
|
|||
|
|
|||
|
public abstract class HeatedPressureChamber extends AContainer {
|
|||
|
|
|||
|
public HeatedPressureChamber(Category category, ItemStack item, String name, RecipeType recipeType, ItemStack[] recipe) {
|
|||
|
super(category, item, name, recipeType, recipe);
|
|||
|
|
|||
|
new BlockMenuPreset(name, getInventoryTitle()) {
|
|||
|
|
|||
|
@Override
|
|||
|
public void init() {
|
|||
|
constructMenu(this);
|
|||
|
}
|
|||
|
|
|||
|
@Override
|
|||
|
public void newInstance(BlockMenu menu, Block b) {
|
|||
|
}
|
|||
|
|
|||
|
@Override
|
|||
|
public boolean canOpen(Block b, Player p) {
|
|||
|
return p.hasPermission("slimefun.inventory.bypass") || CSCoreLib.getLib().getProtectionManager().canAccessChest(p.getUniqueId(), b, true);
|
|||
|
}
|
|||
|
|
|||
|
@Override
|
|||
|
public int[] getSlotsAccessedByItemTransport(ItemTransportFlow flow) {
|
|||
|
return new int[0];
|
|||
|
}
|
|||
|
|
|||
|
@Override
|
|||
|
public int[] getSlotsAccessedByItemTransport(BlockMenu menu, ItemTransportFlow flow, ItemStack item) {
|
|||
|
if (flow.equals(ItemTransportFlow.WITHDRAW)) return getOutputSlots();
|
|||
|
|
|||
|
List<Integer> slots = new ArrayList<Integer>();
|
|||
|
|
|||
|
for (int slot: getInputSlots()) {
|
|||
|
if (SlimefunManager.isItemSimiliar(menu.getItemInSlot(slot), item, true)) {
|
|||
|
slots.add(slot);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if (slots.isEmpty()) {
|
|||
|
return getInputSlots();
|
|||
|
}
|
|||
|
else {
|
|||
|
Collections.sort(slots, new RecipeSorter(menu));
|
|||
|
return ArrayUtils.toPrimitive(slots.toArray(new Integer[slots.size()]));
|
|||
|
}
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
this.registerDefaultRecipes();
|
|||
|
}
|
|||
|
|
|||
|
@Override
|
|||
|
public void registerDefaultRecipes() {
|
|||
|
registerRecipe(45, new ItemStack[] {SlimefunItems.BUCKET_OF_OIL}, new ItemStack[] {new CustomItem(SlimefunItems.PLASTIC_SHEET, 8)});
|
|||
|
registerRecipe(30, new ItemStack[] {SlimefunItems.GOLD_24K, SlimefunItems.URANIUM}, new ItemStack[] {SlimefunItems.BLISTERING_INGOT});
|
|||
|
registerRecipe(30, new ItemStack[] {SlimefunItems.BLISTERING_INGOT, SlimefunItems.CARBONADO}, new ItemStack[] {SlimefunItems.BLISTERING_INGOT_2});
|
|||
|
registerRecipe(60, new ItemStack[] {SlimefunItems.BLISTERING_INGOT_2, new ItemStack(Material.NETHER_STAR)}, new ItemStack[] {SlimefunItems.BLISTERING_INGOT_3});
|
|||
|
registerRecipe(90, new ItemStack[] {SlimefunItems.PLUTONIUM, SlimefunItems.URANIUM}, new ItemStack[] {SlimefunItems.BOOSTED_URANIUM});
|
|||
|
}
|
|||
|
|
|||
|
public String getInventoryTitle() {
|
|||
|
return "<EFBFBD>cHeated Pressure Chamber";
|
|||
|
}
|
|||
|
|
|||
|
public ItemStack getProgressBar() {
|
|||
|
return new ItemStack(Material.FLINT_AND_STEEL);
|
|||
|
}
|
|||
|
|
|||
|
public int[] getInputSlots() {
|
|||
|
return new int[] {10, 11, 19, 20, 28, 29};
|
|||
|
}
|
|||
|
|
|||
|
public int[] getOutputSlots() {
|
|||
|
return new int[] {24, 25};
|
|||
|
}
|
|||
|
|
|||
|
@Override
|
|||
|
public void register(boolean slimefun) {
|
|||
|
addItemHandler(new BlockTicker() {
|
|||
|
|
|||
|
@Override
|
|||
|
public void tick(Block b, SlimefunItem sf, Config data) {
|
|||
|
HeatedPressureChamber.this.tick(b);
|
|||
|
}
|
|||
|
|
|||
|
@Override
|
|||
|
public void uniqueTick() {
|
|||
|
}
|
|||
|
|
|||
|
@Override
|
|||
|
public boolean isSynchronized() {
|
|||
|
return false;
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
super.register(slimefun);
|
|||
|
}
|
|||
|
|
|||
|
@SuppressWarnings("deprecation")
|
|||
|
protected void tick(Block b) {
|
|||
|
if (isProcessing(b)) {
|
|||
|
int timeleft = progress.get(b);
|
|||
|
if (timeleft > 0) {
|
|||
|
ItemStack item = getProgressBar().clone();
|
|||
|
item.setDurability(MachineHelper.getDurability(item, timeleft, processing.get(b).getTicks()));
|
|||
|
ItemMeta im = item.getItemMeta();
|
|||
|
im.setDisplayName(" ");
|
|||
|
List<String> lore = new ArrayList<String>();
|
|||
|
lore.add(MachineHelper.getProgress(timeleft, processing.get(b).getTicks()));
|
|||
|
lore.add("");
|
|||
|
lore.add(MachineHelper.getTimeLeft(timeleft / 2));
|
|||
|
im.setLore(lore);
|
|||
|
item.setItemMeta(im);
|
|||
|
|
|||
|
BlockStorage.getInventory(b).replaceExistingItem(22, item);
|
|||
|
|
|||
|
if (ChargableBlock.isChargable(b)) {
|
|||
|
if (ChargableBlock.getCharge(b) < getEnergyConsumption()) return;
|
|||
|
ChargableBlock.addCharge(b, -getEnergyConsumption());
|
|||
|
progress.put(b, timeleft - 1);
|
|||
|
}
|
|||
|
else progress.put(b, timeleft - 1);
|
|||
|
}
|
|||
|
else {
|
|||
|
BlockStorage.getInventory(b).replaceExistingItem(22, new CustomItem(new MaterialData(Material.STAINED_GLASS_PANE, (byte) 15), " "));
|
|||
|
pushItems(b, processing.get(b).getOutput());
|
|||
|
|
|||
|
progress.remove(b);
|
|||
|
processing.remove(b);
|
|||
|
}
|
|||
|
}
|
|||
|
else {
|
|||
|
MachineRecipe r = null;
|
|||
|
Map<Integer, Integer> found = new HashMap<Integer, Integer>();
|
|||
|
outer:
|
|||
|
for (MachineRecipe recipe: recipes) {
|
|||
|
for (ItemStack input: recipe.getInput()) {
|
|||
|
slots:
|
|||
|
for (int slot: getInputSlots()) {
|
|||
|
if (SlimefunManager.isItemSimiliar(BlockStorage.getInventory(b).getItemInSlot(slot), input, true)) {
|
|||
|
found.put(slot, input.getAmount());
|
|||
|
break slots;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
if (found.size() == recipe.getInput().length) {
|
|||
|
r = recipe;
|
|||
|
break outer;
|
|||
|
}
|
|||
|
else found.clear();
|
|||
|
}
|
|||
|
|
|||
|
if (r != null) {
|
|||
|
if (!fits(b, r.getOutput())) return;
|
|||
|
for (Map.Entry<Integer, Integer> entry: found.entrySet()) {
|
|||
|
BlockStorage.getInventory(b).replaceExistingItem(entry.getKey(), InvUtils.decreaseItem(BlockStorage.getInventory(b).getItemInSlot(entry.getKey()), entry.getValue()));
|
|||
|
}
|
|||
|
processing.put(b, r);
|
|||
|
progress.put(b, r.getTicks());
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
@Override
|
|||
|
public String getMachineIdentifier() {
|
|||
|
return "HEATED_PRESSURE_CHAMBER";
|
|||
|
}
|
|||
|
|
|||
|
}
|