mirror of
https://github.com/HbmMods/Hbm-s-Nuclear-Tech-GIT.git
synced 2026-01-25 10:32:49 +00:00
recipe crap
This commit is contained in:
parent
446f2f8c93
commit
e64a21ffd3
@ -279,6 +279,10 @@ public class RecipesCommon {
|
|||||||
return new ComparableStack(item, stacksize, meta);
|
return new ComparableStack(item, stacksize, meta);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ComparableStack copy(int stacksize) {
|
||||||
|
return new ComparableStack(item, stacksize, meta);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean matchesRecipe(ItemStack stack, boolean ignoreSize) {
|
public boolean matchesRecipe(ItemStack stack, boolean ignoreSize) {
|
||||||
|
|
||||||
@ -391,6 +395,10 @@ public class RecipesCommon {
|
|||||||
return new OreDictStack(name, stacksize);
|
return new OreDictStack(name, stacksize);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public OreDictStack copy(int stacksize) {
|
||||||
|
return new OreDictStack(name, stacksize);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean matchesRecipe(ItemStack stack, boolean ignoreSize) {
|
public boolean matchesRecipe(ItemStack stack, boolean ignoreSize) {
|
||||||
|
|
||||||
|
|||||||
@ -119,24 +119,6 @@ public class GUIAnvil extends GuiContainer {
|
|||||||
this.size = Math.max(0, (int)Math.ceil((this.recipes.size() - 10) / 2D));
|
this.size = Math.max(0, (int)Math.ceil((this.recipes.size() - 10) / 2D));
|
||||||
}
|
}
|
||||||
|
|
||||||
/*@Override
|
|
||||||
protected void mouseMovedOrUp(int x, int y, int mode) {
|
|
||||||
super.mouseMovedOrUp(x, y, mode);
|
|
||||||
|
|
||||||
if(mode == -1) return; // we don't care about mouseMove
|
|
||||||
for(Object obj : this.inventorySlots.inventorySlots) {
|
|
||||||
Slot slot = (Slot) obj;
|
|
||||||
|
|
||||||
// if the mouse is over a slot, cancel
|
|
||||||
if(this.func_146978_c(slot.xDisplayPosition, slot.yDisplayPosition, 16, 16, x, y)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(mode == 0 && this.index > 0) this.index--;
|
|
||||||
if(mode == 1 && this.index < this.size) this.index++;
|
|
||||||
}*/
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void drawScreen(int x, int y, float interp) {
|
public void drawScreen(int x, int y, float interp) {
|
||||||
super.drawScreen(x, y, interp);
|
super.drawScreen(x, y, interp);
|
||||||
|
|||||||
@ -1,14 +1,28 @@
|
|||||||
package com.hbm.inventory.gui;
|
package com.hbm.inventory.gui;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
|
import org.lwjgl.input.Keyboard;
|
||||||
|
import org.lwjgl.input.Mouse;
|
||||||
import org.lwjgl.opengl.GL11;
|
import org.lwjgl.opengl.GL11;
|
||||||
|
import org.lwjgl.opengl.GL12;
|
||||||
|
|
||||||
import com.hbm.inventory.container.ContainerMachineAmmoPress;
|
import com.hbm.inventory.container.ContainerMachineAmmoPress;
|
||||||
|
import com.hbm.inventory.recipes.AmmoPressRecipes;
|
||||||
|
import com.hbm.inventory.recipes.AmmoPressRecipes.AmmoPressRecipe;
|
||||||
import com.hbm.lib.RefStrings;
|
import com.hbm.lib.RefStrings;
|
||||||
import com.hbm.tileentity.machine.TileEntityMachineAmmoPress;
|
import com.hbm.tileentity.machine.TileEntityMachineAmmoPress;
|
||||||
|
|
||||||
import net.minecraft.client.Minecraft;
|
import net.minecraft.client.Minecraft;
|
||||||
|
import net.minecraft.client.audio.PositionedSoundRecord;
|
||||||
|
import net.minecraft.client.gui.FontRenderer;
|
||||||
|
import net.minecraft.client.gui.GuiTextField;
|
||||||
|
import net.minecraft.client.renderer.RenderHelper;
|
||||||
import net.minecraft.client.resources.I18n;
|
import net.minecraft.client.resources.I18n;
|
||||||
import net.minecraft.entity.player.InventoryPlayer;
|
import net.minecraft.entity.player.InventoryPlayer;
|
||||||
|
import net.minecraft.inventory.Slot;
|
||||||
import net.minecraft.util.ResourceLocation;
|
import net.minecraft.util.ResourceLocation;
|
||||||
|
|
||||||
public class GUIMachineAmmoPress extends GuiInfoContainer {
|
public class GUIMachineAmmoPress extends GuiInfoContainer {
|
||||||
@ -16,24 +30,113 @@ public class GUIMachineAmmoPress extends GuiInfoContainer {
|
|||||||
private static ResourceLocation texture = new ResourceLocation(RefStrings.MODID + ":textures/gui/processing/gui_ammo_press.png");
|
private static ResourceLocation texture = new ResourceLocation(RefStrings.MODID + ":textures/gui/processing/gui_ammo_press.png");
|
||||||
private TileEntityMachineAmmoPress press;
|
private TileEntityMachineAmmoPress press;
|
||||||
|
|
||||||
|
private List<AmmoPressRecipe> recipes = new ArrayList();
|
||||||
|
int index;
|
||||||
|
int size;
|
||||||
|
int selection;
|
||||||
|
private GuiTextField search;
|
||||||
|
|
||||||
public GUIMachineAmmoPress(InventoryPlayer invPlayer, TileEntityMachineAmmoPress press) {
|
public GUIMachineAmmoPress(InventoryPlayer invPlayer, TileEntityMachineAmmoPress press) {
|
||||||
super(new ContainerMachineAmmoPress(invPlayer, press));
|
super(new ContainerMachineAmmoPress(invPlayer, press));
|
||||||
this.press = press;
|
this.press = press;
|
||||||
|
|
||||||
this.xSize = 176;
|
this.xSize = 176;
|
||||||
this.ySize = 200;
|
this.ySize = 200;
|
||||||
|
|
||||||
|
regenerateRecipes();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void initGui() {
|
||||||
|
|
||||||
|
super.initGui();
|
||||||
|
|
||||||
|
Keyboard.enableRepeatEvents(true);
|
||||||
|
this.search = new GuiTextField(this.fontRendererObj, guiLeft + 10, guiTop + 75, 66, 12);
|
||||||
|
this.search.setTextColor(-1);
|
||||||
|
this.search.setDisabledTextColour(-1);
|
||||||
|
this.search.setEnableBackgroundDrawing(false);
|
||||||
|
this.search.setMaxStringLength(25);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void regenerateRecipes() {
|
||||||
|
|
||||||
|
this.recipes.clear();
|
||||||
|
this.recipes.addAll(AmmoPressRecipes.recipes);
|
||||||
|
|
||||||
|
resetPaging();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void search(String search) {
|
||||||
|
|
||||||
|
search = search.toLowerCase(Locale.US);
|
||||||
|
|
||||||
|
this.recipes.clear();
|
||||||
|
|
||||||
|
if(search.isEmpty()) {
|
||||||
|
this.recipes.addAll(AmmoPressRecipes.recipes);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
for(AmmoPressRecipe recipe : AmmoPressRecipes.recipes) {
|
||||||
|
if(recipe.output.getDisplayName().toLowerCase(Locale.US).contains(search)) {
|
||||||
|
this.recipes.add(recipe);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
resetPaging();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void resetPaging() {
|
||||||
|
|
||||||
|
this.index = 0;
|
||||||
|
this.selection = -1;
|
||||||
|
this.size = Math.max(0, (int)Math.ceil((this.recipes.size() - 12) / 2D));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void drawScreen(int x, int y, float interp) {
|
public void drawScreen(int x, int y, float interp) {
|
||||||
super.drawScreen(x, y, interp);
|
super.drawScreen(x, y, interp);
|
||||||
|
|
||||||
|
for(Object obj : this.inventorySlots.inventorySlots) {
|
||||||
|
Slot slot = (Slot) obj;
|
||||||
|
|
||||||
|
// if the mouse is over a slot, cancel
|
||||||
|
if(this.func_146978_c(slot.xDisplayPosition, slot.yDisplayPosition, 16, 16, x, y) && slot.getHasStack()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(guiLeft <= x && guiLeft + xSize > x && guiTop < y && guiTop + ySize >= y && getSlotAtPosition(x, y) == null) {
|
||||||
|
if(!Mouse.isButtonDown(0) && !Mouse.isButtonDown(1) && Mouse.next()) {
|
||||||
|
int scroll = Mouse.getEventDWheel();
|
||||||
|
|
||||||
|
if(scroll > 0 && this.index > 0) this.index--;
|
||||||
|
if(scroll < 0 && this.index < this.size) this.index++;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void mouseClicked(int x, int y, int k) {
|
protected void mouseClicked(int x, int y, int k) {
|
||||||
super.mouseClicked(x, y, k);
|
super.mouseClicked(x, y, k);
|
||||||
|
|
||||||
if(this.checkClick(x, y, 151, 17, 18, 18)) {
|
this.search.mouseClicked(x, y, k);
|
||||||
|
|
||||||
|
if(guiLeft + 7 <= x && guiLeft + 7 + 9 > x && guiTop + 17 < y && guiTop + 17 + 54 >= y) {
|
||||||
|
mc.getSoundHandler().playSound(PositionedSoundRecord.func_147674_a(new ResourceLocation("gui.button.press"), 1.0F));
|
||||||
|
if(this.index > 0)
|
||||||
|
this.index--;
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(guiLeft + 88 <= x && guiLeft + 88 + 9 > x && guiTop + 17 < y && guiTop + 17 + 54 >= y) {
|
||||||
|
mc.getSoundHandler().playSound(PositionedSoundRecord.func_147674_a(new ResourceLocation("gui.button.press"), 1.0F));
|
||||||
|
if(this.index < this.size)
|
||||||
|
this.index++;
|
||||||
|
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -49,5 +152,65 @@ public class GUIMachineAmmoPress extends GuiInfoContainer {
|
|||||||
GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
|
GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
|
||||||
Minecraft.getMinecraft().getTextureManager().bindTexture(texture);
|
Minecraft.getMinecraft().getTextureManager().bindTexture(texture);
|
||||||
drawTexturedModalRect(guiLeft, guiTop, 0, 0, xSize, ySize);
|
drawTexturedModalRect(guiLeft, guiTop, 0, 0, xSize, ySize);
|
||||||
|
|
||||||
|
if(guiLeft + 7 <= x && guiLeft + 7 + 9 > x && guiTop + 17 < y && guiTop + 17 + 54 >= y) {
|
||||||
|
drawTexturedModalRect(guiLeft + 7, guiTop + 17, 176, 0, 9, 54);
|
||||||
|
}
|
||||||
|
if(guiLeft + 88 <= x && guiLeft + 88 + 9 > x && guiTop + 17 < y && guiTop + 17 + 54 >= y) {
|
||||||
|
drawTexturedModalRect(guiLeft + 88, guiTop + 17, 185, 0, 9, 54);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(this.search.isFocused()) {
|
||||||
|
drawTexturedModalRect(guiLeft + 8, guiTop + 72, 176, 54, 70, 16);
|
||||||
|
}
|
||||||
|
|
||||||
|
for(int i = index * 3; i < index * 3 + 12; i++) {
|
||||||
|
if(i >= recipes.size())
|
||||||
|
break;
|
||||||
|
|
||||||
|
int ind = i - index * 3;
|
||||||
|
|
||||||
|
GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
|
||||||
|
RenderHelper.enableGUIStandardItemLighting();
|
||||||
|
GL11.glDisable(GL11.GL_LIGHTING);
|
||||||
|
GL11.glEnable(GL12.GL_RESCALE_NORMAL);
|
||||||
|
|
||||||
|
AmmoPressRecipe recipe = recipes.get(i);
|
||||||
|
|
||||||
|
FontRenderer font = null;
|
||||||
|
if (recipe.output != null) font = recipe.output.getItem().getFontRenderer(recipe.output);
|
||||||
|
if (font == null) font = fontRendererObj;
|
||||||
|
|
||||||
|
itemRender.zLevel = 100.0F;
|
||||||
|
itemRender.renderItemAndEffectIntoGUI(font, this.mc.getTextureManager(), recipe.output, guiLeft + 17 + 18 * (ind / 3), guiTop + 18 + 18 * (ind % 3));
|
||||||
|
itemRender.zLevel = 0.0F;
|
||||||
|
|
||||||
|
GL11.glEnable(GL11.GL_ALPHA_TEST);
|
||||||
|
GL11.glDisable(GL11.GL_LIGHTING);
|
||||||
|
this.mc.getTextureManager().bindTexture(texture);
|
||||||
|
this.zLevel = 300.0F;
|
||||||
|
|
||||||
|
if(selection == i)
|
||||||
|
this.drawTexturedModalRect(guiLeft + 16 + 18 * (ind / 3), guiTop + 17 + 18 * (ind % 3), 194, 0, 18, 18);
|
||||||
|
else
|
||||||
|
this.drawTexturedModalRect(guiLeft + 16 + 18 * (ind / 3), guiTop + 17 + 18 * (ind % 3), 212, 0, 18, 18);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.search.drawTextBox();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void keyTyped(char c, int key) {
|
||||||
|
|
||||||
|
if(this.search.textboxKeyTyped(c, key)) {
|
||||||
|
search(this.search.getText());
|
||||||
|
} else {
|
||||||
|
super.keyTyped(c, key);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onGuiClosed() {
|
||||||
|
Keyboard.enableRepeatEvents(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -4,20 +4,110 @@ import java.io.IOException;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import static com.hbm.inventory.OreDictManager.*;
|
||||||
|
|
||||||
|
import com.google.gson.JsonArray;
|
||||||
import com.google.gson.JsonElement;
|
import com.google.gson.JsonElement;
|
||||||
|
import com.google.gson.JsonObject;
|
||||||
import com.google.gson.stream.JsonWriter;
|
import com.google.gson.stream.JsonWriter;
|
||||||
|
import com.hbm.inventory.OreDictManager.DictFrame;
|
||||||
import com.hbm.inventory.RecipesCommon.AStack;
|
import com.hbm.inventory.RecipesCommon.AStack;
|
||||||
|
import com.hbm.inventory.RecipesCommon.ComparableStack;
|
||||||
|
import com.hbm.inventory.RecipesCommon.OreDictStack;
|
||||||
import com.hbm.inventory.recipes.loader.SerializableRecipe;
|
import com.hbm.inventory.recipes.loader.SerializableRecipe;
|
||||||
|
import com.hbm.items.ItemEnums.EnumCasingType;
|
||||||
|
import com.hbm.items.ModItems;
|
||||||
|
import com.hbm.items.weapon.sedna.factory.GunFactory.EnumAmmo;
|
||||||
|
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
|
|
||||||
public class AmmoPressRecipes extends SerializableRecipe {
|
public class AmmoPressRecipes extends SerializableRecipe {
|
||||||
|
|
||||||
public List<AmmoPressRecipe> recipes = new ArrayList();
|
public static List<AmmoPressRecipe> recipes = new ArrayList();
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void registerDefaults() {
|
public void registerDefaults() {
|
||||||
|
|
||||||
|
OreDictStack lead = new OreDictStack(PB.ingot());
|
||||||
|
OreDictStack steel = new OreDictStack(STEEL.ingot());
|
||||||
|
OreDictStack copper = new OreDictStack(CU.ingot());
|
||||||
|
OreDictStack plastic = new OreDictStack(ANY_PLASTIC.ingot());
|
||||||
|
OreDictStack smokeless = new OreDictStack(ANY_SMOKELESS.dust());
|
||||||
|
ComparableStack cSmall = new ComparableStack(ModItems.casing, 1, EnumCasingType.SMALL);
|
||||||
|
ComparableStack cBig = new ComparableStack(ModItems.casing, 1, EnumCasingType.LARGE);
|
||||||
|
ComparableStack sSmall = new ComparableStack(ModItems.casing, 1, EnumCasingType.SMALL_STEEL);
|
||||||
|
ComparableStack sBig = new ComparableStack(ModItems.casing, 1, EnumCasingType.LARGE_STEEL);
|
||||||
|
ComparableStack bpShell = new ComparableStack(ModItems.casing, 1, EnumCasingType.SHOTSHELL);
|
||||||
|
ComparableStack pShell = new ComparableStack(ModItems.casing, 1, EnumCasingType.BUCKSHOT);
|
||||||
|
ComparableStack sShell = new ComparableStack(ModItems.casing, 1, EnumCasingType.BUCKSHOT_ADVANCED);
|
||||||
|
|
||||||
|
recipes.add(new AmmoPressRecipe(DictFrame.fromOne(ModItems.ammo_standard, EnumAmmo.P9_SP, 8),
|
||||||
|
null, lead, null,
|
||||||
|
null, smokeless, null,
|
||||||
|
null, cSmall, null));
|
||||||
|
recipes.add(new AmmoPressRecipe(DictFrame.fromOne(ModItems.ammo_standard, EnumAmmo.P9_FMJ, 8),
|
||||||
|
null, steel, null,
|
||||||
|
null, smokeless, null,
|
||||||
|
null, cSmall, null));
|
||||||
|
recipes.add(new AmmoPressRecipe(DictFrame.fromOne(ModItems.ammo_standard, EnumAmmo.P9_JHP, 8),
|
||||||
|
plastic, copper, null,
|
||||||
|
null, smokeless, null,
|
||||||
|
null, cSmall, null));
|
||||||
|
recipes.add(new AmmoPressRecipe(DictFrame.fromOne(ModItems.ammo_standard, EnumAmmo.P9_JHP, 8),
|
||||||
|
plastic, copper, null,
|
||||||
|
null, smokeless, null,
|
||||||
|
null, cSmall, null));
|
||||||
|
|
||||||
|
recipes.add(new AmmoPressRecipe(DictFrame.fromOne(ModItems.ammo_standard, EnumAmmo.P9_SP, 8),
|
||||||
|
null, lead, null,
|
||||||
|
null, smokeless, null,
|
||||||
|
null, cSmall, null));
|
||||||
|
recipes.add(new AmmoPressRecipe(DictFrame.fromOne(ModItems.ammo_standard, EnumAmmo.P9_FMJ, 8),
|
||||||
|
null, steel, null,
|
||||||
|
null, smokeless, null,
|
||||||
|
null, cSmall, null));
|
||||||
|
recipes.add(new AmmoPressRecipe(DictFrame.fromOne(ModItems.ammo_standard, EnumAmmo.P9_JHP, 8),
|
||||||
|
plastic, copper, null,
|
||||||
|
null, smokeless, null,
|
||||||
|
null, cSmall, null));
|
||||||
|
recipes.add(new AmmoPressRecipe(DictFrame.fromOne(ModItems.ammo_standard, EnumAmmo.P9_JHP, 8),
|
||||||
|
plastic, copper, null,
|
||||||
|
null, smokeless, null,
|
||||||
|
null, cSmall, null));
|
||||||
|
|
||||||
|
recipes.add(new AmmoPressRecipe(DictFrame.fromOne(ModItems.ammo_standard, EnumAmmo.P9_SP, 8),
|
||||||
|
null, lead, null,
|
||||||
|
null, smokeless, null,
|
||||||
|
null, cSmall, null));
|
||||||
|
recipes.add(new AmmoPressRecipe(DictFrame.fromOne(ModItems.ammo_standard, EnumAmmo.P9_FMJ, 8),
|
||||||
|
null, steel, null,
|
||||||
|
null, smokeless, null,
|
||||||
|
null, cSmall, null));
|
||||||
|
recipes.add(new AmmoPressRecipe(DictFrame.fromOne(ModItems.ammo_standard, EnumAmmo.P9_JHP, 8),
|
||||||
|
plastic, copper, null,
|
||||||
|
null, smokeless, null,
|
||||||
|
null, cSmall, null));
|
||||||
|
recipes.add(new AmmoPressRecipe(DictFrame.fromOne(ModItems.ammo_standard, EnumAmmo.P9_JHP, 8),
|
||||||
|
plastic, copper, null,
|
||||||
|
null, smokeless, null,
|
||||||
|
null, cSmall, null));
|
||||||
|
|
||||||
|
recipes.add(new AmmoPressRecipe(DictFrame.fromOne(ModItems.ammo_standard, EnumAmmo.P9_SP, 8),
|
||||||
|
null, lead, null,
|
||||||
|
null, smokeless, null,
|
||||||
|
null, cSmall, null));
|
||||||
|
recipes.add(new AmmoPressRecipe(DictFrame.fromOne(ModItems.ammo_standard, EnumAmmo.P9_FMJ, 8),
|
||||||
|
null, steel, null,
|
||||||
|
null, smokeless, null,
|
||||||
|
null, cSmall, null));
|
||||||
|
recipes.add(new AmmoPressRecipe(DictFrame.fromOne(ModItems.ammo_standard, EnumAmmo.P9_JHP, 8),
|
||||||
|
plastic, copper, null,
|
||||||
|
null, smokeless, null,
|
||||||
|
null, cSmall, null));
|
||||||
|
recipes.add(new AmmoPressRecipe(DictFrame.fromOne(ModItems.ammo_standard, EnumAmmo.P9_JHP, 8),
|
||||||
|
plastic, copper, null,
|
||||||
|
null, smokeless, null,
|
||||||
|
null, cSmall, null));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -25,6 +115,11 @@ public class AmmoPressRecipes extends SerializableRecipe {
|
|||||||
return "hbmAmmoPress.json";
|
return "hbmAmmoPress.json";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getComment() {
|
||||||
|
return "Input array describes slots from left to right, top to bottom. Make sure the input array is exactly 9 elements long, empty slots are represented by null.";
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object getRecipeObject() {
|
public Object getRecipeObject() {
|
||||||
return recipes;
|
return recipes;
|
||||||
@ -37,12 +132,40 @@ public class AmmoPressRecipes extends SerializableRecipe {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void readRecipe(JsonElement recipe) {
|
public void readRecipe(JsonElement recipe) {
|
||||||
|
JsonObject obj = (JsonObject) recipe;
|
||||||
|
|
||||||
|
ItemStack output = this.readItemStack(obj.get("output").getAsJsonArray());
|
||||||
|
JsonArray inputArray = obj.get("input").getAsJsonArray();
|
||||||
|
AStack[] input = new AStack[9];
|
||||||
|
|
||||||
|
for(int i = 0; i < 9; i++) {
|
||||||
|
JsonElement element = inputArray.get(i);
|
||||||
|
if(element.isJsonNull()) {
|
||||||
|
input[i] = null;
|
||||||
|
} else {
|
||||||
|
input[i] = this.readAStack(element.getAsJsonArray());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
this.recipes.add(new AmmoPressRecipe(output, input));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void writeRecipe(Object recipe, JsonWriter writer) throws IOException {
|
public void writeRecipe(Object recipe, JsonWriter writer) throws IOException {
|
||||||
|
AmmoPressRecipe rec = (AmmoPressRecipe) recipe;
|
||||||
|
|
||||||
|
writer.name("output");
|
||||||
|
this.writeItemStack(rec.output, writer);
|
||||||
|
|
||||||
|
writer.name("input").beginArray();
|
||||||
|
for(int i = 0; i < rec.input.length; i++) {
|
||||||
|
if(rec.input[i] == null) {
|
||||||
|
writer.nullValue();
|
||||||
|
} else {
|
||||||
|
this.writeAStack(rec.input[i], writer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
writer.endArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class AmmoPressRecipe {
|
public static class AmmoPressRecipe {
|
||||||
|
|||||||
@ -73,6 +73,7 @@ public abstract class SerializableRecipe {
|
|||||||
recipeHandlers.add(new ArcWelderRecipes());
|
recipeHandlers.add(new ArcWelderRecipes());
|
||||||
recipeHandlers.add(new RotaryFurnaceRecipes());
|
recipeHandlers.add(new RotaryFurnaceRecipes());
|
||||||
recipeHandlers.add(new ExposureChamberRecipes());
|
recipeHandlers.add(new ExposureChamberRecipes());
|
||||||
|
recipeHandlers.add(new AmmoPressRecipes());
|
||||||
recipeHandlers.add(new AssemblerRecipes());
|
recipeHandlers.add(new AssemblerRecipes());
|
||||||
|
|
||||||
recipeHandlers.add(new MatDistribution());
|
recipeHandlers.add(new MatDistribution());
|
||||||
|
|||||||
@ -201,7 +201,7 @@ public class BulletConfig implements Cloneable {
|
|||||||
|
|
||||||
float newHealth = living.getHealth();
|
float newHealth = living.getHealth();
|
||||||
|
|
||||||
if(bullet.config.damageFalloffByPen) bullet.damage -= Math.max(prevHealth - newHealth, 0);
|
if(bullet.config.damageFalloffByPen) bullet.damage -= Math.max(prevHealth - newHealth, 0) * 0.5;
|
||||||
if(!bullet.doesPenetrate() || bullet.damage < 0) {
|
if(!bullet.doesPenetrate() || bullet.damage < 0) {
|
||||||
bullet.setPosition(mop.hitVec.xCoord, mop.hitVec.yCoord, mop.hitVec.zCoord);
|
bullet.setPosition(mop.hitVec.xCoord, mop.hitVec.yCoord, mop.hitVec.zCoord);
|
||||||
bullet.setDead();
|
bullet.setDead();
|
||||||
|
|||||||
@ -1598,13 +1598,13 @@ item.casing_44.name=.44 Magnum-Hülsen
|
|||||||
item.casing_50.name=Großkaliberhülsen
|
item.casing_50.name=Großkaliberhülsen
|
||||||
item.casing_9.name=Kleinkaliberhülsen
|
item.casing_9.name=Kleinkaliberhülsen
|
||||||
item.casing_buckshot.name=Schrothülsen
|
item.casing_buckshot.name=Schrothülsen
|
||||||
item.casing.small.name=Kleine Rotgussgehäuse
|
item.casing.small.name=Kleine Patronenhülse
|
||||||
item.casing.small_steel.name=Stahlhülsen für kleine Waffen
|
item.casing.small_steel.name=Kleine Waffenstahlhülse
|
||||||
item.casing.large.name=Large Rotgussgehäuse
|
item.casing.large.name=Große Patronenhülse
|
||||||
item.casing.large_steel.name=Große Waffenstahlhülsen
|
item.casing.large_steel.name=Große Waffenstahlhülse
|
||||||
item.casing.shotshell.name=Schrotpatronenhülsen
|
item.casing.shotshell.name=Schwarzpulver-Schrothülse
|
||||||
item.casing.buckshot.name=Schrothülsen
|
item.casing.buckshot.name=Plastik-Schrothülse
|
||||||
item.casing.buckshot_advanced.name=Fortschrittliche Schrothülsen
|
item.casing.buckshot_advanced.name=Fortgeschrittene Schrothülse
|
||||||
item.catalyst_clay.name=Tonerde-Katalysator
|
item.catalyst_clay.name=Tonerde-Katalysator
|
||||||
item.catalytic_converter.name=Katalytischer Konverter
|
item.catalytic_converter.name=Katalytischer Konverter
|
||||||
item.cbt_device.name=CBT-Gerät
|
item.cbt_device.name=CBT-Gerät
|
||||||
|
|||||||
@ -2367,14 +2367,14 @@ item.casing_357.name=.357 Magnum Casings
|
|||||||
item.casing_44.name=.44 Magnum Casings
|
item.casing_44.name=.44 Magnum Casings
|
||||||
item.casing_50.name=Large Caliber Casings
|
item.casing_50.name=Large Caliber Casings
|
||||||
item.casing_9.name=Small Caliber Casings
|
item.casing_9.name=Small Caliber Casings
|
||||||
item.casing_buckshot.name=Buckshot Casings
|
item.casing_buckshot.name=Buckshot Casing
|
||||||
item.casing.small.name=Small Gunmetal Casings
|
item.casing.small.name=Small Gunmetal Casing
|
||||||
item.casing.small_steel.name=Small Weapon Steel Casings
|
item.casing.small_steel.name=Small Weapon Steel Casing
|
||||||
item.casing.large.name=Large Gunmetal Casings
|
item.casing.large.name=Large Gunmetal Casing
|
||||||
item.casing.large_steel.name=Large Weapon Steel Casings
|
item.casing.large_steel.name=Large Weapon Steel Casing
|
||||||
item.casing.shotshell.name=Shotshell Casings
|
item.casing.shotshell.name=Black Powder Shotshell Casing
|
||||||
item.casing.buckshot.name=Buckshot Casings
|
item.casing.buckshot.name=Plastic Shotshell Casing
|
||||||
item.casing.buckshot_advanced.name=Advanced Buckshot Casings
|
item.casing.buckshot_advanced.name=Advanced Shotshell Casing
|
||||||
item.catalyst_clay.name=Clay Catalyst
|
item.catalyst_clay.name=Clay Catalyst
|
||||||
item.catalytic_converter.name=Catalytic Converter
|
item.catalytic_converter.name=Catalytic Converter
|
||||||
item.cbt_device.name=CBT Device
|
item.cbt_device.name=CBT Device
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user