diff --git a/mods/tinker/armory/client/RenderDisplay.java b/mods/tinker/armory/client/RenderDisplay.java index 7f98fce..5f6266b 100644 --- a/mods/tinker/armory/client/RenderDisplay.java +++ b/mods/tinker/armory/client/RenderDisplay.java @@ -24,96 +24,96 @@ public class RenderDisplay implements ISimpleBlockRenderingHandler } public void renderInventoryBlock (Block block, int metadata, int modelID, RenderBlocks renderer) - { - if (modelID == displayModel) - { - if (metadata == 5) - { - renderer.setRenderBounds(0.0F, 0.0, 0.0F, 1.0F, 0.875F, 1.0F); - renderDo(renderer, block, metadata); - } - else - { - renderer.setRenderBounds(0.0F, 0.75F, 0.0F, 1.0F, 1.0F, 1.0F); - renderDo(renderer, block, metadata); - renderer.setRenderBounds(0.0F, 0.0F, 0.0F, 0.25F, 0.75F, 0.25F); - renderDo(renderer, block, metadata); - renderer.setRenderBounds(0.75F, 0.0F, 0.0F, 1.0F, 0.75F, 0.25F); - renderDo(renderer, block, metadata); - renderer.setRenderBounds(0.0F, 0.0F, 0.75F, 0.25F, 0.75F, 1.0F); - renderDo(renderer, block, metadata); - renderer.setRenderBounds(0.75F, 0.0F, 0.75F, 1.0F, 0.75F, 1.0F); - renderDo(renderer, block, metadata); - } - } - } + { + if (modelID == displayModel) + { + if (metadata == 5) + { + renderer.setRenderBounds(0.0F, 0.0, 0.0F, 1.0F, 0.875F, 1.0F); + renderDo(renderer, block, metadata); + } + else + { + renderer.setRenderBounds(0.0F, 0.75F, 0.0F, 1.0F, 1.0F, 1.0F); + renderDo(renderer, block, metadata); + renderer.setRenderBounds(0.0F, 0.0F, 0.0F, 0.25F, 0.75F, 0.25F); + renderDo(renderer, block, metadata); + renderer.setRenderBounds(0.75F, 0.0F, 0.0F, 1.0F, 0.75F, 0.25F); + renderDo(renderer, block, metadata); + renderer.setRenderBounds(0.0F, 0.0F, 0.75F, 0.25F, 0.75F, 1.0F); + renderDo(renderer, block, metadata); + renderer.setRenderBounds(0.75F, 0.0F, 0.75F, 1.0F, 0.75F, 1.0F); + renderDo(renderer, block, metadata); + } + } + } - @Override - public boolean renderWorldBlock (IBlockAccess world, int x, int y, int z, Block block, int modelID, RenderBlocks renderer) - { - if (modelID == displayModel) - { - int metadata = world.getBlockMetadata(x, y, z); - TileEntity te = world.getBlockTileEntity(x, y, z); - ItemStack topStack = ((DisplayLogic)te).getFrontDisplay(); - Block topSkin = Block.blocksList[topStack.itemID]; - int topMeta = topStack.getItemDamage(); - ItemStack bottomStack = ((DisplayLogic)te).getBackDisplay(); - Block bottomSkin = Block.blocksList[bottomStack.itemID]; - int bottomMeta = bottomStack.getItemDamage(); - - renderer.setRenderBounds(0.125, 0.125F, 0.0F, 0.375, 0.875F, 0.0625); - BlockSkinRenderHelper.renderMetadataBlock(bottomSkin, bottomMeta, x, y, z, renderer, world); - renderer.setRenderBounds(0.6125, 0.125F, 0.0F, 0.875, 0.875F, 0.0625); - BlockSkinRenderHelper.renderMetadataBlock(bottomSkin, bottomMeta, x, y, z, renderer, world); - renderer.setRenderBounds(0.0F, 0.5F, 0.0F, 1.0F, 0.625F, 0.09375); - BlockSkinRenderHelper.renderMetadataBlock(topSkin, topMeta, x, y, z, renderer, world); - renderer.setRenderBounds(0.0F, 0.0F, 0.0F, 1.0F, 0.125F, 0.125); - BlockSkinRenderHelper.renderMetadataBlock(topSkin, topMeta, x, y, z, renderer, world); - } - return false; - } + @Override + public boolean renderWorldBlock (IBlockAccess world, int x, int y, int z, Block block, int modelID, RenderBlocks renderer) + { + if (modelID == displayModel) + { + int metadata = world.getBlockMetadata(x, y, z); + TileEntity te = world.getBlockTileEntity(x, y, z); + ItemStack topStack = ((DisplayLogic) te).getFrontDisplay(); + Block topSkin = Block.blocksList[topStack.itemID]; + int topMeta = topStack.getItemDamage(); + ItemStack bottomStack = ((DisplayLogic) te).getBackDisplay(); + Block bottomSkin = Block.blocksList[bottomStack.itemID]; + int bottomMeta = bottomStack.getItemDamage(); - @Override - public boolean shouldRender3DInInventory () - { - return true; - } + renderer.setRenderBounds(0.125, 0.125F, 0.0F, 0.375, 0.875F, 0.0625); + BlockSkinRenderHelper.renderMetadataBlock(bottomSkin, bottomMeta, x, y, z, renderer, world); + renderer.setRenderBounds(0.6125, 0.125F, 0.0F, 0.875, 0.875F, 0.0625); + BlockSkinRenderHelper.renderMetadataBlock(bottomSkin, bottomMeta, x, y, z, renderer, world); + renderer.setRenderBounds(0.0F, 0.5F, 0.0F, 1.0F, 0.625F, 0.09375); + BlockSkinRenderHelper.renderMetadataBlock(topSkin, topMeta, x, y, z, renderer, world); + renderer.setRenderBounds(0.0F, 0.0F, 0.0F, 1.0F, 0.125F, 0.125); + BlockSkinRenderHelper.renderMetadataBlock(topSkin, topMeta, x, y, z, renderer, world); + } + return false; + } - @Override - public int getRenderId () - { - return displayModel; - } + @Override + public boolean shouldRender3DInInventory () + { + return true; + } - private void renderDo(RenderBlocks renderblocks, Block block, int meta) - { - Tessellator tessellator = Tessellator.instance; - GL11.glTranslatef(-0.5F, -0.5F, -0.5F); - tessellator.startDrawingQuads(); - tessellator.setNormal(0.0F, -1F, 0.0F); - renderblocks.renderBottomFace(block, 0.0D, 0.0D, 0.0D, block.getBlockTextureFromSideAndMetadata(0, meta)); - tessellator.draw(); - tessellator.startDrawingQuads(); - tessellator.setNormal(0.0F, 1.0F, 0.0F); - renderblocks.renderTopFace(block, 0.0D, 0.0D, 0.0D, block.getBlockTextureFromSideAndMetadata(1, meta)); - tessellator.draw(); - tessellator.startDrawingQuads(); - tessellator.setNormal(0.0F, 0.0F, -1F); - renderblocks.renderEastFace(block, 0.0D, 0.0D, 0.0D, block.getBlockTextureFromSideAndMetadata(2, meta)); - tessellator.draw(); - tessellator.startDrawingQuads(); - tessellator.setNormal(0.0F, 0.0F, 1.0F); - renderblocks.renderWestFace(block, 0.0D, 0.0D, 0.0D, block.getBlockTextureFromSideAndMetadata(3, meta)); - tessellator.draw(); - tessellator.startDrawingQuads(); - tessellator.setNormal(-1F, 0.0F, 0.0F); - renderblocks.renderNorthFace(block, 0.0D, 0.0D, 0.0D, block.getBlockTextureFromSideAndMetadata(4, meta)); - tessellator.draw(); - tessellator.startDrawingQuads(); - tessellator.setNormal(1.0F, 0.0F, 0.0F); - renderblocks.renderSouthFace(block, 0.0D, 0.0D, 0.0D, block.getBlockTextureFromSideAndMetadata(5, meta)); - tessellator.draw(); - GL11.glTranslatef(0.5F, 0.5F, 0.5F); - } + @Override + public int getRenderId () + { + return displayModel; + } + + private void renderDo (RenderBlocks renderblocks, Block block, int meta) + { + Tessellator tessellator = Tessellator.instance; + GL11.glTranslatef(-0.5F, -0.5F, -0.5F); + tessellator.startDrawingQuads(); + tessellator.setNormal(0.0F, -1F, 0.0F); + renderblocks.renderBottomFace(block, 0.0D, 0.0D, 0.0D, block.getBlockTextureFromSideAndMetadata(0, meta)); + tessellator.draw(); + tessellator.startDrawingQuads(); + tessellator.setNormal(0.0F, 1.0F, 0.0F); + renderblocks.renderTopFace(block, 0.0D, 0.0D, 0.0D, block.getBlockTextureFromSideAndMetadata(1, meta)); + tessellator.draw(); + tessellator.startDrawingQuads(); + tessellator.setNormal(0.0F, 0.0F, -1F); + renderblocks.renderEastFace(block, 0.0D, 0.0D, 0.0D, block.getBlockTextureFromSideAndMetadata(2, meta)); + tessellator.draw(); + tessellator.startDrawingQuads(); + tessellator.setNormal(0.0F, 0.0F, 1.0F); + renderblocks.renderWestFace(block, 0.0D, 0.0D, 0.0D, block.getBlockTextureFromSideAndMetadata(3, meta)); + tessellator.draw(); + tessellator.startDrawingQuads(); + tessellator.setNormal(-1F, 0.0F, 0.0F); + renderblocks.renderNorthFace(block, 0.0D, 0.0D, 0.0D, block.getBlockTextureFromSideAndMetadata(4, meta)); + tessellator.draw(); + tessellator.startDrawingQuads(); + tessellator.setNormal(1.0F, 0.0F, 0.0F); + renderblocks.renderSouthFace(block, 0.0D, 0.0D, 0.0D, block.getBlockTextureFromSideAndMetadata(5, meta)); + tessellator.draw(); + GL11.glTranslatef(0.5F, 0.5F, 0.5F); + } } diff --git a/mods/tinker/armory/content/DisplayLogic.java b/mods/tinker/armory/content/DisplayLogic.java index 9e88a96..defbd3a 100644 --- a/mods/tinker/armory/content/DisplayLogic.java +++ b/mods/tinker/armory/content/DisplayLogic.java @@ -7,24 +7,24 @@ import net.minecraft.item.ItemStack; public abstract class DisplayLogic extends InventoryLogic { - public DisplayLogic(int invSize) - { - super(invSize + 2); //Skin blocks - } + public DisplayLogic(int invSize) + { + super(invSize + 2); //Skin blocks + } - public ItemStack getFrontDisplay() - { - if (inventory[0] == null || !(inventory[0].getItem() instanceof ItemBlock)) - return new ItemStack(Block.planks, 1, 1); - else - return inventory[0]; - } + public ItemStack getFrontDisplay () + { + if (inventory[0] == null || !(inventory[0].getItem() instanceof ItemBlock)) + return new ItemStack(Block.planks, 1, 1); + else + return inventory[0]; + } - public ItemStack getBackDisplay() - { - if (inventory[1] == null || !(inventory[1].getItem() instanceof ItemBlock)) - return new ItemStack(Block.cloth, 1, 3); - else - return inventory[1]; - } + public ItemStack getBackDisplay () + { + if (inventory[1] == null || !(inventory[1].getItem() instanceof ItemBlock)) + return new ItemStack(Block.cloth, 1, 3); + else + return inventory[1]; + } } diff --git a/mods/tinker/common/ToolMod.java b/mods/tinker/common/ToolMod.java index 625b4dc..0996b53 100644 --- a/mods/tinker/common/ToolMod.java +++ b/mods/tinker/common/ToolMod.java @@ -91,22 +91,31 @@ public abstract class ToolMod public void addMatchingEffect (ItemStack tool) { NBTTagCompound tags = tool.getTagCompound().getCompoundTag("InfiTool"); - if (tags.hasKey("Effect3") || tags.hasKey(key)) + if (tags.hasKey("Effect6") || tags.hasKey(key)) return; - + + else if (tags.hasKey("Effect5")) + { + tags.setInteger("Effect6", effectIndex); + } + else if (tags.hasKey("Effect4")) + { + tags.setInteger("Effect5", effectIndex); + } + else if (tags.hasKey("Effect3")) + { + tags.setInteger("Effect4", effectIndex); + } else if (tags.hasKey("Effect2")) { - //System.out.println("Adding Effect 3"); tags.setInteger("Effect3", effectIndex); } else if (tags.hasKey("Effect1")) { - //System.out.println("Adding Effect 2"); tags.setInteger("Effect2", effectIndex); } else { - //System.out.println("Adding Effect 1"); tags.setInteger("Effect1", effectIndex); } } diff --git a/mods/tinker/resources/lang/en_US.xml b/mods/tinker/resources/lang/en_US.xml index 1843f2b..f14e7bd 100644 --- a/mods/tinker/resources/lang/en_US.xml +++ b/mods/tinker/resources/lang/en_US.xml @@ -51,7 +51,7 @@ Blank Pattern Blank Cast - Tinker's Log + Materials and You Materials and You Mighty Smelting @@ -80,5 +80,7 @@ Blue Slime Nitro Creeper + Blue Slime + Nitro Creeper \ No newline at end of file diff --git a/mods/tinker/resources/manuals/firstday.xml b/mods/tinker/resources/manuals/firstday.xml new file mode 100644 index 0000000..76de24f --- /dev/null +++ b/mods/tinker/resources/manuals/firstday.xml @@ -0,0 +1,161 @@ + + + + +Materials and You +Surviving the first day and beyond + +Volume 1 +By Skyla + + + +Table of Contents + + Getting Started + sapling + 3 + + + Recipes + workbench + 5 + + + + +Welcome to the first edition of Materials and You: Surviving the first day and beyond. Within these pages you will find the first steps to making the tools and materials you need to survive. + +This book is a magic copy; it updates whenever the original has been modified. Check back occasionally for information on new things. + + + +The first step in making tools is crafting a blank pattern. It is a blank slate to stamp a shape into, providing a reference for future creations. The patterns are shaped on the Stencil Table or are used as tabletops. + +You can then shape a material in a part builder with the pattern, then combine parts in the tool station. Patterns can be stored and accessed in the pattern chest. + +Together these make the Tool Workshop. It is recommended you keep all of these nearby when using any of them. + + + +Blank Pattern + + blankpattern + two + + + + +Stencil Table + + stenciltable + two + + + + +Part Crafter + + partcrafter + two + + + + +Pattern Chest + + patternchest + two + + + + +Tool Station + + toolstation + two + + + + +Once you're well established, you can begin to process metals in a more efficient manner. The scope of the smeltery is beyond this volume, but a few recipes will help you get started. + + + +Grout + + grout + two + + + + +Seared Brick +searedbrick + + + +Seared Bricks + + searedbricks + two + + + + +Smeltery Controller + + smelterycontroller + three + + + + +Smeltery Drain + + smelterydrain + three + + + + +Lava Tank + + smelterytank1 + three + + + + +Seared Glass + + smelterytank2 + three + + + + +Seared Window + + smelterytank3 + three + + + + +Casting Table + + smelterytable + three + + + + +Seared Faucet + + smelteryfaucet + three + + + + \ No newline at end of file diff --git a/mods/tinker/resources/manuals/materials.xml b/mods/tinker/resources/manuals/materials.xml index 8998bac..ad1ff66 100644 --- a/mods/tinker/resources/manuals/materials.xml +++ b/mods/tinker/resources/manuals/materials.xml @@ -5,50 +5,208 @@ Materials and You A Guide to Tools and Abilities -Volume 1 +Volume 2 By Skyla - -Table of Contents - -This book is -not- anywhere near finished. Please don't read me yet. + +Table of Contents + + Tools + ironpick + 2 + + + Materials + woodplanks + 4 + + + Modifiers + lavacrystal + 4 + -Welcome to the first edition of Materials and You: A Guide to Tools and Abilities. Within you will find details on each tool and anything you can make them from. You will also find the key to becoming a great Tool Tinker: changing tools after they're created. Many of the best known tools have changed so much since their inception that they may as well be somethign else. +Welcome to the second edition of Materials and You: A Guide to Tools and Abilities. Within these pages you will details on every known tool, modifier, and material. A detailed breakdown of each + +This book is a magic copy; it updates whenever the original has been modified. Check back occasionally for information on new things. - -Worktables - -In general: -- Tools are made from parts -- Parts are created from materials using a pattern - -We will create three separate areas for the creation of tools. The first will be for shaping patterns, the second for crafting parts out of materials, and the last will be the main station for finished products. + +Wood +woodaxe +It seems to grow everywhere. + +
woodplanks
+
- -Blank patterns are where the - + +Stone +stonepick +One of the most common materials in the world. + +
stoneblock
+ stoneshard + stonerod +
- -Blank Wood Pattern -woodpattern + +Iron +ironpick +A staple for tools, it can be refined and processed. + +
ironingot
+
- -The Stencil Table is where you shape blank patterns into something useful. This is done by punching a hole in precisely the shape you want the end result to look like. Materials can be place in the hole and combined until they resemble the end product. - + +Flint +flintshovel +More durable than stone. The material of choice for cavemen. + +
flint
+
- -Stencil Table -stenciltable + +Cactus +cactussword +A form of wood found only in the desert. + +
cactus
+
- - + + +Bone +bonerapier +A material with many uses dead or alive. + +
bone
+
+ + +Obsidian +bonefrypan +Tough as nails, but fragile when shaped. + +
obsidian
+
+
+ + +Alumite +alumitepick +An uncommon alloy. It seems to be quite durable. + +
alumiteingot
+
+
+ + +Netherrack +netherrackmattock +This is made of what?! + +
netherrack
+
+
+ + +Blue Slime +blueslimebattlesign +Converting it from food has made it stronger. +BlueSlime + +
blueslimecrystal
+
+
+ + +Green Slime +slimebattlesign +Soft and springy, it seems to last forever. +Slime + +
slimecrystal
+
+
+ + +Paper +paperpick +It's very weak, but can take a lot of modification. + +
paperstack
+
+
+ + +Paper +paperpick +It's very weak, but can take a lot of modification. + +
paperstack
+
+
+ + +Cobalt +cobaltlongsword +One of the nether materials. It's bright blue. + +
cobaltingot
+
+
+ + +Ardite +arditelongsword +One of the nether materials. It's rustic red. + +
arditeingot
+
+
+ + +Manyullyn +manyullynlongsword +The nether alloy. It's stronger than diamond. + +
manyullyningot
+
+
+ + +Copper +copperaxe +A common metal found in the ground. + +
copperingot
+
+
+ + +Bronze +bronzeaxe +A common alloy. It's a bit better than iron. + +
bronzeingot
+
+
+ + +Steel +steelsword +An Iron alloy. The method for obtaining this is unknown. + +
steelingot
+
+
+ \ No newline at end of file diff --git a/mods/tinker/resources/manuals/smeltery.xml b/mods/tinker/resources/manuals/smeltery.xml index b9a7958..6d74c2c 100644 --- a/mods/tinker/resources/manuals/smeltery.xml +++ b/mods/tinker/resources/manuals/smeltery.xml @@ -127,7 +127,80 @@ Other liquid removal objects will work, but are frowned upon. An example picture
- -To be continued... + +Grout + + grout + two + + + + +Seared Brick +searedbrick + + + +Seared Bricks + + searedbricks + two + + + + +Smeltery Controller + + smelterycontroller + three + + + + +Smeltery Drain + + smelterydrain + three + + + + +Lava Tank + + smelterytank1 + three + + + + +Seared Glass + + smelterytank2 + three + + + + +Seared Window + + smelterytank3 + three + + + + +Casting Table + + smelterytable + three + + + + +Seared Faucet + + smelteryfaucet + three + \ No newline at end of file diff --git a/mods/tinker/tconstruct/PHConstruct.java b/mods/tinker/tconstruct/PHConstruct.java index 245ca75..6a24fb8 100644 --- a/mods/tinker/tconstruct/PHConstruct.java +++ b/mods/tinker/tconstruct/PHConstruct.java @@ -56,7 +56,7 @@ public class PHConstruct { redCreeper = config.get("Mob Spawning", "Activate Nitro Creeper Spawns", true).getBoolean(true); blueSlime = config.get("Mob Spawning", "Activate Blue Slime Spawns", true).getBoolean(true); - redCreeperWeight = config.get("Mob Spawning", "Spawn Weight for Nitro Creeper", 5).getInt(5); + redCreeperWeight = config.get("Mob Spawning", "Spawn Weight for Nitro Creeper", 6).getInt(6); blueSlimeWeight = config.get("Mob Spawning", "Spawn Weight for Blue Slime", 8).getInt(8); woodCrafter = config.getBlock("Wood Tool Station", 1471).getInt(1471); @@ -75,6 +75,8 @@ public class PHConstruct { golemHead = config.getBlock("Golem Head", 1482).getInt(1482); golemPedestal = config.getBlock("Golem Pedestal", 1483).getInt(1483); + stoneTorch = config.getBlock("Stone Torch", 1484).getInt(1484); + manual = config.getItem("Patterns and Misc", "Tinker's Manual", 14018).getInt(14018); blankPattern = config.getItem("Patterns and Misc", "Blank Patterns", 14019).getInt(14019); materials = config.getItem("Patterns and Misc", "Materials", 14020).getInt(14020); @@ -147,7 +149,7 @@ public class PHConstruct { tinDensity = config.get("Worldgen", "Tin Density", 8).getInt(8); tinHeight = config.get("Worldgen", "Tin Height", 0).getInt(0); tinRange = config.get("Worldgen", "Tin Range", 40).getInt(40); - aluminumDensity = config.get("Worldgen", "Aluminum Density", 9).getInt(9); + aluminumDensity = config.get("Worldgen", "Aluminum Density", 5).getInt(5); aluminumHeight = config.get("Worldgen", "Aluminum Height", 0).getInt(0); aluminumRange = config.get("Worldgen", "Aluminum Range", 64).getInt(64); netherDensity = config.get("Worldgen", "Nether Ores Density", 8).getInt(8); @@ -179,6 +181,9 @@ public class PHConstruct { public static int metalFlowing; public static int metalStill; + //Decoration + public static int stoneTorch; + //Patterns and misc public static int blankPattern; public static int materials; diff --git a/mods/tinker/tconstruct/TConstruct.java b/mods/tinker/tconstruct/TConstruct.java index e919c55..0158bf2 100644 --- a/mods/tinker/tconstruct/TConstruct.java +++ b/mods/tinker/tconstruct/TConstruct.java @@ -25,7 +25,7 @@ import cpw.mods.fml.common.registry.GameRegistry; * @author: mDiyo */ -@Mod(modid = "TConstruct", name = "TConstruct", version = "1.5.1_1.2.17") +@Mod(modid = "TConstruct", name = "TConstruct", version = "1.5.1_1.2.23") @NetworkMod(serverSideRequired = false, clientSideRequired = true, channels = { "TConstruct" }, packetHandler = mods.tinker.tconstruct.TPacketHandler.class) public class TConstruct { diff --git a/mods/tinker/tconstruct/TContent.java b/mods/tinker/tconstruct/TContent.java index ce189f8..58f194b 100644 --- a/mods/tinker/tconstruct/TContent.java +++ b/mods/tinker/tconstruct/TContent.java @@ -4,80 +4,17 @@ import java.lang.ref.WeakReference; import java.util.ArrayList; import java.util.List; -import mods.tinker.common.IPattern; -import mods.tinker.common.RecipeRemover; +import mods.tinker.common.*; import mods.tinker.common.fancyitem.FancyEntityItem; -import mods.tinker.tconstruct.blocks.EquipBlock; -import mods.tinker.tconstruct.blocks.GolemCoreBlock; -import mods.tinker.tconstruct.blocks.GolemHeadBlock; -import mods.tinker.tconstruct.blocks.GolemPedestalBlock; -import mods.tinker.tconstruct.blocks.LavaTankBlock; -import mods.tinker.tconstruct.blocks.LiquidMetalFlowing; -import mods.tinker.tconstruct.blocks.LiquidMetalStill; -import mods.tinker.tconstruct.blocks.MetalOre; -import mods.tinker.tconstruct.blocks.SearedBlock; -import mods.tinker.tconstruct.blocks.SmelteryBlock; -import mods.tinker.tconstruct.blocks.TConstructBlock; -import mods.tinker.tconstruct.blocks.ToolStationBlock; -import mods.tinker.tconstruct.crafting.LiquidCasting; -import mods.tinker.tconstruct.crafting.PatternBuilder; -import mods.tinker.tconstruct.crafting.Smeltery; -import mods.tinker.tconstruct.crafting.ToolBuilder; -import mods.tinker.tconstruct.entity.BlueSlime; -import mods.tinker.tconstruct.entity.Crystal; -import mods.tinker.tconstruct.entity.LaunchedPotion; -import mods.tinker.tconstruct.entity.UnstableCreeper; -import mods.tinker.tconstruct.items.CraftedSoilItemBlock; -import mods.tinker.tconstruct.items.CraftingItem; -import mods.tinker.tconstruct.items.FilledBucket; -import mods.tinker.tconstruct.items.LavaTankItemBlock; -import mods.tinker.tconstruct.items.LiquidItemBlock; -import mods.tinker.tconstruct.items.MetalItemBlock; -import mods.tinker.tconstruct.items.MetalOreItemBlock; -import mods.tinker.tconstruct.items.MetalPattern; -import mods.tinker.tconstruct.items.Pattern; -import mods.tinker.tconstruct.items.PatternManual; -import mods.tinker.tconstruct.items.SearedTableItemBlock; -import mods.tinker.tconstruct.items.SmelteryItemBlock; -import mods.tinker.tconstruct.items.StrangeFood; -import mods.tinker.tconstruct.items.TitleIcon; -import mods.tinker.tconstruct.items.ToolPart; -import mods.tinker.tconstruct.items.ToolShard; -import mods.tinker.tconstruct.items.ToolStationItemBlock; -import mods.tinker.tconstruct.library.TConstructRegistry; -import mods.tinker.tconstruct.library.ToolCore; -import mods.tinker.tconstruct.logic.CastingTableLogic; -import mods.tinker.tconstruct.logic.FaucetLogic; -import mods.tinker.tconstruct.logic.FrypanLogic; -import mods.tinker.tconstruct.logic.GolemCoreLogic; -import mods.tinker.tconstruct.logic.GolemPedestalLogic; -import mods.tinker.tconstruct.logic.LavaTankLogic; -import mods.tinker.tconstruct.logic.LiquidTextureLogic; -import mods.tinker.tconstruct.logic.MultiServantLogic; -import mods.tinker.tconstruct.logic.PartCrafterLogic; -import mods.tinker.tconstruct.logic.PatternChestLogic; -import mods.tinker.tconstruct.logic.PatternShaperLogic; -import mods.tinker.tconstruct.logic.SmelteryDrainLogic; -import mods.tinker.tconstruct.logic.SmelteryLogic; -import mods.tinker.tconstruct.logic.ToolStationLogic; -import mods.tinker.tconstruct.modifiers.ModBlaze; -import mods.tinker.tconstruct.modifiers.ModBoolean; -import mods.tinker.tconstruct.modifiers.ModDurability; -import mods.tinker.tconstruct.modifiers.ModElectric; -import mods.tinker.tconstruct.modifiers.ModInteger; -import mods.tinker.tconstruct.modifiers.ModLapis; -import mods.tinker.tconstruct.modifiers.ModRedstone; -import mods.tinker.tconstruct.modifiers.ModRepair; -import mods.tinker.tconstruct.tools.Axe; -import mods.tinker.tconstruct.tools.BattleSign; -import mods.tinker.tconstruct.tools.Broadsword; -import mods.tinker.tconstruct.tools.FryingPan; -import mods.tinker.tconstruct.tools.Longsword; -import mods.tinker.tconstruct.tools.Mattock; -import mods.tinker.tconstruct.tools.Pickaxe; -import mods.tinker.tconstruct.tools.PotionLauncher; -import mods.tinker.tconstruct.tools.Rapier; -import mods.tinker.tconstruct.tools.Shovel; +import mods.tinker.tconstruct.blocks.*; +import mods.tinker.tconstruct.crafting.*; +import mods.tinker.tconstruct.entity.*; +import mods.tinker.tconstruct.items.*; +import mods.tinker.tconstruct.library.*; +import mods.tinker.tconstruct.logic.*; +import mods.tinker.tconstruct.modifiers.*; +import mods.tinker.tconstruct.tools.*; + import net.minecraft.block.Block; import net.minecraft.block.material.MapColor; import net.minecraft.block.material.Material; @@ -101,682 +38,713 @@ import cpw.mods.fml.common.registry.GameRegistry; public class TContent implements IFuelHandler { - //Patterns and other materials - public static Item blankPattern; - public static Item materials; - public static Item toolRod; - public static Item toolShard; - public static Item woodPattern; - public static Item metalPattern; + //Patterns and other materials + public static Item blankPattern; + public static Item materials; + public static Item toolRod; + public static Item toolShard; + public static Item woodPattern; + public static Item metalPattern; - public static Item manualBook; - public static Item buckets; - public static Item titleIcon; - - public static Item strangeFood; - //public static Item stonePattern; - //public static Item netherPattern; + public static Item manualBook; + public static Item buckets; + public static Item titleIcon; - //Tools - public static ToolCore pickaxe; - public static ToolCore shovel; - public static ToolCore axe; - public static ToolCore broadsword; - public static ToolCore longsword; - public static ToolCore rapier; + public static Item strangeFood; + //public static Item stonePattern; + //public static Item netherPattern; - public static ToolCore frypan; - public static ToolCore battlesign; - //public static ToolCore longbow; + //Tools + public static ToolCore pickaxe; + public static ToolCore shovel; + public static ToolCore axe; + public static ToolCore broadsword; + public static ToolCore longsword; + public static ToolCore rapier; - public static ToolCore mattock; - public static ToolCore lumberaxe; - - public static Item potionLauncher; + public static ToolCore frypan; + public static ToolCore battlesign; + //public static ToolCore longbow; - //Tool parts - public static Item pickaxeHead; - public static Item shovelHead; - public static Item axeHead; - public static Item swordBlade; - public static Item largeGuard; - public static Item medGuard; - public static Item crossbar; - public static Item binding; + public static ToolCore mattock; + public static ToolCore lumberaxe; - public static Item frypanHead; - public static Item signHead; + public static Item potionLauncher; - public static Item lumberHead; + //Tool parts + public static Item pickaxeHead; + public static Item shovelHead; + public static Item axeHead; + public static Item swordBlade; + public static Item largeGuard; + public static Item medGuard; + public static Item crossbar; + public static Item binding; - //Crafting blocks - public static Block woodCrafter; - public static Block heldItemBlock; - public static Block craftedSoil; + public static Item frypanHead; + public static Item signHead; - public static Block smeltery; - public static Block lavaTank; - public static Block searedBlock; - public static Block oreSlag; - public static Block metalBlock; + public static Item lumberHead; - //Traps - public static Block landmine; + //Crafting blocks + public static Block toolStationWood; + public static Block heldItemBlock; + public static Block craftedSoil; - //Liquids - public static Block liquidMetalFlowing; - public static Block liquidMetalStill; - public static Material liquidMetal; + public static Block smeltery; + public static Block lavaTank; + public static Block searedBlock; + public static Block oreSlag; + public static Block metalBlock; - //public static Block axle; + //Decoration + public static Block stoneTorch; - //Tool modifiers - public static ModElectric modE; - - //Golems - public static Block glowSapling; - public static Block glowLeaves; - public static Block glowLog; - - public static Block golemCore; - public static Block golemPedestal; - public static Block golemHead; - - public static Item golemWand; - public static Item golemRecharger; - public static Item corestone; - public static Item notebook; - public static Item note; + //Traps + public static Block landmine; - public TContent() - { - createEntities(); - registerBlocks(); - registerItems(); - registerMaterials(); - addToolRecipes(); - addSmelteryRecipes(); - addCraftingRecipes(); - setupToolTabs(); - } + //Liquids + public static Block liquidMetalFlowing; + public static Block liquidMetalStill; + public static Material liquidMetal; - void createEntities () - { - EntityRegistry.registerModEntity(FancyEntityItem.class, "Fancy Item", 0, TConstruct.instance, 32, 5, true); - EntityRegistry.registerModEntity(LaunchedPotion.class, "Launched Potion", 1, TConstruct.instance, 32, 3, true); - //EntityRegistry.registerModEntity(CartEntity.class, "Small Wagon", 1, TConstruct.instance, 32, 5, true); - //EntityRegistry.registerModEntity(Crystal.class, "Crystal", 2, TConstruct.instance, 32, 5, true); - EntityRegistry.registerModEntity(Crystal.class, "Crystal", 2, TConstruct.instance, 32, 5, true); + //public static Block axle; - //EntityRegistry.registerModEntity(Skyla.class, "Skyla", 10, TConstruct.instance, 32, 5, true); - EntityRegistry.registerModEntity(UnstableCreeper.class, "UnstableCreeper", 11, TConstruct.instance, 64, 5, true); - EntityRegistry.registerModEntity(BlueSlime.class, "EdibleSlime", 12, TConstruct.instance, 64, 5, true); - //EntityRegistry.registerModEntity(MetalSlime.class, "MetalSlime", 13, TConstruct.instance, 64, 5, true); + //Tool modifiers + public static ModElectric modE; - BiomeGenBase[] overworldBiomes = new BiomeGenBase[] { BiomeGenBase.ocean, BiomeGenBase.plains, BiomeGenBase.desert, BiomeGenBase.extremeHills, BiomeGenBase.forest, BiomeGenBase.taiga, - BiomeGenBase.swampland, BiomeGenBase.river, BiomeGenBase.frozenOcean, BiomeGenBase.frozenRiver, BiomeGenBase.icePlains, BiomeGenBase.iceMountains, BiomeGenBase.beach, - BiomeGenBase.desertHills, BiomeGenBase.forestHills, BiomeGenBase.taigaHills, BiomeGenBase.extremeHillsEdge, BiomeGenBase.jungle, BiomeGenBase.jungleHills }; - if (PHConstruct.redCreeper) - EntityRegistry.addSpawn(UnstableCreeper.class, PHConstruct.redCreeperWeight, 4, 6, EnumCreatureType.monster, overworldBiomes); - if (PHConstruct.blueSlime) - EntityRegistry.addSpawn(BlueSlime.class, PHConstruct.blueSlimeWeight, 4, 4, EnumCreatureType.monster, overworldBiomes); - //EntityRegistry.addSpawn(MetalSlime.class, 1, 4, 4, EnumCreatureType.monster, overworldBiomes); - } + //Golems + public static Block glowSapling; + public static Block glowLeaves; + public static Block glowLog; - void registerBlocks () - { - //Tool Station - woodCrafter = new ToolStationBlock(PHConstruct.woodCrafter, Material.wood); - GameRegistry.registerBlock(woodCrafter, ToolStationItemBlock.class, "ToolStationBlock"); - GameRegistry.registerTileEntity(ToolStationLogic.class, "ToolStation"); - GameRegistry.registerTileEntity(PartCrafterLogic.class, "PartCrafter"); - GameRegistry.registerTileEntity(PatternChestLogic.class, "PatternHolder"); - GameRegistry.registerTileEntity(PatternShaperLogic.class, "PatternShaper"); + public static Block golemCore; + public static Block golemPedestal; + public static Block golemHead; - heldItemBlock = new EquipBlock(PHConstruct.heldItemBlock, Material.wood); - GameRegistry.registerBlock(heldItemBlock, "HeldItemBlock"); - GameRegistry.registerTileEntity(FrypanLogic.class, "FrypanLogic"); + public static Item golemWand; + public static Item golemRecharger; + public static Item corestone; + public static Item notebook; + public static Item note; - String[] soilTypes = new String[] { "slimesand", "grout", "slimesandblue" }; - craftedSoil = new TConstructBlock(PHConstruct.craftedSoil, Material.sand, 3.0F, soilTypes); - craftedSoil.stepSound = Block.soundGravelFootstep; - GameRegistry.registerBlock(craftedSoil, CraftedSoilItemBlock.class, "CraftedSoil"); + public TContent() + { + createEntities(); + registerBlocks(); + registerItems(); + registerMaterials(); + addToolRecipes(); + addSmelteryRecipes(); + addCraftingRecipes(); + setupToolTabs(); + } - String[] metalTypes = new String[] { "compressed_cobalt", "compressed_ardite", "compressed_manyullyn", "compressed_copper", "compressed_bronze", "compressed_tin", "compressed_aluminum", - "compressed_alubrass", "compressed_alumite", "compressed_steel" }; - metalBlock = new TConstructBlock(PHConstruct.metalBlock, Material.iron, 10.0F, metalTypes); - metalBlock.stepSound = Block.soundMetalFootstep; - GameRegistry.registerBlock(metalBlock, MetalItemBlock.class, "MetalBlock"); + void createEntities () + { + EntityRegistry.registerModEntity(FancyEntityItem.class, "Fancy Item", 0, TConstruct.instance, 32, 5, true); + EntityRegistry.registerModEntity(LaunchedPotion.class, "Launched Potion", 1, TConstruct.instance, 32, 3, true); + //EntityRegistry.registerModEntity(CartEntity.class, "Small Wagon", 1, TConstruct.instance, 32, 5, true); + //EntityRegistry.registerModEntity(Crystal.class, "Crystal", 2, TConstruct.instance, 32, 5, true); + EntityRegistry.registerModEntity(Crystal.class, "Crystal", 2, TConstruct.instance, 32, 5, true); - //Smeltery - smeltery = new SmelteryBlock(PHConstruct.smeltery).setUnlocalizedName("Smeltery"); - GameRegistry.registerBlock(smeltery, SmelteryItemBlock.class, "Smeltery"); - GameRegistry.registerTileEntity(SmelteryLogic.class, "TConstruct.Smeltery"); - GameRegistry.registerTileEntity(SmelteryDrainLogic.class, "TConstruct.SmelteryDrain"); - GameRegistry.registerTileEntity(MultiServantLogic.class, "TConstruct.Servants"); + //EntityRegistry.registerModEntity(Skyla.class, "Skyla", 10, TConstruct.instance, 32, 5, true); + EntityRegistry.registerModEntity(UnstableCreeper.class, "UnstableCreeper", 11, TConstruct.instance, 64, 5, true); + EntityRegistry.registerModEntity(BlueSlime.class, "EdibleSlime", 12, TConstruct.instance, 64, 5, true); + //EntityRegistry.registerModEntity(MetalSlime.class, "MetalSlime", 13, TConstruct.instance, 64, 5, true); - lavaTank = new LavaTankBlock(PHConstruct.lavaTank).setUnlocalizedName("LavaTank"); - lavaTank.setStepSound(Block.soundGlassFootstep); - GameRegistry.registerBlock(lavaTank, LavaTankItemBlock.class, "LavaTank"); - GameRegistry.registerTileEntity(LavaTankLogic.class, "TConstruct.LavaTank"); + BiomeGenBase[] overworldBiomes = new BiomeGenBase[] { BiomeGenBase.ocean, BiomeGenBase.plains, BiomeGenBase.desert, BiomeGenBase.extremeHills, BiomeGenBase.forest, BiomeGenBase.taiga, + BiomeGenBase.swampland, BiomeGenBase.river, BiomeGenBase.frozenOcean, BiomeGenBase.frozenRiver, BiomeGenBase.icePlains, BiomeGenBase.iceMountains, BiomeGenBase.beach, + BiomeGenBase.desertHills, BiomeGenBase.forestHills, BiomeGenBase.taigaHills, BiomeGenBase.extremeHillsEdge, BiomeGenBase.jungle, BiomeGenBase.jungleHills }; + if (PHConstruct.redCreeper) + EntityRegistry.addSpawn(UnstableCreeper.class, PHConstruct.redCreeperWeight, 4, 6, EnumCreatureType.monster, overworldBiomes); + if (PHConstruct.blueSlime) + EntityRegistry.addSpawn(BlueSlime.class, PHConstruct.blueSlimeWeight, 4, 4, EnumCreatureType.monster, overworldBiomes); + //EntityRegistry.addSpawn(MetalSlime.class, 1, 4, 4, EnumCreatureType.monster, overworldBiomes); + } - searedBlock = new SearedBlock(PHConstruct.searedTable).setUnlocalizedName("SearedBlock"); - GameRegistry.registerBlock(searedBlock, SearedTableItemBlock.class, "SearedBlock"); - GameRegistry.registerTileEntity(CastingTableLogic.class, "CastingTable"); - GameRegistry.registerTileEntity(FaucetLogic.class, "Faucet"); + void registerBlocks () + { + //Tool Station + toolStationWood = new ToolStationBlock(PHConstruct.woodCrafter, Material.wood); + GameRegistry.registerBlock(toolStationWood, ToolStationItemBlock.class, "ToolStationBlock"); + GameRegistry.registerTileEntity(ToolStationLogic.class, "ToolStation"); + GameRegistry.registerTileEntity(PartCrafterLogic.class, "PartCrafter"); + GameRegistry.registerTileEntity(PatternChestLogic.class, "PatternHolder"); + GameRegistry.registerTileEntity(PatternShaperLogic.class, "PatternShaper"); - String[] oreTypes = new String[] { "nether_slag", "nether_cobalt", "nether_ardite", "ore_copper", "ore_tin", "ore_aluminum", "ore_slag" }; - oreSlag = new MetalOre(PHConstruct.oreSlag, Material.iron, 10.0F, oreTypes); - GameRegistry.registerBlock(oreSlag, MetalOreItemBlock.class, "SearedBrick"); - //MinecraftForge.setBlockHarvestLevel(oreSlag, 0, "pickaxe", 0); - MinecraftForge.setBlockHarvestLevel(oreSlag, 1, "pickaxe", 4); - MinecraftForge.setBlockHarvestLevel(oreSlag, 2, "pickaxe", 4); - MinecraftForge.setBlockHarvestLevel(oreSlag, 3, "pickaxe", 1); - MinecraftForge.setBlockHarvestLevel(oreSlag, 4, "pickaxe", 1); - MinecraftForge.setBlockHarvestLevel(oreSlag, 5, "pickaxe", 1); + heldItemBlock = new EquipBlock(PHConstruct.heldItemBlock, Material.wood); + GameRegistry.registerBlock(heldItemBlock, "HeldItemBlock"); + GameRegistry.registerTileEntity(FrypanLogic.class, "FrypanLogic"); - //Traps - /*landmine = new Landmine(PHConstruct.landmine, 0, EnumMobType.mobs, Material.cactus).setUnlocalizedName("landmine"); - GameRegistry.registerBlock(landmine, "landmine");*/ + String[] soilTypes = new String[] { "slimesand", "grout", "slimesandblue" }; + craftedSoil = new TConstructBlock(PHConstruct.craftedSoil, Material.sand, 3.0F, soilTypes); + craftedSoil.stepSound = Block.soundGravelFootstep; + GameRegistry.registerBlock(craftedSoil, CraftedSoilItemBlock.class, "CraftedSoil"); - //Liquids - liquidMetal = new MaterialLiquid(MapColor.tntColor); - liquidMetalFlowing = new LiquidMetalFlowing(PHConstruct.metalFlowing).setUnlocalizedName("liquid.metalFlow"); - liquidMetalStill = new LiquidMetalStill(PHConstruct.metalStill).setUnlocalizedName("liquid.metalStill"); - GameRegistry.registerBlock(liquidMetalFlowing, LiquidItemBlock.class, "metalFlow"); - GameRegistry.registerBlock(liquidMetalStill, LiquidItemBlock.class, "metalStill"); - GameRegistry.registerTileEntity(LiquidTextureLogic.class, "LiquidTexture"); - - //Golems - /*golemCore = new GolemCoreBlock(PHConstruct.golemCore).setUnlocalizedName("golemcore"); - GameRegistry.registerBlock(golemCore, "Golem Core"); - GameRegistry.registerTileEntity(GolemCoreLogic.class, "TConstruct.GolemCore"); - - golemHead = new GolemHeadBlock(PHConstruct.golemHead).setUnlocalizedName("golemhead"); - GameRegistry.registerBlock(golemHead, "Golem Head"); - - golemPedestal = new GolemPedestalBlock(PHConstruct.golemPedestal).setUnlocalizedName("golempedestal"); - GameRegistry.registerBlock(golemPedestal, "Golem Pedestal"); - GameRegistry.registerTileEntity(GolemPedestalLogic.class, "TConstruct.GolemPedestal");*/ - } + String[] metalTypes = new String[] { "compressed_cobalt", "compressed_ardite", "compressed_manyullyn", "compressed_copper", "compressed_bronze", "compressed_tin", "compressed_aluminum", + "compressed_alubrass", "compressed_alumite", "compressed_steel" }; + metalBlock = new TConstructBlock(PHConstruct.metalBlock, Material.iron, 10.0F, metalTypes); + metalBlock.stepSound = Block.soundMetalFootstep; + GameRegistry.registerBlock(metalBlock, MetalItemBlock.class, "MetalBlock"); - void registerItems () - { - titleIcon = new TitleIcon(PHConstruct.uselessItem).setUnlocalizedName("tconstruct.titleicon"); - String[] blanks = new String[] { "blank_pattern", "blank_cast" }; - blankPattern = new CraftingItem(PHConstruct.blankPattern, blanks, blanks, "materials/").setUnlocalizedName("tconstruct.Pattern"); - - String[] craftingMaterials = new String[] { "PaperStack", "SlimeCrystal", "SearedBrick", "CobaltIngot", "ArditeIngot", "ManyullynIngot", "Mossball", "LavaCrystal", "NecroticBone", - "CopperIngot", "TinIngot", "AluminumIngot", "RawAluminum", "BronzeIngot", "AlBrassIngot", "AlumiteIngot", "SteelIngot", "BlueSlimeCrystal" }; - String[] craftingTextures = new String[] { "material_paperstack", "material_slimecrystal", "material_searedbrick", "material_cobaltingot", "material_arditeingot", "material_manyullyningot", - "material_mossball", "material_lavacrystal", "material_necroticbone", "material_copperingot", "material_tiningot", "material_aluminumingot", "material_aluminumraw", - "material_bronzeingot", "material_alubrassingot", "material_alumiteingot", "material_steelingot", "material_blueslimecrystal" }; - - materials = new CraftingItem(PHConstruct.materials, craftingMaterials, craftingTextures, "materials/").setUnlocalizedName("tconstruct.Materials"); - toolRod = new ToolPart(PHConstruct.toolRod, "ToolRod", "_rod").setUnlocalizedName("tconstruct.ToolRod"); - TConstructRegistry.toolRod = toolRod; - toolShard = new ToolShard(PHConstruct.toolShard, "ToolShard", "_chunk").setUnlocalizedName("tconstruct.ToolShard"); - woodPattern = new Pattern(PHConstruct.woodPattern, "WoodPattern", "pattern_", "materials/").setUnlocalizedName("tconstruct.Pattern"); - metalPattern = new MetalPattern(PHConstruct.metalPattern, "MetalPattern", "cast_", "materials/").setUnlocalizedName("tconstruct.MetalPattern"); - //netherPattern = new Pattern(PHTools.netherPattern, 128, patternTexture).setUnlocalizedName("tconstruct.Pattern"); + //Smeltery + smeltery = new SmelteryBlock(PHConstruct.smeltery).setUnlocalizedName("Smeltery"); + GameRegistry.registerBlock(smeltery, SmelteryItemBlock.class, "Smeltery"); + GameRegistry.registerTileEntity(SmelteryLogic.class, "TConstruct.Smeltery"); + GameRegistry.registerTileEntity(SmelteryDrainLogic.class, "TConstruct.SmelteryDrain"); + GameRegistry.registerTileEntity(MultiServantLogic.class, "TConstruct.Servants"); - manualBook = new PatternManual(PHConstruct.manual); - buckets = new FilledBucket(PHConstruct.buckets); + lavaTank = new LavaTankBlock(PHConstruct.lavaTank).setUnlocalizedName("LavaTank"); + lavaTank.setStepSound(Block.soundGlassFootstep); + GameRegistry.registerBlock(lavaTank, LavaTankItemBlock.class, "LavaTank"); + GameRegistry.registerTileEntity(LavaTankLogic.class, "TConstruct.LavaTank"); - pickaxe = new Pickaxe(PHConstruct.pickaxe); - shovel = new Shovel(PHConstruct.shovel); - axe = new Axe(PHConstruct.axe); - broadsword = new Broadsword(PHConstruct.broadsword); - longsword = new Longsword(PHConstruct.longsword); - rapier = new Rapier(PHConstruct.rapier); + searedBlock = new SearedBlock(PHConstruct.searedTable).setUnlocalizedName("SearedBlock"); + GameRegistry.registerBlock(searedBlock, SearedTableItemBlock.class, "SearedBlock"); + GameRegistry.registerTileEntity(CastingTableLogic.class, "CastingTable"); + GameRegistry.registerTileEntity(FaucetLogic.class, "Faucet"); - frypan = new FryingPan(PHConstruct.frypan); - battlesign = new BattleSign(PHConstruct.battlesign); - //longbow = new RangedWeapon(PHConstruct.longbow); - mattock = new Mattock(PHConstruct.mattock); - //lumberaxe = new LumberAxe(PHConstruct.lumberaxe, lumberaxeTexture); - potionLauncher = new PotionLauncher(PHConstruct.potionLauncher).setUnlocalizedName("tconstruct.PotionLauncher"); + String[] oreTypes = new String[] { "nether_slag", "nether_cobalt", "nether_ardite", "ore_copper", "ore_tin", "ore_aluminum", "ore_slag" }; + oreSlag = new MetalOre(PHConstruct.oreSlag, Material.iron, 10.0F, oreTypes); + GameRegistry.registerBlock(oreSlag, MetalOreItemBlock.class, "SearedBrick"); + //MinecraftForge.setBlockHarvestLevel(oreSlag, 0, "pickaxe", 0); + MinecraftForge.setBlockHarvestLevel(oreSlag, 1, "pickaxe", 4); + MinecraftForge.setBlockHarvestLevel(oreSlag, 2, "pickaxe", 4); + MinecraftForge.setBlockHarvestLevel(oreSlag, 3, "pickaxe", 1); + MinecraftForge.setBlockHarvestLevel(oreSlag, 4, "pickaxe", 1); + MinecraftForge.setBlockHarvestLevel(oreSlag, 5, "pickaxe", 1); - pickaxeHead = new ToolPart(PHConstruct.pickaxeHead, "PickaxeHead", "_pickaxe_head").setUnlocalizedName("tconstruct.PickaxeHead"); - shovelHead = new ToolPart(PHConstruct.shovelHead, "ShovelHead", "_shovel_head").setUnlocalizedName("tconstruct.ShovelHead"); - axeHead = new ToolPart(PHConstruct.axeHead, "AxeHead", "_axe_head").setUnlocalizedName("tconstruct.AxeHead"); - swordBlade = new ToolPart(PHConstruct.swordBlade, "SwordBlade", "_sword_blade").setUnlocalizedName("tconstruct.SwordBlade"); - largeGuard = new ToolPart(PHConstruct.largeGuard, "LargeGuard", "_large_guard").setUnlocalizedName("tconstruct.LargeGuard"); - medGuard = new ToolPart(PHConstruct.medGuard, "MediumGuard", "_medium_guard").setUnlocalizedName("tconstruct.MediumGuard"); - crossbar = new ToolPart(PHConstruct.crossbar, "Crossbar", "_crossbar").setUnlocalizedName("tconstruct.Crossbar"); - binding = new ToolPart(PHConstruct.binding, "Binding", "_binding").setUnlocalizedName("tconstruct.Binding"); + //Traps + /*landmine = new Landmine(PHConstruct.landmine, 0, EnumMobType.mobs, Material.cactus).setUnlocalizedName("landmine"); + GameRegistry.registerBlock(landmine, "landmine");*/ - frypanHead = new ToolPart(PHConstruct.frypanHead, "FrypanHead", "_frypan_head").setUnlocalizedName("tconstruct.FrypanHead"); - signHead = new ToolPart(PHConstruct.signHead, "SignHead", "_battlesign_head").setUnlocalizedName("tconstruct.SignHead"); + //Liquids + liquidMetal = new MaterialLiquid(MapColor.tntColor); + liquidMetalFlowing = new LiquidMetalFlowing(PHConstruct.metalFlowing).setUnlocalizedName("liquid.metalFlow"); + liquidMetalStill = new LiquidMetalStill(PHConstruct.metalStill).setUnlocalizedName("liquid.metalStill"); + GameRegistry.registerBlock(liquidMetalFlowing, LiquidItemBlock.class, "metalFlow"); + GameRegistry.registerBlock(liquidMetalStill, LiquidItemBlock.class, "metalStill"); + GameRegistry.registerTileEntity(LiquidTextureLogic.class, "LiquidTexture"); - strangeFood = new StrangeFood(PHConstruct.slimefood).setUnlocalizedName("tconstruct.strangefood"); - //lumberHead = new ToolPart(PHConstruct.lumberHead, 0, broadheads).setUnlocalizedName("tconstruct.LumberHead"); - Item.doorWood.setMaxStackSize(16); - Item.doorSteel.setMaxStackSize(16); - Item.snowball.setMaxStackSize(64); - Item.boat.setMaxStackSize(16); - Item.minecartEmpty.setMaxStackSize(3); - Item.minecartCrate.setMaxStackSize(3); - Item.minecartPowered.setMaxStackSize(3); - } + //Decoration + stoneTorch = new StoneTorch(PHConstruct.stoneTorch).setUnlocalizedName("decoration.stonetorch"); + GameRegistry.registerBlock(stoneTorch, "decoration.stonetorch"); - void registerMaterials () - { - TConstructRegistry.addToolMaterial(0, "Wood", 1, 0, 59, 200, 0, 1.0F, 0, 0f, "\u00A7e", ""); - TConstructRegistry.addToolMaterial(1, "Stone", 1, 1, 131, 400, 1, 0.5F, 0, 1f, "", "Shoddy"); - TConstructRegistry.addToolMaterial(2, "Iron", 1, 2, 250, 600, 2, 1.3F, 1, 0f, "\u00A7f", ""); - TConstructRegistry.addToolMaterial(3, "Flint", 1, 1, 171, 525, 2, 0.7F, 0, 1f, "\u00A78", "Shoddy"); - TConstructRegistry.addToolMaterial(4, "Cactus", 1, 1, 150, 500, 2, 1.0F, 0, -1f, "\u00A72", "Spiny"); - TConstructRegistry.addToolMaterial(5, "Bone", 1, 1, 200, 400, 1, 1.0F, 0, 0f, "\u00A7e", ""); - TConstructRegistry.addToolMaterial(6, "Obsidian", 1, 3, 89, 700, 2, 0.8F, 3, 0f, "\u00A7d", ""); - TConstructRegistry.addToolMaterial(7, "Netherrack", 1, 2, 131, 400, 1, 1.2F, 0, 1f, "\u00A74", "Shoddy"); - TConstructRegistry.addToolMaterial(8, "Slime", 1, 3, 1500, 150, 0, 5.0F, 0, 0f, "\u00A7a", ""); - TConstructRegistry.addToolMaterial(9, "Paper", 1, 0, 30, 200, 0, 0.3F, 0, 0f, "\u00A7f", "Writable"); - TConstructRegistry.addToolMaterial(10, "Cobalt", 2, 4, 800, 800, 3, 1.75F, 2, 0f, "\u00A73", ""); - TConstructRegistry.addToolMaterial(11, "Ardite", 2, 4, 600, 800, 3, 2.0F, 0, 0f, "\u00A74", ""); - TConstructRegistry.addToolMaterial(12, "Manyullyn", 2, 5, 1200, 1000, 4, 2.5F, 0, 0f, "\u00A75", "Awareness"); - TConstructRegistry.addToolMaterial(13, "Copper", 1, 1, 180, 500, 2, 1.15F, 0, 0f, "\u00A7c", ""); - TConstructRegistry.addToolMaterial(14, "Bronze", 1, 2, 350, 700, 2, 1.3F, 1, 0f, "\u00A76", ""); - TConstructRegistry.addToolMaterial(15, "Alumite", 2, 4, 550, 800, 3, 1.3F, 2, 0f, "\u00A7d", ""); - TConstructRegistry.addToolMaterial(16, "Steel", 2, 3, 750, 800, 3, 1.3F, 2, 0f); - TConstructRegistry.addToolMaterial(17, "BlueSlime", 1, 1, 500, 150, 0, 5.0F, 0, 0f, "\u00A7b", ""); + //Golems + /*golemCore = new GolemCoreBlock(PHConstruct.golemCore).setUnlocalizedName("golemcore"); + GameRegistry.registerBlock(golemCore, "Golem Core"); + GameRegistry.registerTileEntity(GolemCoreLogic.class, "TConstruct.GolemCore"); + + golemHead = new GolemHeadBlock(PHConstruct.golemHead).setUnlocalizedName("golemhead"); + GameRegistry.registerBlock(golemHead, "Golem Head"); + + golemPedestal = new GolemPedestalBlock(PHConstruct.golemPedestal).setUnlocalizedName("golempedestal"); + GameRegistry.registerBlock(golemPedestal, "Golem Pedestal"); + GameRegistry.registerTileEntity(GolemPedestalLogic.class, "TConstruct.GolemPedestal");*/ + } - //Thaumcraft - TConstructRegistry.addToolMaterial(21, "Thaumium", 2, 2, 250, 600, 2, 1.3F, 1, 0f); - - /*//Metallurgy - TConstructRegistry.addToolMaterial(22, "Heptazion", 2, 2, 300, 800, 1, 1.0F, 0, 0f); - TConstructRegistry.addToolMaterial(23, "Damascus Steel", 2, 3, 500, 600, 2, 1.35F, 1, 0f); - TConstructRegistry.addToolMaterial(24, "Angmallen", 2, 2, 300, 800, 2, 0.8F, 0, 0f); + void registerItems () + { + titleIcon = new TitleIcon(PHConstruct.uselessItem).setUnlocalizedName("tconstruct.titleicon"); + String[] blanks = new String[] { "blank_pattern", "blank_cast" }; + blankPattern = new CraftingItem(PHConstruct.blankPattern, blanks, blanks, "materials/").setUnlocalizedName("tconstruct.Pattern"); - TConstructRegistry.addToolMaterial(25, "Promethium", 1, 1, 200, 400, 1, 1.0F, 0, 0.5f); - TConstructRegistry.addToolMaterial(26, "Deep Iron", 1, 2, 250, 600, 2, 1.3F, 1, 0f); - TConstructRegistry.addToolMaterial(27, "Oureclase", 2, 3, 750, 800, 2, 1.2F, 0, 0f); - TConstructRegistry.addToolMaterial(28, "Aredrite", 2, 3, 1000, 400, 2, 1.5F, 0, 1.0f); - TConstructRegistry.addToolMaterial(29, "Astral Silver", 1, 4, 35, 1200, 1, 0.5F, 0, 0f); - TConstructRegistry.addToolMaterial(30, "Carmot", 1, 4, 50, 1200, 1, 0.5F, 0, 0f); - TConstructRegistry.addToolMaterial(31, "Mithril", 2, 4, 1000, 900, 3, 1.25F, 3, 0f); - TConstructRegistry.addToolMaterial(32, "Orichalcum", 2, 5, 1350, 900, 3, 1.25F, 0, 0f); - TConstructRegistry.addToolMaterial(33, "Adamantine", 3, 6, 1550, 1000, 4, 1.5F, 1, 0f); - TConstructRegistry.addToolMaterial(34, "Atlarus", 3, 6, 1750, 1000, 4, 1.6F, 2, 0f); + String[] craftingMaterials = new String[] { "PaperStack", "SlimeCrystal", "SearedBrick", "CobaltIngot", "ArditeIngot", "ManyullynIngot", "Mossball", "LavaCrystal", "NecroticBone", + "CopperIngot", "TinIngot", "AluminumIngot", "RawAluminum", "BronzeIngot", "AlBrassIngot", "AlumiteIngot", "SteelIngot", "BlueSlimeCrystal", "ObsidianIngot" }; + String[] craftingTextures = new String[] { "material_paperstack", "material_slimecrystal", "material_searedbrick", "material_cobaltingot", "material_arditeingot", "material_manyullyningot", + "material_mossball", "material_lavacrystal", "material_necroticbone", "material_copperingot", "material_tiningot", "material_aluminumingot", "material_aluminumraw", + "material_bronzeingot", "material_alubrassingot", "material_alumiteingot", "material_steelingot", "material_blueslimecrystal", "material_obsidianingot" }; - TConstructRegistry.addToolMaterial(35, "Black Steel", 2, 2, 500, 800, 2, 1.3F, 2, 0f); - TConstructRegistry.addToolMaterial(36, "Quicksilver", 2, 4, 1100, 1400, 3, 1.0F, 1, 0f); - TConstructRegistry.addToolMaterial(37, "Haderoth", 2, 4, 1250, 1200, 3, 1.0F, 2, 0f); - TConstructRegistry.addToolMaterial(38, "Celenegil", 3, 5, 1600, 1400, 3, 1.0F, 2, 0f); - TConstructRegistry.addToolMaterial(39, "Tartarite", 3, 7, 3000, 1400, 5, 1.6667F, 4, 0f);*/ + materials = new CraftingItem(PHConstruct.materials, craftingMaterials, craftingTextures, "materials/").setUnlocalizedName("tconstruct.Materials"); + toolRod = new ToolPart(PHConstruct.toolRod, "ToolRod", "_rod").setUnlocalizedName("tconstruct.ToolRod"); + TConstructRegistry.toolRod = toolRod; + toolShard = new ToolShard(PHConstruct.toolShard, "ToolShard", "_chunk").setUnlocalizedName("tconstruct.ToolShard"); + woodPattern = new Pattern(PHConstruct.woodPattern, "WoodPattern", "pattern_", "materials/").setUnlocalizedName("tconstruct.Pattern"); + metalPattern = new MetalPattern(PHConstruct.metalPattern, "MetalPattern", "cast_", "materials/").setUnlocalizedName("tconstruct.MetalPattern"); + //netherPattern = new Pattern(PHTools.netherPattern, 128, patternTexture).setUnlocalizedName("tconstruct.Pattern"); - PatternBuilder pb = PatternBuilder.instance; - if (PHConstruct.enableTWood) - pb.registerFullMaterial(Block.planks, 2, "Wood", new ItemStack(Item.stick, 2), new ItemStack(Item.stick), 0); - else - pb.registerMaterialSet("Wood", new ItemStack(Item.stick, 2), new ItemStack(Item.stick), 0); - if (PHConstruct.enableTStone) - { - pb.registerFullMaterial(Block.stone, 2, "Stone", new ItemStack(TContent.toolShard, 1, 1), new ItemStack(TContent.toolRod, 1, 1), 1); - pb.registerMaterial(Block.cobblestone, 2, "Stone"); - } - //else - //pb.registerMaterialSet("Stone", new ItemStack(TContent.toolShard, 1, 1), new ItemStack(TContent.toolRod, 1, 1), 1); - pb.registerFullMaterial(Item.ingotIron, 2, "Iron", new ItemStack(TContent.toolShard, 1, 2), new ItemStack(TContent.toolRod, 1, 2), 2); - pb.registerFullMaterial(Item.flint, 2, "Flint", new ItemStack(TContent.toolShard, 1, 3), new ItemStack(TContent.toolRod, 1, 3), 3); - if (PHConstruct.enableTCactus) - pb.registerFullMaterial(Block.cactus, 2, "Cactus", new ItemStack(TContent.toolShard, 1, 4), new ItemStack(TContent.toolRod, 1, 4), 4); - else - pb.registerMaterialSet("Cactus", new ItemStack(TContent.toolShard, 1, 4), new ItemStack(TContent.toolRod, 1, 4), 4); - if (PHConstruct.enableTBone) - pb.registerFullMaterial(Item.bone, 2, "Bone", new ItemStack(Item.dyePowder, 1, 15), new ItemStack(Item.bone), 5); - else - pb.registerMaterialSet("Bone", new ItemStack(Item.dyePowder, 1, 15), new ItemStack(Item.bone), 5); - pb.registerFullMaterial(Block.obsidian, 2, "Obsidian", new ItemStack(TContent.toolShard, 1, 6), new ItemStack(TContent.toolRod, 1, 6), 6); - pb.registerFullMaterial(Block.netherrack, 2, "Netherrack", new ItemStack(TContent.toolShard, 1, 7), new ItemStack(TContent.toolRod, 1, 7), 7); - pb.registerFullMaterial(new ItemStack(materials, 1, 1), 2, "Slime", new ItemStack(toolShard, 1, 8), new ItemStack(toolRod, 1, 8), 8); - pb.registerFullMaterial(new ItemStack(materials, 1, 0), 2, "Paper", new ItemStack(Item.paper, 2), new ItemStack(toolRod, 1, 9), 9); - pb.registerMaterialSet("Cobalt", new ItemStack(toolShard, 1, 10), new ItemStack(toolRod, 1, 10), 10); - pb.registerMaterialSet("Ardite", new ItemStack(toolShard, 1, 11), new ItemStack(toolRod, 1, 11), 11); - pb.registerMaterialSet("Manyullyn", new ItemStack(toolShard, 1, 12), new ItemStack(toolRod, 1, 12), 12); - pb.registerMaterialSet("Copper", new ItemStack(toolShard, 1, 13), new ItemStack(toolRod, 1, 13), 13); - pb.registerMaterialSet("Bronze", new ItemStack(toolShard, 1, 14), new ItemStack(toolRod, 1, 14), 14); - pb.registerMaterialSet("Alumite", new ItemStack(toolShard, 1, 15), new ItemStack(toolRod, 1, 15), 15); - pb.registerMaterialSet("Steel", new ItemStack(toolShard, 1, 16), new ItemStack(toolRod, 1, 16), 16); + manualBook = new PatternManual(PHConstruct.manual); + buckets = new FilledBucket(PHConstruct.buckets); + + pickaxe = new Pickaxe(PHConstruct.pickaxe); + shovel = new Shovel(PHConstruct.shovel); + axe = new Axe(PHConstruct.axe); + broadsword = new Broadsword(PHConstruct.broadsword); + longsword = new Longsword(PHConstruct.longsword); + rapier = new Rapier(PHConstruct.rapier); + + frypan = new FryingPan(PHConstruct.frypan); + battlesign = new BattleSign(PHConstruct.battlesign); + //longbow = new RangedWeapon(PHConstruct.longbow); + mattock = new Mattock(PHConstruct.mattock); + //lumberaxe = new LumberAxe(PHConstruct.lumberaxe, lumberaxeTexture); + potionLauncher = new PotionLauncher(PHConstruct.potionLauncher).setUnlocalizedName("tconstruct.PotionLauncher"); + + pickaxeHead = new ToolPart(PHConstruct.pickaxeHead, "PickaxeHead", "_pickaxe_head").setUnlocalizedName("tconstruct.PickaxeHead"); + shovelHead = new ToolPart(PHConstruct.shovelHead, "ShovelHead", "_shovel_head").setUnlocalizedName("tconstruct.ShovelHead"); + axeHead = new ToolPart(PHConstruct.axeHead, "AxeHead", "_axe_head").setUnlocalizedName("tconstruct.AxeHead"); + swordBlade = new ToolPart(PHConstruct.swordBlade, "SwordBlade", "_sword_blade").setUnlocalizedName("tconstruct.SwordBlade"); + largeGuard = new ToolPart(PHConstruct.largeGuard, "LargeGuard", "_large_guard").setUnlocalizedName("tconstruct.LargeGuard"); + medGuard = new ToolPart(PHConstruct.medGuard, "MediumGuard", "_medium_guard").setUnlocalizedName("tconstruct.MediumGuard"); + crossbar = new ToolPart(PHConstruct.crossbar, "Crossbar", "_crossbar").setUnlocalizedName("tconstruct.Crossbar"); + binding = new ToolPart(PHConstruct.binding, "Binding", "_binding").setUnlocalizedName("tconstruct.Binding"); + + frypanHead = new ToolPart(PHConstruct.frypanHead, "FrypanHead", "_frypan_head").setUnlocalizedName("tconstruct.FrypanHead"); + signHead = new ToolPart(PHConstruct.signHead, "SignHead", "_battlesign_head").setUnlocalizedName("tconstruct.SignHead"); + + strangeFood = new StrangeFood(PHConstruct.slimefood).setUnlocalizedName("tconstruct.strangefood"); + //lumberHead = new ToolPart(PHConstruct.lumberHead, 0, broadheads).setUnlocalizedName("tconstruct.LumberHead"); + Item.doorWood.setMaxStackSize(16); + Item.doorSteel.setMaxStackSize(16); + Item.snowball.setMaxStackSize(64); + Item.boat.setMaxStackSize(16); + Item.minecartEmpty.setMaxStackSize(3); + Item.minecartCrate.setMaxStackSize(3); + Item.minecartPowered.setMaxStackSize(3); + Block.torchWood.setTickRandomly(false); + } + + void registerMaterials () + { + TConstructRegistry.addToolMaterial(0, "Wood", 1, 0, 59, 200, 0, 1.0F, 0, 0f, "\u00A7e", ""); + TConstructRegistry.addToolMaterial(1, "Stone", 1, 1, 131, 400, 1, 0.5F, 0, 1f, "", "Shoddy"); + TConstructRegistry.addToolMaterial(2, "Iron", 1, 2, 250, 600, 2, 1.3F, 1, 0f, "\u00A7f", ""); + TConstructRegistry.addToolMaterial(3, "Flint", 1, 1, 171, 525, 2, 0.7F, 0, 1f, "\u00A78", "Shoddy"); + TConstructRegistry.addToolMaterial(4, "Cactus", 1, 1, 150, 500, 2, 1.0F, 0, -1f, "\u00A72", "Spiny"); + TConstructRegistry.addToolMaterial(5, "Bone", 1, 1, 200, 400, 1, 1.0F, 0, 0f, "\u00A7e", ""); + TConstructRegistry.addToolMaterial(6, "Obsidian", 1, 3, 89, 700, 2, 0.8F, 3, 0f, "\u00A7d", ""); + TConstructRegistry.addToolMaterial(7, "Netherrack", 1, 2, 131, 400, 1, 1.2F, 0, 1f, "\u00A74", "Shoddy"); + TConstructRegistry.addToolMaterial(8, "Slime", 1, 3, 1500, 150, 0, 5.0F, 0, 0f, "\u00A7a", ""); + TConstructRegistry.addToolMaterial(9, "Paper", 1, 0, 30, 200, 0, 0.3F, 0, 0f, "\u00A7f", "Writable"); + TConstructRegistry.addToolMaterial(10, "Cobalt", 2, 4, 800, 800, 3, 1.75F, 2, 0f, "\u00A73", ""); + TConstructRegistry.addToolMaterial(11, "Ardite", 2, 4, 600, 800, 3, 2.0F, 0, 0f, "\u00A74", ""); + TConstructRegistry.addToolMaterial(12, "Manyullyn", 2, 5, 1200, 1000, 4, 2.5F, 0, 0f, "\u00A75", "Awareness"); + TConstructRegistry.addToolMaterial(13, "Copper", 1, 1, 180, 500, 2, 1.15F, 0, 0f, "\u00A7c", ""); + TConstructRegistry.addToolMaterial(14, "Bronze", 1, 2, 350, 700, 2, 1.3F, 1, 0f, "\u00A76", ""); + TConstructRegistry.addToolMaterial(15, "Alumite", 2, 4, 550, 800, 3, 1.3F, 2, 0f, "\u00A7d", ""); + TConstructRegistry.addToolMaterial(16, "Steel", 2, 3, 750, 800, 3, 1.3F, 2, 0f); + TConstructRegistry.addToolMaterial(17, "BlueSlime", 1, 1, 500, 150, 0, 1.5F, 0, 0f, "\u00A7b", ""); + + //Thaumcraft + TConstructRegistry.addToolMaterial(21, "Thaumium", 2, 2, 250, 600, 2, 1.3F, 1, 0f); + + /*//Metallurgy + TConstructRegistry.addToolMaterial(22, "Heptazion", 2, 2, 300, 800, 1, 1.0F, 0, 0f); + TConstructRegistry.addToolMaterial(23, "Damascus Steel", 2, 3, 500, 600, 2, 1.35F, 1, 0f); + TConstructRegistry.addToolMaterial(24, "Angmallen", 2, 2, 300, 800, 2, 0.8F, 0, 0f); + + TConstructRegistry.addToolMaterial(25, "Promethium", 1, 1, 200, 400, 1, 1.0F, 0, 0.5f); + TConstructRegistry.addToolMaterial(26, "Deep Iron", 1, 2, 250, 600, 2, 1.3F, 1, 0f); + TConstructRegistry.addToolMaterial(27, "Oureclase", 2, 3, 750, 800, 2, 1.2F, 0, 0f); + TConstructRegistry.addToolMaterial(28, "Aredrite", 2, 3, 1000, 400, 2, 1.5F, 0, 1.0f); + TConstructRegistry.addToolMaterial(29, "Astral Silver", 1, 4, 35, 1200, 1, 0.5F, 0, 0f); + TConstructRegistry.addToolMaterial(30, "Carmot", 1, 4, 50, 1200, 1, 0.5F, 0, 0f); + TConstructRegistry.addToolMaterial(31, "Mithril", 2, 4, 1000, 900, 3, 1.25F, 3, 0f); + TConstructRegistry.addToolMaterial(32, "Orichalcum", 2, 5, 1350, 900, 3, 1.25F, 0, 0f); + TConstructRegistry.addToolMaterial(33, "Adamantine", 3, 6, 1550, 1000, 4, 1.5F, 1, 0f); + TConstructRegistry.addToolMaterial(34, "Atlarus", 3, 6, 1750, 1000, 4, 1.6F, 2, 0f); + + TConstructRegistry.addToolMaterial(35, "Black Steel", 2, 2, 500, 800, 2, 1.3F, 2, 0f); + TConstructRegistry.addToolMaterial(36, "Quicksilver", 2, 4, 1100, 1400, 3, 1.0F, 1, 0f); + TConstructRegistry.addToolMaterial(37, "Haderoth", 2, 4, 1250, 1200, 3, 1.0F, 2, 0f); + TConstructRegistry.addToolMaterial(38, "Celenegil", 3, 5, 1600, 1400, 3, 1.0F, 2, 0f); + TConstructRegistry.addToolMaterial(39, "Tartarite", 3, 7, 3000, 1400, 5, 1.6667F, 4, 0f);*/ + + PatternBuilder pb = PatternBuilder.instance; + if (PHConstruct.enableTWood) + pb.registerFullMaterial(Block.planks, 2, "Wood", new ItemStack(Item.stick, 2), new ItemStack(Item.stick), 0); + else + pb.registerMaterialSet("Wood", new ItemStack(Item.stick, 2), new ItemStack(Item.stick), 0); + if (PHConstruct.enableTStone) + { + pb.registerFullMaterial(Block.stone, 2, "Stone", new ItemStack(TContent.toolShard, 1, 1), new ItemStack(TContent.toolRod, 1, 1), 1); + pb.registerMaterial(Block.cobblestone, 2, "Stone"); + } + //else + //pb.registerMaterialSet("Stone", new ItemStack(TContent.toolShard, 1, 1), new ItemStack(TContent.toolRod, 1, 1), 1); + pb.registerFullMaterial(Item.ingotIron, 2, "Iron", new ItemStack(TContent.toolShard, 1, 2), new ItemStack(TContent.toolRod, 1, 2), 2); + pb.registerFullMaterial(Item.flint, 2, "Flint", new ItemStack(TContent.toolShard, 1, 3), new ItemStack(TContent.toolRod, 1, 3), 3); + if (PHConstruct.enableTCactus) + pb.registerFullMaterial(Block.cactus, 2, "Cactus", new ItemStack(TContent.toolShard, 1, 4), new ItemStack(TContent.toolRod, 1, 4), 4); + else + pb.registerMaterialSet("Cactus", new ItemStack(TContent.toolShard, 1, 4), new ItemStack(TContent.toolRod, 1, 4), 4); + if (PHConstruct.enableTBone) + pb.registerFullMaterial(Item.bone, 2, "Bone", new ItemStack(Item.dyePowder, 1, 15), new ItemStack(Item.bone), 5); + else + pb.registerMaterialSet("Bone", new ItemStack(Item.dyePowder, 1, 15), new ItemStack(Item.bone), 5); + pb.registerFullMaterial(Block.obsidian, 2, "Obsidian", new ItemStack(TContent.toolShard, 1, 6), new ItemStack(TContent.toolRod, 1, 6), 6); + pb.registerMaterial(new ItemStack(materials, 1, 18), 2, "Obsidian"); + pb.registerFullMaterial(Block.netherrack, 2, "Netherrack", new ItemStack(TContent.toolShard, 1, 7), new ItemStack(TContent.toolRod, 1, 7), 7); + pb.registerFullMaterial(new ItemStack(materials, 1, 1), 2, "Slime", new ItemStack(toolShard, 1, 8), new ItemStack(toolRod, 1, 8), 8); + pb.registerFullMaterial(new ItemStack(materials, 1, 0), 2, "Paper", new ItemStack(Item.paper, 2), new ItemStack(toolRod, 1, 9), 9); + pb.registerMaterialSet("Cobalt", new ItemStack(toolShard, 1, 10), new ItemStack(toolRod, 1, 10), 10); + pb.registerMaterialSet("Ardite", new ItemStack(toolShard, 1, 11), new ItemStack(toolRod, 1, 11), 11); + pb.registerMaterialSet("Manyullyn", new ItemStack(toolShard, 1, 12), new ItemStack(toolRod, 1, 12), 12); + pb.registerMaterialSet("Copper", new ItemStack(toolShard, 1, 13), new ItemStack(toolRod, 1, 13), 13); + pb.registerMaterialSet("Bronze", new ItemStack(toolShard, 1, 14), new ItemStack(toolRod, 1, 14), 14); + pb.registerMaterialSet("Alumite", new ItemStack(toolShard, 1, 15), new ItemStack(toolRod, 1, 15), 15); + pb.registerMaterialSet("Steel", new ItemStack(toolShard, 1, 16), new ItemStack(toolRod, 1, 16), 16); pb.registerFullMaterial(new ItemStack(materials, 1, 17), 2, "BlueSlime", new ItemStack(toolShard, 1, 17), new ItemStack(toolRod, 1, 17), 17); - pb.addToolPattern((IPattern) woodPattern); - } + pb.addToolPattern((IPattern) woodPattern); + } - public static Item[] patternOutputs; - public static LiquidStack[] liquids; + public static Item[] patternOutputs; + public static LiquidStack[] liquids; - void addToolRecipes () - { - List removeTools = new ArrayList(); - if (PHConstruct.disableWoodTools) - { - removeTools.add(new ItemStack(Item.pickaxeWood)); - removeTools.add(new ItemStack(Item.axeWood)); - removeTools.add(new ItemStack(Item.shovelWood)); - removeTools.add(new ItemStack(Item.swordWood)); - removeTools.add(new ItemStack(Item.hoeWood)); - } - if (PHConstruct.disableStoneTools) - { - removeTools.add(new ItemStack(Item.pickaxeStone)); - removeTools.add(new ItemStack(Item.axeStone)); - removeTools.add(new ItemStack(Item.shovelStone)); - removeTools.add(new ItemStack(Item.swordStone)); - removeTools.add(new ItemStack(Item.hoeStone)); - } - if (PHConstruct.disableIronTools) - { - removeTools.add(new ItemStack(Item.pickaxeSteel)); - removeTools.add(new ItemStack(Item.axeSteel)); - removeTools.add(new ItemStack(Item.shovelSteel)); - removeTools.add(new ItemStack(Item.swordSteel)); - removeTools.add(new ItemStack(Item.hoeSteel)); - } - if (PHConstruct.disableDiamondTools) - { - removeTools.add(new ItemStack(Item.pickaxeDiamond)); - removeTools.add(new ItemStack(Item.axeDiamond)); - removeTools.add(new ItemStack(Item.shovelDiamond)); - removeTools.add(new ItemStack(Item.swordDiamond)); - removeTools.add(new ItemStack(Item.hoeDiamond)); - } - if (PHConstruct.disableGoldTools) - { - removeTools.add(new ItemStack(Item.pickaxeGold)); - removeTools.add(new ItemStack(Item.axeGold)); - removeTools.add(new ItemStack(Item.shovelGold)); - removeTools.add(new ItemStack(Item.swordGold)); - removeTools.add(new ItemStack(Item.hoeGold)); - } + void addToolRecipes () + { + List removeTools = new ArrayList(); + if (PHConstruct.disableWoodTools) + { + removeTools.add(new ItemStack(Item.pickaxeWood)); + removeTools.add(new ItemStack(Item.axeWood)); + removeTools.add(new ItemStack(Item.shovelWood)); + removeTools.add(new ItemStack(Item.swordWood)); + removeTools.add(new ItemStack(Item.hoeWood)); + } + if (PHConstruct.disableStoneTools) + { + removeTools.add(new ItemStack(Item.pickaxeStone)); + removeTools.add(new ItemStack(Item.axeStone)); + removeTools.add(new ItemStack(Item.shovelStone)); + removeTools.add(new ItemStack(Item.swordStone)); + removeTools.add(new ItemStack(Item.hoeStone)); + } + if (PHConstruct.disableIronTools) + { + removeTools.add(new ItemStack(Item.pickaxeSteel)); + removeTools.add(new ItemStack(Item.axeSteel)); + removeTools.add(new ItemStack(Item.shovelSteel)); + removeTools.add(new ItemStack(Item.swordSteel)); + removeTools.add(new ItemStack(Item.hoeSteel)); + } + if (PHConstruct.disableDiamondTools) + { + removeTools.add(new ItemStack(Item.pickaxeDiamond)); + removeTools.add(new ItemStack(Item.axeDiamond)); + removeTools.add(new ItemStack(Item.shovelDiamond)); + removeTools.add(new ItemStack(Item.swordDiamond)); + removeTools.add(new ItemStack(Item.hoeDiamond)); + } + if (PHConstruct.disableGoldTools) + { + removeTools.add(new ItemStack(Item.pickaxeGold)); + removeTools.add(new ItemStack(Item.axeGold)); + removeTools.add(new ItemStack(Item.shovelGold)); + removeTools.add(new ItemStack(Item.swordGold)); + removeTools.add(new ItemStack(Item.hoeGold)); + } - RecipeRemover.removeShapedRecipes(removeTools); + RecipeRemover.removeShapedRecipes(removeTools); - patternOutputs = new Item[] { toolRod, pickaxeHead, shovelHead, axeHead, swordBlade, largeGuard, medGuard, crossbar, binding, frypanHead, signHead }; + patternOutputs = new Item[] { toolRod, pickaxeHead, shovelHead, axeHead, swordBlade, largeGuard, medGuard, crossbar, binding, frypanHead, signHead }; - ToolBuilder tb = ToolBuilder.instance; - tb.addToolRecipe(pickaxe, pickaxeHead, binding); - tb.addToolRecipe(broadsword, swordBlade, largeGuard); - tb.addToolRecipe(axe, axeHead); - tb.addToolRecipe(shovel, shovelHead); - tb.addToolRecipe(longsword, swordBlade, medGuard); - tb.addToolRecipe(rapier, swordBlade, crossbar); - tb.addToolRecipe(frypan, frypanHead); - tb.addToolRecipe(battlesign, signHead); - tb.addToolRecipe(mattock, axeHead, shovelHead); - //tb.addToolRecipe(longbow, toolRod, toolRod); - //tb.addToolRecipe(lumberaxe, lumberHead); + ToolBuilder tb = ToolBuilder.instance; + tb.addToolRecipe(pickaxe, pickaxeHead, binding); + tb.addToolRecipe(broadsword, swordBlade, largeGuard); + tb.addToolRecipe(axe, axeHead); + tb.addToolRecipe(shovel, shovelHead); + tb.addToolRecipe(longsword, swordBlade, medGuard); + tb.addToolRecipe(rapier, swordBlade, crossbar); + tb.addToolRecipe(frypan, frypanHead); + tb.addToolRecipe(battlesign, signHead); + tb.addToolRecipe(mattock, axeHead, shovelHead); + //tb.addToolRecipe(longbow, toolRod, toolRod); + //tb.addToolRecipe(lumberaxe, lumberHead); - tb.registerToolMod(new ModRepair()); - tb.registerToolMod(new ModDurability(new ItemStack[] { new ItemStack(Item.diamond) }, 0, 500, 0f, 3, "Diamond", "\u00a7bDurability +500", "\u00a7b")); - tb.registerToolMod(new ModDurability(new ItemStack[] { new ItemStack(Item.emerald) }, 1, 0, 0.5f, 2, "Emerald", "\u00a72Durability +50%", "\u00a72")); - modE = new ModElectric(); - tb.registerToolMod(modE); - tb.registerToolMod(new ModRedstone(new ItemStack[] { new ItemStack(Item.redstone) }, 2, 1)); - tb.registerToolMod(new ModRedstone(new ItemStack[] { new ItemStack(Item.redstone), new ItemStack(Item.redstone) }, 2, 2)); - tb.registerToolMod(new ModRedstone(new ItemStack[] { new ItemStack(Block.blockRedstone) }, 2, 9)); - tb.registerToolMod(new ModRedstone(new ItemStack[] { new ItemStack(Block.blockRedstone), new ItemStack(Item.redstone) }, 2, 10)); - tb.registerToolMod(new ModRedstone(new ItemStack[] { new ItemStack(Block.blockRedstone), new ItemStack(Block.blockRedstone) }, 2, 18)); - tb.registerToolMod(new ModLapis(new ItemStack[] { new ItemStack(Item.dyePowder, 1, 4) }, 10, 1)); - tb.registerToolMod(new ModLapis(new ItemStack[] { new ItemStack(Item.dyePowder, 1, 4), new ItemStack(Item.dyePowder, 1, 4) }, 10, 2)); - tb.registerToolMod(new ModLapis(new ItemStack[] { new ItemStack(Block.blockLapis) }, 10, 9)); - tb.registerToolMod(new ModLapis(new ItemStack[] { new ItemStack(Item.dyePowder, 1, 4), new ItemStack(Block.blockLapis) }, 10, 10)); - tb.registerToolMod(new ModLapis(new ItemStack[] { new ItemStack(Block.blockLapis), new ItemStack(Block.blockLapis) }, 10, 18)); - tb.registerToolMod(new ModInteger(new ItemStack[] { new ItemStack(materials, 1, 6) }, 4, "Moss", 3, "\u00a72", "Auto-Repair")); - tb.registerToolMod(new ModBlaze(new ItemStack[] { new ItemStack(Item.blazePowder) }, 7, 1)); - tb.registerToolMod(new ModBlaze(new ItemStack[] { new ItemStack(Item.blazePowder), new ItemStack(Item.blazePowder) }, 7, 2)); - tb.registerToolMod(new ModBoolean(new ItemStack[] { new ItemStack(materials, 1, 7) }, 6, "Lava", "\u00a74", "Auto-Smelt")); - tb.registerToolMod(new ModInteger(new ItemStack[] { new ItemStack(materials, 1, 8) }, 8, "Necrotic", 1, "\u00a78", "Life Steal")); + tb.registerToolMod(new ModRepair()); + tb.registerToolMod(new ModDurability(new ItemStack[] { new ItemStack(Item.diamond) }, 0, 500, 0f, 3, "Diamond", "\u00a7bDurability +500", "\u00a7b")); + tb.registerToolMod(new ModDurability(new ItemStack[] { new ItemStack(Item.emerald) }, 1, 0, 0.5f, 2, "Emerald", "\u00a72Durability +50%", "\u00a72")); + + modE = new ModElectric(); + tb.registerToolMod(modE); + + ItemStack redstoneItem = new ItemStack(Item.redstone); + ItemStack redstoneBlock = new ItemStack(Block.blockRedstone); + tb.registerToolMod(new ModRedstone(new ItemStack[] { redstoneItem }, 2, 1)); + tb.registerToolMod(new ModRedstone(new ItemStack[] { redstoneItem, redstoneItem }, 2, 2)); + tb.registerToolMod(new ModRedstone(new ItemStack[] { redstoneBlock }, 2, 9)); + tb.registerToolMod(new ModRedstone(new ItemStack[] { redstoneItem, redstoneBlock }, 2, 10)); + tb.registerToolMod(new ModRedstone(new ItemStack[] { redstoneBlock, redstoneBlock }, 2, 18)); + + ItemStack lapisItem = new ItemStack(Item.dyePowder, 1, 4); + ItemStack lapisBlock = new ItemStack(Block.blockLapis); + tb.registerToolMod(new ModLapis(new ItemStack[] { lapisItem }, 10, 1)); + tb.registerToolMod(new ModLapis(new ItemStack[] { lapisItem, lapisItem }, 10, 2)); + tb.registerToolMod(new ModLapis(new ItemStack[] { lapisBlock }, 10, 9)); + tb.registerToolMod(new ModLapis(new ItemStack[] { lapisItem, lapisBlock }, 10, 10)); + tb.registerToolMod(new ModLapis(new ItemStack[] { lapisBlock, lapisBlock }, 10, 18)); + + tb.registerToolMod(new ModInteger(new ItemStack[] { new ItemStack(materials, 1, 6) }, 4, "Moss", 3, "\u00a72", "Auto-Repair")); + ItemStack blazePowder = new ItemStack(Item.blazePowder); + tb.registerToolMod(new ModBlaze(new ItemStack[] { blazePowder }, 7, 1)); + tb.registerToolMod(new ModBlaze(new ItemStack[] { blazePowder, blazePowder }, 7, 2)); + tb.registerToolMod(new ModBoolean(new ItemStack[] { new ItemStack(materials, 1, 7) }, 6, "Lava", "\u00a74", "Auto-Smelt")); + tb.registerToolMod(new ModInteger(new ItemStack[] { new ItemStack(materials, 1, 8) }, 8, "Necrotic", 1, "\u00a78", "Life Steal")); + + ItemStack quartzItem = new ItemStack(Item.field_94583_ca); + ItemStack quartzBlock = new ItemStack(Block.blockNetherQuartz, 1, Short.MAX_VALUE); + tb.registerToolMod(new ModAttack("Quartz", new ItemStack[] { quartzItem }, 11, 1)); + tb.registerToolMod(new ModAttack("Quartz", new ItemStack[] { quartzItem, quartzItem }, 11, 2)); + tb.registerToolMod(new ModAttack("Quartz", new ItemStack[] { quartzBlock }, 11, 4)); + tb.registerToolMod(new ModAttack("Quartz", new ItemStack[] { quartzItem, quartzBlock }, 11, 5)); + tb.registerToolMod(new ModAttack("Quartz", new ItemStack[] { quartzBlock, quartzBlock }, 11, 8)); - ItemStack ingotcast = new ItemStack(metalPattern, 1, 0); + ItemStack ingotcast = new ItemStack(metalPattern, 1, 0); - LiquidCasting lc = LiquidCasting.instance; - //Blank - lc.addCastingRecipe(new ItemStack(blankPattern, 1, 1), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 8), 80); + LiquidCasting lc = LiquidCasting.instance; + //Blank + lc.addCastingRecipe(new ItemStack(blankPattern, 1, 1), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 8), 80); - //Ingots - lc.addCastingRecipe(new ItemStack(Item.ingotIron), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 0), ingotcast, 80); //Iron - lc.addCastingRecipe(new ItemStack(Item.ingotGold), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 1), ingotcast, 80); //gold - lc.addCastingRecipe(new ItemStack(materials, 1, 9), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 2), ingotcast, 80); //copper - lc.addCastingRecipe(new ItemStack(materials, 1, 10), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 3), ingotcast, 80); //tin - lc.addCastingRecipe(new ItemStack(materials, 1, 11), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 4), ingotcast, 80); //aluminum - lc.addCastingRecipe(new ItemStack(materials, 1, 3), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 5), ingotcast, 80); //cobalt - lc.addCastingRecipe(new ItemStack(materials, 1, 4), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 6), ingotcast, 80); //ardite - lc.addCastingRecipe(new ItemStack(materials, 1, 13), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 7), ingotcast, 80); //bronze - lc.addCastingRecipe(new ItemStack(materials, 1, 14), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 8), ingotcast, 80); //albrass - lc.addCastingRecipe(new ItemStack(materials, 1, 5), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 9), ingotcast, 80); //manyullyn - lc.addCastingRecipe(new ItemStack(materials, 1, 15), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 10), ingotcast, 80); //alumite - // obsidian - lc.addCastingRecipe(new ItemStack(materials, 1, 16), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 12), ingotcast, 80); //steel - - //Buckets - ItemStack bucket = new ItemStack(Item.bucketEmpty); - lc.addCastingRecipe(new ItemStack(buckets, 1, 0), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue*9, 0), bucket, 10); //Iron - lc.addCastingRecipe(new ItemStack(buckets, 1, 1), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue*9, 1), bucket, 10); //gold - lc.addCastingRecipe(new ItemStack(buckets, 1, 2), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue*9, 2), bucket, 10); //copper - lc.addCastingRecipe(new ItemStack(buckets, 1, 3), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue*9, 3), bucket, 10); //tin - lc.addCastingRecipe(new ItemStack(buckets, 1, 4), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue*9, 4), bucket, 10); //aluminum - lc.addCastingRecipe(new ItemStack(buckets, 1, 5), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue*9, 5), bucket, 10); //cobalt - lc.addCastingRecipe(new ItemStack(buckets, 1, 6), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue*9, 6), bucket, 10); //ardite - lc.addCastingRecipe(new ItemStack(buckets, 1, 7), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue*9, 7), bucket, 10); //bronze - lc.addCastingRecipe(new ItemStack(buckets, 1, 8), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue*9, 8), bucket, 10); //albrass - lc.addCastingRecipe(new ItemStack(buckets, 1, 9), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue*9, 9), bucket, 10); //manyullyn - lc.addCastingRecipe(new ItemStack(buckets, 1, 10), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue*9, 10), bucket, 10); //alumite - lc.addCastingRecipe(new ItemStack(buckets, 1, 11), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue*9, 11), bucket, 10);// obsidian - lc.addCastingRecipe(new ItemStack(buckets, 1, 12), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue*9, 12), bucket, 10); //steel + //Ingots + lc.addCastingRecipe(new ItemStack(Item.ingotIron), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 0), ingotcast, 80); //Iron + lc.addCastingRecipe(new ItemStack(Item.ingotGold), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 1), ingotcast, 80); //gold + lc.addCastingRecipe(new ItemStack(materials, 1, 9), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 2), ingotcast, 80); //copper + lc.addCastingRecipe(new ItemStack(materials, 1, 10), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 3), ingotcast, 80); //tin + lc.addCastingRecipe(new ItemStack(materials, 1, 11), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 4), ingotcast, 80); //aluminum + lc.addCastingRecipe(new ItemStack(materials, 1, 3), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 5), ingotcast, 80); //cobalt + lc.addCastingRecipe(new ItemStack(materials, 1, 4), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 6), ingotcast, 80); //ardite + lc.addCastingRecipe(new ItemStack(materials, 1, 13), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 7), ingotcast, 80); //bronze + lc.addCastingRecipe(new ItemStack(materials, 1, 14), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 8), ingotcast, 80); //albrass + lc.addCastingRecipe(new ItemStack(materials, 1, 5), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 9), ingotcast, 80); //manyullyn + lc.addCastingRecipe(new ItemStack(materials, 1, 15), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 10), ingotcast, 80); //alumite + lc.addCastingRecipe(new ItemStack(materials, 1, 18), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 11), ingotcast, 80); //obsidian + lc.addCastingRecipe(new ItemStack(materials, 1, 16), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 12), ingotcast, 80); //steel - liquids = new LiquidStack[] { new LiquidStack(liquidMetalStill.blockID, 1, 0), new LiquidStack(liquidMetalStill.blockID, 1, 2), new LiquidStack(liquidMetalStill.blockID, 1, 5), - new LiquidStack(liquidMetalStill.blockID, 1, 6), new LiquidStack(liquidMetalStill.blockID, 1, 9), new LiquidStack(liquidMetalStill.blockID, 1, 7), - new LiquidStack(liquidMetalStill.blockID, 1, 10), new LiquidStack(liquidMetalStill.blockID, 1, 12) }; - int[] liquidDamage = new int[] { 2, 13, 10, 11, 12, 14, 15, 16 }; + //Buckets + ItemStack bucket = new ItemStack(Item.bucketEmpty); + lc.addCastingRecipe(new ItemStack(buckets, 1, 0), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 9, 0), bucket, 10); //Iron + lc.addCastingRecipe(new ItemStack(buckets, 1, 1), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 9, 1), bucket, 10); //gold + lc.addCastingRecipe(new ItemStack(buckets, 1, 2), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 9, 2), bucket, 10); //copper + lc.addCastingRecipe(new ItemStack(buckets, 1, 3), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 9, 3), bucket, 10); //tin + lc.addCastingRecipe(new ItemStack(buckets, 1, 4), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 9, 4), bucket, 10); //aluminum + lc.addCastingRecipe(new ItemStack(buckets, 1, 5), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 9, 5), bucket, 10); //cobalt + lc.addCastingRecipe(new ItemStack(buckets, 1, 6), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 9, 6), bucket, 10); //ardite + lc.addCastingRecipe(new ItemStack(buckets, 1, 7), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 9, 7), bucket, 10); //bronze + lc.addCastingRecipe(new ItemStack(buckets, 1, 8), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 9, 8), bucket, 10); //albrass + lc.addCastingRecipe(new ItemStack(buckets, 1, 9), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 9, 9), bucket, 10); //manyullyn + lc.addCastingRecipe(new ItemStack(buckets, 1, 10), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 9, 10), bucket, 10); //alumite + lc.addCastingRecipe(new ItemStack(buckets, 1, 11), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 9, 11), bucket, 10);// obsidian + lc.addCastingRecipe(new ItemStack(buckets, 1, 12), new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 9, 12), bucket, 10); //steel - for (int iter = 0; iter < patternOutputs.length; iter++) - { - ItemStack cast = new ItemStack(metalPattern, 1, iter + 1); - for (int iterTwo = 0; iterTwo < liquids.length; iterTwo++) - { - lc.addCastingRecipe(new ItemStack(patternOutputs[iter], 1, liquidDamage[iterTwo]), liquids[iterTwo], cast, 50); - } - } - } + liquids = new LiquidStack[] { new LiquidStack(liquidMetalStill.blockID, 1, 0), new LiquidStack(liquidMetalStill.blockID, 1, 2), new LiquidStack(liquidMetalStill.blockID, 1, 5), + new LiquidStack(liquidMetalStill.blockID, 1, 6), new LiquidStack(liquidMetalStill.blockID, 1, 9), new LiquidStack(liquidMetalStill.blockID, 1, 7), + new LiquidStack(liquidMetalStill.blockID, 1, 10), new LiquidStack(liquidMetalStill.blockID, 1, 11), new LiquidStack(liquidMetalStill.blockID, 1, 12) }; + int[] liquidDamage = new int[] { 2, 13, 10, 11, 12, 14, 15, 6, 16 }; - WeakReference tool = new WeakReference(null); - void addSmelteryRecipes () - { - //Ore - Smeltery.addMelting(Block.oreIron, 0, 600, new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 2, 0)); - Smeltery.addMelting(Block.oreGold, 0, 550, new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 2, 1)); + for (int iter = 0; iter < patternOutputs.length; iter++) + { + ItemStack cast = new ItemStack(metalPattern, 1, iter + 1); + for (int iterTwo = 0; iterTwo < liquids.length; iterTwo++) + { + lc.addCastingRecipe(new ItemStack(patternOutputs[iter], 1, liquidDamage[iterTwo]), liquids[iterTwo], cast, 50); + } + } + } - //Items - Smeltery.addMelting(new ItemStack(Item.ingotIron, 4), Block.blockSteel.blockID, 0, 500, new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 0)); - Smeltery.addMelting(new ItemStack(Item.ingotGold, 4), Block.blockGold.blockID, 0, 450, new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 1)); - Smeltery.addMelting(new ItemStack(Item.goldNugget, 4), Block.blockGold.blockID, 0, 150, new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue / 9, 1)); + WeakReference tool = new WeakReference(null); - //Blocks - Smeltery.addMelting(Block.blockSteel, 0, 600, new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 9, 0)); - Smeltery.addMelting(Block.blockGold, 0, 550, new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 9, 1)); - Smeltery.addMelting(Block.obsidian, 0, 800, new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 2, 11)); + void addSmelteryRecipes () + { + //Ore + Smeltery.addMelting(Block.oreIron, 0, 600, new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 2, 0)); + Smeltery.addMelting(Block.oreGold, 0, 550, new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 2, 1)); - //Alloys - Smeltery.addAlloyMixing(new LiquidStack(liquidMetalStill.blockID, 2, 7), new LiquidStack(liquidMetalStill.blockID, 3, 2), new LiquidStack(liquidMetalStill.blockID, 1, 3)); //Bronze - Smeltery.addAlloyMixing(new LiquidStack(liquidMetalStill.blockID, 2, 8), new LiquidStack(liquidMetalStill.blockID, 3, 4), new LiquidStack(liquidMetalStill.blockID, 1, 2)); //Aluminum Brass - Smeltery.addAlloyMixing(new LiquidStack(liquidMetalStill.blockID, 2, 9), new LiquidStack(liquidMetalStill.blockID, 1, 5), new LiquidStack(liquidMetalStill.blockID, 1, 6)); //Manyullyn - Smeltery.addAlloyMixing(new LiquidStack(liquidMetalStill.blockID, 3, 10), new LiquidStack(liquidMetalStill.blockID, 5, 4), new LiquidStack(liquidMetalStill.blockID, 2, 0), new LiquidStack( - liquidMetalStill.blockID, 2, 11)); //Alumite - } + //Items + Smeltery.addMelting(new ItemStack(Item.ingotIron, 4), Block.blockSteel.blockID, 0, 500, new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 0)); + Smeltery.addMelting(new ItemStack(Item.ingotGold, 4), Block.blockGold.blockID, 0, 450, new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue, 1)); + Smeltery.addMelting(new ItemStack(Item.goldNugget, 4), Block.blockGold.blockID, 0, 150, new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue / 9, 1)); - void addCraftingRecipes () - { - GameRegistry.addRecipe(new ItemStack(woodCrafter, 1, 0), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', Block.workbench); - GameRegistry.addRecipe(new ItemStack(woodCrafter, 1, 1), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', new ItemStack(Block.wood, 1, 0)); - GameRegistry.addRecipe(new ItemStack(woodCrafter, 1, 2), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', new ItemStack(Block.wood, 1, 1)); - GameRegistry.addRecipe(new ItemStack(woodCrafter, 1, 3), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', new ItemStack(Block.wood, 1, 2)); - GameRegistry.addRecipe(new ItemStack(woodCrafter, 1, 4), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', new ItemStack(Block.wood, 1, 3)); - GameRegistry.addRecipe(new ItemStack(woodCrafter, 1, 5), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', Block.chest); - GameRegistry.addRecipe(new ItemStack(woodCrafter, 1, 10), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', new ItemStack(Block.planks, 1, 0)); - GameRegistry.addRecipe(new ItemStack(woodCrafter, 1, 11), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', new ItemStack(Block.planks, 1, 1)); - GameRegistry.addRecipe(new ItemStack(woodCrafter, 1, 12), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', new ItemStack(Block.planks, 1, 2)); - GameRegistry.addRecipe(new ItemStack(woodCrafter, 1, 13), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', new ItemStack(Block.planks, 1, 3)); - GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(woodCrafter, 1, 1), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', "logWood")); - GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(woodCrafter, 1, 10), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', "plankWood")); + //Blocks + Smeltery.addMelting(Block.blockSteel, 0, 600, new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 9, 0)); + Smeltery.addMelting(Block.blockGold, 0, 550, new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 9, 1)); + Smeltery.addMelting(Block.obsidian, 0, 800, new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 2, 11)); - GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(blankPattern, 1, 0), "ps", "sp", 'p', "plankWood", 's', Item.stick)); - GameRegistry.addRecipe(new ItemStack(manualBook), "wp", 'w', new ItemStack(blankPattern, 1, 0), 'p', Item.paper); + //Alloys + Smeltery.addAlloyMixing(new LiquidStack(liquidMetalStill.blockID, 2, 7), new LiquidStack(liquidMetalStill.blockID, 3, 2), new LiquidStack(liquidMetalStill.blockID, 1, 3)); //Bronze + Smeltery.addAlloyMixing(new LiquidStack(liquidMetalStill.blockID, 2, 8), new LiquidStack(liquidMetalStill.blockID, 3, 4), new LiquidStack(liquidMetalStill.blockID, 1, 2)); //Aluminum Brass + Smeltery.addAlloyMixing(new LiquidStack(liquidMetalStill.blockID, 2, 9), new LiquidStack(liquidMetalStill.blockID, 1, 5), new LiquidStack(liquidMetalStill.blockID, 1, 6)); //Manyullyn + Smeltery.addAlloyMixing(new LiquidStack(liquidMetalStill.blockID, 3, 10), new LiquidStack(liquidMetalStill.blockID, 5, 4), new LiquidStack(liquidMetalStill.blockID, 2, 0), new LiquidStack( + liquidMetalStill.blockID, 2, 11)); //Alumite + } - GameRegistry.addRecipe(new ItemStack(materials, 1, 0), "pp", "pp", 'p', Item.paper); //Paper stack - GameRegistry.addRecipe(new ItemStack(materials, 1, 6), "ppp", "ppp", "ppp", 'p', Block.cobblestoneMossy); //Moss ball - GameRegistry.addRecipe(new ItemStack(materials, 1, 7), "xcx", "cbc", "xcx", 'b', Item.bucketLava, 'c', Item.coal, 'x', Block.netherrack); //Auto-smelt - //GameRegistry.addShapelessRecipe(new ItemStack(materials, 1, 8), Item.bone, Item.rottenFlesh, Item.chickenRaw, Item.beefRaw, Item.porkRaw, Item.fishRaw); //Necrotic bone - GameRegistry.addShapelessRecipe(new ItemStack(craftedSoil, 1, 0), Item.slimeBall, Item.slimeBall, Item.slimeBall, Item.slimeBall, Block.sand, Block.dirt); //Slimy sand + void addCraftingRecipes () + { + GameRegistry.addRecipe(new ItemStack(toolStationWood, 1, 0), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', Block.workbench); + GameRegistry.addRecipe(new ItemStack(toolStationWood, 1, 1), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', new ItemStack(Block.wood, 1, 0)); + GameRegistry.addRecipe(new ItemStack(toolStationWood, 1, 2), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', new ItemStack(Block.wood, 1, 1)); + GameRegistry.addRecipe(new ItemStack(toolStationWood, 1, 3), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', new ItemStack(Block.wood, 1, 2)); + GameRegistry.addRecipe(new ItemStack(toolStationWood, 1, 4), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', new ItemStack(Block.wood, 1, 3)); + GameRegistry.addRecipe(new ItemStack(toolStationWood, 1, 5), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', Block.chest); + GameRegistry.addRecipe(new ItemStack(toolStationWood, 1, 10), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', new ItemStack(Block.planks, 1, 0)); + GameRegistry.addRecipe(new ItemStack(toolStationWood, 1, 11), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', new ItemStack(Block.planks, 1, 1)); + GameRegistry.addRecipe(new ItemStack(toolStationWood, 1, 12), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', new ItemStack(Block.planks, 1, 2)); + GameRegistry.addRecipe(new ItemStack(toolStationWood, 1, 13), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', new ItemStack(Block.planks, 1, 3)); + GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(toolStationWood, 1, 1), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', "logWood")); + GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(toolStationWood, 1, 10), "p", "w", 'p', new ItemStack(blankPattern, 1, 0), 'w', "plankWood")); + + GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(blankPattern, 1, 0), "ps", "sp", 'p', "plankWood", 's', Item.stick)); + GameRegistry.addRecipe(new ItemStack(manualBook), "wp", 'w', new ItemStack(blankPattern, 1, 0), 'p', Item.paper); + + GameRegistry.addRecipe(new ItemStack(materials, 1, 0), "pp", "pp", 'p', Item.paper); //Paper stack + GameRegistry.addRecipe(new ItemStack(materials, 1, 6), "ppp", "ppp", "ppp", 'p', Block.cobblestoneMossy); //Moss ball + GameRegistry.addRecipe(new ItemStack(materials, 1, 7), "xcx", "cbc", "xcx", 'b', Item.bucketLava, 'c', Item.coal, 'x', Block.netherrack); //Auto-smelt + //GameRegistry.addShapelessRecipe(new ItemStack(materials, 1, 8), Item.bone, Item.rottenFlesh, Item.chickenRaw, Item.beefRaw, Item.porkRaw, Item.fishRaw); //Necrotic bone + GameRegistry.addShapelessRecipe(new ItemStack(craftedSoil, 1, 0), Item.slimeBall, Item.slimeBall, Item.slimeBall, Item.slimeBall, Block.sand, Block.dirt); //Slimy sand GameRegistry.addShapelessRecipe(new ItemStack(craftedSoil, 1, 2), strangeFood, strangeFood, strangeFood, strangeFood, Block.sand, Block.dirt); //Slimy sand - GameRegistry.addShapelessRecipe(new ItemStack(craftedSoil, 1, 1), Item.clay, Block.sand, Block.gravel); //Grout, Add stone dust? + GameRegistry.addShapelessRecipe(new ItemStack(craftedSoil, 2, 1), Item.clay, Block.sand, Block.gravel); //Grout + GameRegistry.addShapelessRecipe(new ItemStack(craftedSoil, 8, 1), Block.blockClay, Block.sand, Block.gravel, Block.sand, Block.gravel, Block.sand, Block.gravel, Block.sand, Block.gravel); //Grout - FurnaceRecipes.smelting().addSmelting(craftedSoil.blockID, 0, new ItemStack(materials, 1, 1), 2f); //Slime - FurnaceRecipes.smelting().addSmelting(craftedSoil.blockID, 1, new ItemStack(materials, 1, 2), 2f); //Seared brick item + FurnaceRecipes.smelting().addSmelting(craftedSoil.blockID, 0, new ItemStack(materials, 1, 1), 2f); //Slime + FurnaceRecipes.smelting().addSmelting(craftedSoil.blockID, 1, new ItemStack(materials, 1, 2), 2f); //Seared brick item FurnaceRecipes.smelting().addSmelting(craftedSoil.blockID, 2, new ItemStack(materials, 1, 17), 2f); //Blue Slime - //GameRegistry.addRecipe(new ItemStack(oreSlag, 1, 0), "pp", "pp", 'p', new ItemStack(materials, 1, 2)); //Seared brick block + //GameRegistry.addRecipe(new ItemStack(oreSlag, 1, 0), "pp", "pp", 'p', new ItemStack(materials, 1, 2)); //Seared brick block - FurnaceRecipes.smelting().addSmelting(oreSlag.blockID, 1, new ItemStack(materials, 1, 3), 3f); - FurnaceRecipes.smelting().addSmelting(oreSlag.blockID, 2, new ItemStack(materials, 1, 4), 3f); - FurnaceRecipes.smelting().addSmelting(oreSlag.blockID, 3, new ItemStack(materials, 1, 9), 0.5f); - FurnaceRecipes.smelting().addSmelting(oreSlag.blockID, 4, new ItemStack(materials, 1, 10), 0.5f); - FurnaceRecipes.smelting().addSmelting(oreSlag.blockID, 5, new ItemStack(materials, 1, 12), 0.5f); + FurnaceRecipes.smelting().addSmelting(oreSlag.blockID, 1, new ItemStack(materials, 1, 3), 3f); + FurnaceRecipes.smelting().addSmelting(oreSlag.blockID, 2, new ItemStack(materials, 1, 4), 3f); + FurnaceRecipes.smelting().addSmelting(oreSlag.blockID, 3, new ItemStack(materials, 1, 9), 0.5f); + FurnaceRecipes.smelting().addSmelting(oreSlag.blockID, 4, new ItemStack(materials, 1, 10), 0.5f); + FurnaceRecipes.smelting().addSmelting(oreSlag.blockID, 5, new ItemStack(materials, 1, 12), 0.5f); - //Smeltery - ItemStack searedBrick = new ItemStack(materials, 1, 2); - GameRegistry.addRecipe(new ItemStack(smeltery, 1, 0), "bbb", "b b", "bbb", 'b', searedBrick); - GameRegistry.addRecipe(new ItemStack(smeltery, 1, 1), "b b", "b b", "bbb", 'b', searedBrick); - GameRegistry.addRecipe(new ItemStack(smeltery, 1, 2), "bb", "bb", 'b', searedBrick); + //Smeltery + ItemStack searedBrick = new ItemStack(materials, 1, 2); + GameRegistry.addRecipe(new ItemStack(smeltery, 1, 0), "bbb", "b b", "bbb", 'b', searedBrick); //Controller + GameRegistry.addRecipe(new ItemStack(smeltery, 1, 1), "b b", "b b", "bbb", 'b', searedBrick); //Drain + GameRegistry.addRecipe(new ItemStack(smeltery, 1, 2), "bb", "bb", 'b', searedBrick); //Bricks - GameRegistry.addRecipe(new ItemStack(lavaTank, 1, 0), "bbb", "bgb", "bbb", 'b', searedBrick, 'g', Block.glass); - GameRegistry.addRecipe(new ItemStack(lavaTank, 1, 1), "bgb", "ggg", "bgb", 'b', searedBrick, 'g', Block.glass); - GameRegistry.addRecipe(new ItemStack(lavaTank, 1, 2), "bgb", "bgb", "bgb", 'b', searedBrick, 'g', Block.glass); + GameRegistry.addRecipe(new ItemStack(lavaTank, 1, 0), "bbb", "bgb", "bbb", 'b', searedBrick, 'g', Block.glass); //Tank + GameRegistry.addRecipe(new ItemStack(lavaTank, 1, 1), "bgb", "ggg", "bgb", 'b', searedBrick, 'g', Block.glass); //Glass + GameRegistry.addRecipe(new ItemStack(lavaTank, 1, 2), "bgb", "bgb", "bgb", 'b', searedBrick, 'g', Block.glass); //Window - GameRegistry.addRecipe(new ItemStack(searedBlock, 1, 0), "bbb", "b b", "b b", 'b', searedBrick); - GameRegistry.addRecipe(new ItemStack(searedBlock, 1, 1), "b b", " b ", 'b', searedBrick); - } + GameRegistry.addRecipe(new ItemStack(searedBlock, 1, 0), "bbb", "b b", "b b", 'b', searedBrick); //Table + GameRegistry.addRecipe(new ItemStack(searedBlock, 1, 1), "b b", " b ", 'b', searedBrick); //Faucet + } - void setupToolTabs () - { - TConstructRegistry.materialTab.init(new ItemStack(titleIcon)); - TConstructRegistry.blockTab.init(new ItemStack(woodCrafter)); - ItemStack tool = new ItemStack(longsword, 1, 0); + void setupToolTabs () + { + TConstructRegistry.materialTab.init(new ItemStack(titleIcon)); + TConstructRegistry.blockTab.init(new ItemStack(toolStationWood)); + ItemStack tool = new ItemStack(longsword, 1, 0); - NBTTagCompound compound = new NBTTagCompound(); - compound.setCompoundTag("InfiTool", new NBTTagCompound()); - compound.getCompoundTag("InfiTool").setInteger("RenderHead", 2); - compound.getCompoundTag("InfiTool").setInteger("RenderHandle", 0); - compound.getCompoundTag("InfiTool").setInteger("RenderAccessory", 10); - tool.setTagCompound(compound); + NBTTagCompound compound = new NBTTagCompound(); + compound.setCompoundTag("InfiTool", new NBTTagCompound()); + compound.getCompoundTag("InfiTool").setInteger("RenderHead", 2); + compound.getCompoundTag("InfiTool").setInteger("RenderHandle", 0); + compound.getCompoundTag("InfiTool").setInteger("RenderAccessory", 10); + tool.setTagCompound(compound); - //TConstruct. - TConstructRegistry.toolTab.init(tool); - } + //TConstruct. + TConstructRegistry.toolTab.init(tool); + } - public void oreRegistry () - { - OreDictionary.registerOre("oreCobalt", new ItemStack(oreSlag, 1, 1)); - OreDictionary.registerOre("oreArdite", new ItemStack(oreSlag, 1, 2)); - OreDictionary.registerOre("oreCopper", new ItemStack(oreSlag, 1, 3)); - OreDictionary.registerOre("oreTin", new ItemStack(oreSlag, 1, 4)); - OreDictionary.registerOre("oreNaturalAluminum", new ItemStack(oreSlag, 1, 5)); + public void oreRegistry () + { + OreDictionary.registerOre("oreCobalt", new ItemStack(oreSlag, 1, 1)); + OreDictionary.registerOre("oreArdite", new ItemStack(oreSlag, 1, 2)); + OreDictionary.registerOre("oreCopper", new ItemStack(oreSlag, 1, 3)); + OreDictionary.registerOre("oreTin", new ItemStack(oreSlag, 1, 4)); + OreDictionary.registerOre("oreNaturalAluminum", new ItemStack(oreSlag, 1, 5)); - OreDictionary.registerOre("ingotCobalt", new ItemStack(materials, 1, 3)); - OreDictionary.registerOre("ingotArdite", new ItemStack(materials, 1, 4)); - OreDictionary.registerOre("ingotManyullyn", new ItemStack(materials, 1, 5)); - OreDictionary.registerOre("ingotCopper", new ItemStack(materials, 1, 9)); - OreDictionary.registerOre("ingotTin", new ItemStack(materials, 1, 10)); - OreDictionary.registerOre("ingotNaturalAluminum", new ItemStack(materials, 1, 11)); - OreDictionary.registerOre("naturalAluminum", new ItemStack(materials, 1, 12)); - OreDictionary.registerOre("ingotBronze", new ItemStack(materials, 1, 13)); - OreDictionary.registerOre("ingotAluminumBrass", new ItemStack(materials, 1, 14)); - OreDictionary.registerOre("ingotAlumite", new ItemStack(materials, 1, 15)); - OreDictionary.registerOre("ingotSteel", new ItemStack(materials, 1, 16)); + OreDictionary.registerOre("ingotCobalt", new ItemStack(materials, 1, 3)); + OreDictionary.registerOre("ingotArdite", new ItemStack(materials, 1, 4)); + OreDictionary.registerOre("ingotManyullyn", new ItemStack(materials, 1, 5)); + OreDictionary.registerOre("ingotCopper", new ItemStack(materials, 1, 9)); + OreDictionary.registerOre("ingotTin", new ItemStack(materials, 1, 10)); + OreDictionary.registerOre("ingotNaturalAluminum", new ItemStack(materials, 1, 11)); + OreDictionary.registerOre("naturalAluminum", new ItemStack(materials, 1, 12)); + OreDictionary.registerOre("ingotBronze", new ItemStack(materials, 1, 13)); + OreDictionary.registerOre("ingotAluminumBrass", new ItemStack(materials, 1, 14)); + OreDictionary.registerOre("ingotAlumite", new ItemStack(materials, 1, 15)); + OreDictionary.registerOre("ingotSteel", new ItemStack(materials, 1, 16)); - OreDictionary.registerOre("blockCobalt", new ItemStack(metalBlock, 1, 0)); - OreDictionary.registerOre("blockArdite", new ItemStack(metalBlock, 1, 1)); - OreDictionary.registerOre("blockManyullyn", new ItemStack(metalBlock, 1, 2)); - OreDictionary.registerOre("blockCopper", new ItemStack(metalBlock, 1, 3)); - OreDictionary.registerOre("blockBronze", new ItemStack(metalBlock, 1, 4)); - OreDictionary.registerOre("blockTin", new ItemStack(metalBlock, 1, 5)); - OreDictionary.registerOre("blockNaturalAluminum", new ItemStack(metalBlock, 1, 6)); - OreDictionary.registerOre("blockAluminumBrass", new ItemStack(metalBlock, 1, 7)); - OreDictionary.registerOre("blockAlumite", new ItemStack(metalBlock, 1, 8)); - OreDictionary.registerOre("blockSteel", new ItemStack(metalBlock, 1, 9)); + OreDictionary.registerOre("blockCobalt", new ItemStack(metalBlock, 1, 0)); + OreDictionary.registerOre("blockArdite", new ItemStack(metalBlock, 1, 1)); + OreDictionary.registerOre("blockManyullyn", new ItemStack(metalBlock, 1, 2)); + OreDictionary.registerOre("blockCopper", new ItemStack(metalBlock, 1, 3)); + OreDictionary.registerOre("blockBronze", new ItemStack(metalBlock, 1, 4)); + OreDictionary.registerOre("blockTin", new ItemStack(metalBlock, 1, 5)); + OreDictionary.registerOre("blockNaturalAluminum", new ItemStack(metalBlock, 1, 6)); + OreDictionary.registerOre("blockAluminumBrass", new ItemStack(metalBlock, 1, 7)); + OreDictionary.registerOre("blockAlumite", new ItemStack(metalBlock, 1, 8)); + OreDictionary.registerOre("blockSteel", new ItemStack(metalBlock, 1, 9)); - String[] liquidNames = new String[] { "Iron", "Gold", "Copper", "Tin", "Aluminum", "Cobalt", "Ardite", "Bronze", "Brass", "Manyullyn", "Alumite", "Obsidian", "Steel" }; - for (int iter = 0; iter < liquidNames.length; iter++) - { - LiquidStack liquidstack = new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue*9, iter); - LiquidDictionary.getOrCreateLiquid("Molten " + liquidNames[iter], liquidstack); - LiquidContainerRegistry.registerLiquid(new LiquidContainerData(liquidstack, new ItemStack(buckets, 1, iter), new ItemStack(Item.bucketEmpty))); - } - } + String[] liquidNames = new String[] { "Iron", "Gold", "Copper", "Tin", "Aluminum", "Cobalt", "Ardite", "Bronze", "Brass", "Manyullyn", "Alumite", "Obsidian", "Steel" }; + for (int iter = 0; iter < liquidNames.length; iter++) + { + LiquidStack liquidstack = new LiquidStack(liquidMetalStill.blockID, TConstruct.ingotLiquidValue * 9, iter); + LiquidDictionary.getOrCreateLiquid("Molten " + liquidNames[iter], liquidstack); + LiquidContainerRegistry.registerLiquid(new LiquidContainerData(liquidstack, new ItemStack(buckets, 1, iter), new ItemStack(Item.bucketEmpty))); + } + } - public void modIntegration () - { - /* IC2 */ - ItemStack reBattery = ic2.api.Items.getItem("reBattery"); - if (reBattery != null) - modE.batteries.add(reBattery); - ItemStack chargedReBattery = ic2.api.Items.getItem("chargedReBattery"); - if (chargedReBattery != null) - modE.batteries.add(new ItemStack(chargedReBattery.getItem(), 1, -1)); - ItemStack electronicCircuit = ic2.api.Items.getItem("electronicCircuit"); - if (electronicCircuit != null) - modE.circuits.add(electronicCircuit); + public void modIntegration () + { + /* IC2 */ + ItemStack reBattery = ic2.api.Items.getItem("reBattery"); + if (reBattery != null) + modE.batteries.add(reBattery); + ItemStack chargedReBattery = ic2.api.Items.getItem("chargedReBattery"); + if (chargedReBattery != null) + { + //modE.batteries.add(new ItemStack(chargedReBattery.getItem(), 1, Short.MAX_VALUE)); + modE.batteries.add(chargedReBattery); + } + ItemStack electronicCircuit = ic2.api.Items.getItem("electronicCircuit"); + if (electronicCircuit != null) + modE.circuits.add(electronicCircuit); - /* Thaumcraft */ - //Object obj = getItem("itemResource", "thaumcraft.common.Config"); - } + /* Thaumcraft */ + //Object obj = getItem("itemResource", "thaumcraft.common.Config"); + } - public static Object getItem (String name, String classPackage) - { - try - { - Class c = Class.forName(classPackage); - Object ret = c.getField(name); - if (ret != null && (ret instanceof ItemStack || ret instanceof Item)) - return ret; - return null; - } - catch (Exception e) - { - System.out.println("[TConstruct] Could not find item for " + name); - return null; - } - } + public static Object getItem (String name, String classPackage) + { + try + { + Class c = Class.forName(classPackage); + Object ret = c.getField(name); + if (ret != null && (ret instanceof ItemStack || ret instanceof Item)) + return ret; + return null; + } + catch (Exception e) + { + System.out.println("[TConstruct] Could not find item for " + name); + return null; + } + } - /*public static String blockTexture = "/tinkertextures/ConstructBlocks.png"; - public static String blankSprite = "/tinkertextures/blanksprite.png"; - public static String liquidTexture = "/tinkertextures/LiquidWhite.png"; + /*public static String blockTexture = "/tinkertextures/ConstructBlocks.png"; + public static String blankSprite = "/tinkertextures/blanksprite.png"; + public static String liquidTexture = "/tinkertextures/LiquidWhite.png"; - public static String craftingTexture = "/tinkertextures/materials.png"; - public static String patternTexture = "/tinkertextures/patterns.png"; - public static String baseHeads = "/tinkertextures/tools/baseheads.png"; - public static String baseAccessories = "/tinkertextures/tools/baseaccessories.png"; - public static String swordparts = "/tinkertextures/tools/swordparts.png"; - public static String jokeparts = "/tinkertextures/tools/jokeparts.png"; - public static String broadheads = "/tinkertextures/tools/broadheads.png"; + public static String craftingTexture = "/tinkertextures/materials.png"; + public static String patternTexture = "/tinkertextures/patterns.png"; + public static String baseHeads = "/tinkertextures/tools/baseheads.png"; + public static String baseAccessories = "/tinkertextures/tools/baseaccessories.png"; + public static String swordparts = "/tinkertextures/tools/swordparts.png"; + public static String jokeparts = "/tinkertextures/tools/jokeparts.png"; + public static String broadheads = "/tinkertextures/tools/broadheads.png"; - public static String pickaxeTexture = "/tinkertextures/tools/pickaxe/"; - public static String broadswordTexture = "/tinkertextures/tools/broadsword/"; - public static String shovelTexture = "/tinkertextures/tools/shovel/"; - public static String axeTexture = "/tinkertextures/tools/axe/"; - public static String longswordTexture = "/tinkertextures/tools/longsword/"; - public static String rapierTexture = "/tinkertextures/tools/rapier/"; - public static String frypanTexture = "/tinkertextures/tools/frypan/"; - public static String signTexture = "/tinkertextures/tools/battlesign/"; - public static String bowTexture = "/tinkertextures/tools/bow/"; - public static String mattockTexture = "/tinkertextures/tools/mattock/"; - public static String lumberaxeTexture = "/tinkertextures/tools/lumberaxe/";*/ + public static String pickaxeTexture = "/tinkertextures/tools/pickaxe/"; + public static String broadswordTexture = "/tinkertextures/tools/broadsword/"; + public static String shovelTexture = "/tinkertextures/tools/shovel/"; + public static String axeTexture = "/tinkertextures/tools/axe/"; + public static String longswordTexture = "/tinkertextures/tools/longsword/"; + public static String rapierTexture = "/tinkertextures/tools/rapier/"; + public static String frypanTexture = "/tinkertextures/tools/frypan/"; + public static String signTexture = "/tinkertextures/tools/battlesign/"; + public static String bowTexture = "/tinkertextures/tools/bow/"; + public static String mattockTexture = "/tinkertextures/tools/mattock/"; + public static String lumberaxeTexture = "/tinkertextures/tools/lumberaxe/";*/ - @Override - public int getBurnTime (ItemStack fuel) - { - if (fuel.itemID == materials.itemID && fuel.getItemDamage() == 7) - return 26400; - return 0; - } + @Override + public int getBurnTime (ItemStack fuel) + { + if (fuel.itemID == materials.itemID && fuel.getItemDamage() == 7) + return 26400; + return 0; + } } \ No newline at end of file diff --git a/mods/tinker/tconstruct/TCraftingHandler.java b/mods/tinker/tconstruct/TCraftingHandler.java index 37b68be..773ff78 100644 --- a/mods/tinker/tconstruct/TCraftingHandler.java +++ b/mods/tinker/tconstruct/TCraftingHandler.java @@ -10,21 +10,32 @@ import cpw.mods.fml.common.ICraftingHandler; public class TCraftingHandler implements ICraftingHandler { - @Override - public void onCrafting (EntityPlayer player, ItemStack item, IInventory craftMatrix) - { - if (item.getItem().itemID == TContent.smeltery.blockID) - { - NBTTagCompound tags = player.getEntityData().getCompoundTag("TConstruct"); - if (!tags.getBoolean("smelteryManual")) - { - tags.setBoolean("smelteryManual", true); - AbilityHelper.spawnItemAtPlayer(player, new ItemStack(TContent.manualBook, 1, 2)); - } - } - } + @Override + public void onCrafting (EntityPlayer player, ItemStack item, IInventory craftMatrix) + { + if (item.getItem().itemID == TContent.toolStationWood.blockID) + { + NBTTagCompound tags = player.getEntityData().getCompoundTag("TConstruct"); + if (!tags.getBoolean("materialManual")) + { + tags.setBoolean("materialManual", true); + AbilityHelper.spawnItemAtPlayer(player, new ItemStack(TContent.manualBook, 1, 1)); + } + } + if (item.getItem().itemID == TContent.smeltery.blockID) + { + NBTTagCompound tags = player.getEntityData().getCompoundTag("TConstruct"); + if (!tags.getBoolean("smelteryManual")) + { + tags.setBoolean("smelteryManual", true); + AbilityHelper.spawnItemAtPlayer(player, new ItemStack(TContent.manualBook, 1, 2)); + } + } + } - @Override - public void onSmelting (EntityPlayer player, ItemStack item) {} + @Override + public void onSmelting (EntityPlayer player, ItemStack item) + { + } } diff --git a/mods/tinker/tconstruct/blocks/EquipBlock.java b/mods/tinker/tconstruct/blocks/EquipBlock.java index 1e9aaef..83eccdb 100644 --- a/mods/tinker/tconstruct/blocks/EquipBlock.java +++ b/mods/tinker/tconstruct/blocks/EquipBlock.java @@ -40,11 +40,11 @@ public class EquipBlock extends InventoryBlock return Block.blockSteel.getBlockTextureFromSideAndMetadata(side, meta); } - /*@SideOnly(Side.CLIENT) + @SideOnly(Side.CLIENT) public void registerIcons (IconRegister par1IconRegister) { - this.blockIcon = par1iconRegister.registerIcon(Block.blockSteel.getUnlocalizedName()); - }*/ + //this.blockIcon = par1iconRegister.registerIcon(Block.blockSteel.getUnlocalizedName()); + } @Override public boolean renderAsNormalBlock () diff --git a/mods/tinker/tconstruct/blocks/SearedBlock.java b/mods/tinker/tconstruct/blocks/SearedBlock.java index 74b1b23..5a409b9 100644 --- a/mods/tinker/tconstruct/blocks/SearedBlock.java +++ b/mods/tinker/tconstruct/blocks/SearedBlock.java @@ -8,6 +8,7 @@ import mods.tinker.tconstruct.client.SearedRender; import mods.tinker.tconstruct.library.TConstructRegistry; import mods.tinker.tconstruct.logic.CastingTableLogic; import mods.tinker.tconstruct.logic.FaucetLogic; +import net.minecraft.block.Block; import net.minecraft.block.material.Material; import net.minecraft.creativetab.CreativeTabs; import net.minecraft.entity.item.EntityItem; @@ -282,4 +283,19 @@ public class SearedBlock extends InventoryBlock return super.getCollisionBoundingBoxFromPool(world, x, y, z); } + + /* Redstone */ + public boolean canConnectRedstone(IBlockAccess world, int x, int y, int z, int side) + { + return world.getBlockMetadata(x, y, z) == 1; + } + + public void onNeighborBlockChange(World world, int x, int y, int z, int neighborBlockID) + { + if (world.isBlockIndirectlyGettingPowered(x, y, z) && world.getBlockMetadata(x, y, z) == 1) + { + FaucetLogic logic = (FaucetLogic) world.getBlockTileEntity(x, y, z); + logic.setActive(true); + } + } } diff --git a/mods/tinker/tconstruct/blocks/StoneTorch.java b/mods/tinker/tconstruct/blocks/StoneTorch.java new file mode 100644 index 0000000..11984a4 --- /dev/null +++ b/mods/tinker/tconstruct/blocks/StoneTorch.java @@ -0,0 +1,287 @@ +package mods.tinker.tconstruct.blocks; + +import static net.minecraftforge.common.ForgeDirection.EAST; +import static net.minecraftforge.common.ForgeDirection.NORTH; +import static net.minecraftforge.common.ForgeDirection.SOUTH; +import static net.minecraftforge.common.ForgeDirection.WEST; + +import java.util.Random; + +import net.minecraft.block.Block; +import net.minecraft.block.material.Material; +import net.minecraft.client.renderer.texture.IconRegister; +import net.minecraft.creativetab.CreativeTabs; +import net.minecraft.util.AxisAlignedBB; +import net.minecraft.util.MovingObjectPosition; +import net.minecraft.util.Vec3; +import net.minecraft.world.World; +import cpw.mods.fml.relauncher.Side; +import cpw.mods.fml.relauncher.SideOnly; + +public class StoneTorch extends Block +{ + public StoneTorch(int id) + { + super(id, Material.circuits); + this.setCreativeTab(CreativeTabs.tabDecorations); + setLightValue(0.9375F); + } + + /** + * Returns a bounding box from the pool of bounding boxes (this means this box can change after the pool has been + * cleared to be reused) + */ + public AxisAlignedBB getCollisionBoundingBoxFromPool(World par1World, int par2, int par3, int par4) + { + return null; + } + + /** + * Is this block (a) opaque and (b) a full 1m cube? This determines whether or not to render the shared face of two + * adjacent blocks and also whether the player can attach torches, redstone wire, etc to this block. + */ + public boolean isOpaqueCube() + { + return false; + } + + /** + * If this block doesn't render as an ordinary block it will return False (examples: signs, buttons, stairs, etc) + */ + public boolean renderAsNormalBlock() + { + return false; + } + + /** + * The type of render function that is called for this block + */ + public int getRenderType() + { + return 2; + } + + /** + * Gets if we can place a torch on a block. + */ + private boolean canPlaceTorchOn(World par1World, int par2, int par3, int par4) + { + if (par1World.doesBlockHaveSolidTopSurface(par2, par3, par4)) + { + return true; + } + else + { + int l = par1World.getBlockId(par2, par3, par4); + return (Block.blocksList[l] != null && Block.blocksList[l].canPlaceTorchOnTop(par1World, par2, par3, par4)); + } + } + + /** + * Checks to see if its valid to put this block at the specified coordinates. Args: world, x, y, z + */ + public boolean canPlaceBlockAt(World par1World, int par2, int par3, int par4) + { + return par1World.isBlockSolidOnSide(par2 - 1, par3, par4, EAST, true) || + par1World.isBlockSolidOnSide(par2 + 1, par3, par4, WEST, true) || + par1World.isBlockSolidOnSide(par2, par3, par4 - 1, SOUTH, true) || + par1World.isBlockSolidOnSide(par2, par3, par4 + 1, NORTH, true) || + canPlaceTorchOn(par1World, par2, par3 - 1, par4); + } + + /** + * Called when a block is placed using its ItemBlock. Args: World, X, Y, Z, side, hitX, hitY, hitZ, block metadata + */ + public int onBlockPlaced(World par1World, int par2, int par3, int par4, int par5, float par6, float par7, float par8, int par9) + { + int j1 = par9; + + if (par5 == 1 && this.canPlaceTorchOn(par1World, par2, par3 - 1, par4)) + { + j1 = 5; + } + + if (par5 == 2 && par1World.isBlockSolidOnSide(par2, par3, par4 + 1, NORTH, true)) + { + j1 = 4; + } + + if (par5 == 3 && par1World.isBlockSolidOnSide(par2, par3, par4 - 1, SOUTH, true)) + { + j1 = 3; + } + + if (par5 == 4 && par1World.isBlockSolidOnSide(par2 + 1, par3, par4, WEST, true)) + { + j1 = 2; + } + + if (par5 == 5 && par1World.isBlockSolidOnSide(par2 - 1, par3, par4, EAST, true)) + { + j1 = 1; + } + + return j1; + } + + @SideOnly(Side.CLIENT) + public void registerIcons (IconRegister par1IconRegister) + { + this.blockIcon = par1IconRegister.registerIcon("tinker:torch_stone"); + } + + /** + * Lets the block know when one of its neighbor changes. Doesn't know which neighbor changed (coordinates passed are + * their own) Args: x, y, z, neighbor blockID + */ + public void onNeighborBlockChange(World par1World, int par2, int par3, int par4, int par5) + { + this.func_94397_d(par1World, par2, par3, par4, par5); + } + + protected boolean func_94397_d(World par1World, int par2, int par3, int par4, int par5) + { + if (this.dropTorchIfCantStay(par1World, par2, par3, par4)) + { + int i1 = par1World.getBlockMetadata(par2, par3, par4); + boolean flag = false; + + if (!par1World.isBlockSolidOnSide(par2 - 1, par3, par4, EAST, true) && i1 == 1) + { + flag = true; + } + + if (!par1World.isBlockSolidOnSide(par2 + 1, par3, par4, WEST, true) && i1 == 2) + { + flag = true; + } + + if (!par1World.isBlockSolidOnSide(par2, par3, par4 - 1, SOUTH, true) && i1 == 3) + { + flag = true; + } + + if (!par1World.isBlockSolidOnSide(par2, par3, par4 + 1, NORTH, true) && i1 == 4) + { + flag = true; + } + + if (!this.canPlaceTorchOn(par1World, par2, par3 - 1, par4) && i1 == 5) + { + flag = true; + } + + if (flag) + { + this.dropBlockAsItem(par1World, par2, par3, par4, par1World.getBlockMetadata(par2, par3, par4), 0); + par1World.setBlockToAir(par2, par3, par4); + return true; + } + else + { + return false; + } + } + else + { + return true; + } + } + + /** + * Tests if the block can remain at its current location and will drop as an item if it is unable to stay. Returns + * True if it can stay and False if it drops. Args: world, x, y, z + */ + protected boolean dropTorchIfCantStay(World par1World, int par2, int par3, int par4) + { + if (!this.canPlaceBlockAt(par1World, par2, par3, par4)) + { + if (par1World.getBlockId(par2, par3, par4) == this.blockID) + { + this.dropBlockAsItem(par1World, par2, par3, par4, par1World.getBlockMetadata(par2, par3, par4), 0); + par1World.setBlockToAir(par2, par3, par4); + } + + return false; + } + else + { + return true; + } + } + + /** + * Ray traces through the blocks collision from start vector to end vector returning a ray trace hit. Args: world, + * x, y, z, startVec, endVec + */ + public MovingObjectPosition collisionRayTrace(World par1World, int par2, int par3, int par4, Vec3 par5Vec3, Vec3 par6Vec3) + { + int l = par1World.getBlockMetadata(par2, par3, par4) & 7; + float f = 0.15F; + + if (l == 1) + { + this.setBlockBounds(0.0F, 0.2F, 0.5F - f, f * 2.0F, 0.8F, 0.5F + f); + } + else if (l == 2) + { + this.setBlockBounds(1.0F - f * 2.0F, 0.2F, 0.5F - f, 1.0F, 0.8F, 0.5F + f); + } + else if (l == 3) + { + this.setBlockBounds(0.5F - f, 0.2F, 0.0F, 0.5F + f, 0.8F, f * 2.0F); + } + else if (l == 4) + { + this.setBlockBounds(0.5F - f, 0.2F, 1.0F - f * 2.0F, 0.5F + f, 0.8F, 1.0F); + } + else + { + f = 0.1F; + this.setBlockBounds(0.5F - f, 0.0F, 0.5F - f, 0.5F + f, 0.6F, 0.5F + f); + } + + return super.collisionRayTrace(par1World, par2, par3, par4, par5Vec3, par6Vec3); + } + + @SideOnly(Side.CLIENT) + + /** + * A randomly called display update to be able to add particles or other items for display + */ + public void randomDisplayTick(World par1World, int par2, int par3, int par4, Random par5Random) + { + int meta = par1World.getBlockMetadata(par2, par3, par4); + double d0 = (double)((float)par2 + 0.5F); + double d1 = (double)((float)par3 + 0.7F); + double d2 = (double)((float)par4 + 0.5F); + double d3 = 0.2199999988079071D; + double d4 = 0.27000001072883606D; + + if (meta == 1) + { + par1World.spawnParticle("smoke", d0 - d4, d1 + d3, d2, 0.0D, 0.0D, 0.0D); + par1World.spawnParticle("flame", d0 - d4, d1 + d3, d2, 0.0D, 0.0D, 0.0D); + } + else if (meta == 2) + { + par1World.spawnParticle("smoke", d0 + d4, d1 + d3, d2, 0.0D, 0.0D, 0.0D); + par1World.spawnParticle("flame", d0 + d4, d1 + d3, d2, 0.0D, 0.0D, 0.0D); + } + else if (meta == 3) + { + par1World.spawnParticle("smoke", d0, d1 + d3, d2 - d4, 0.0D, 0.0D, 0.0D); + par1World.spawnParticle("flame", d0, d1 + d3, d2 - d4, 0.0D, 0.0D, 0.0D); + } + else if (meta == 4) + { + par1World.spawnParticle("smoke", d0, d1 + d3, d2 + d4, 0.0D, 0.0D, 0.0D); + par1World.spawnParticle("flame", d0, d1 + d3, d2 + d4, 0.0D, 0.0D, 0.0D); + } + else + { + par1World.spawnParticle("smoke", d0, d1, d2, 0.0D, 0.0D, 0.0D); + par1World.spawnParticle("flame", d0, d1, d2, 0.0D, 0.0D, 0.0D); + } + } +} diff --git a/mods/tinker/tconstruct/client/FrypanRender.java b/mods/tinker/tconstruct/client/FrypanRender.java index 80ea146..7ab4116 100644 --- a/mods/tinker/tconstruct/client/FrypanRender.java +++ b/mods/tinker/tconstruct/client/FrypanRender.java @@ -30,7 +30,7 @@ public class FrypanRender implements ISimpleBlockRenderingHandler renderer.renderStandardBlock(block, x, y, z); renderer.setRenderBounds(1F, 0.0F, 0.4375F, 2F, 0.125F, 0.5625F); renderer.renderStandardBlock(block, x, y, z); - return false; + return true; } @Override diff --git a/mods/tinker/tconstruct/client/SearedRender.java b/mods/tinker/tconstruct/client/SearedRender.java index d5175f5..e4a192f 100644 --- a/mods/tinker/tconstruct/client/SearedRender.java +++ b/mods/tinker/tconstruct/client/SearedRender.java @@ -222,7 +222,7 @@ public class SearedRender implements ISimpleBlockRenderingHandler renderer.renderStandardBlock(block, x, y, z); } } - return false; + return true; } @Override diff --git a/mods/tinker/tconstruct/client/SmelteryRender.java b/mods/tinker/tconstruct/client/SmelteryRender.java index e384cbb..69280d4 100644 --- a/mods/tinker/tconstruct/client/SmelteryRender.java +++ b/mods/tinker/tconstruct/client/SmelteryRender.java @@ -122,7 +122,7 @@ public class SmelteryRender implements ISimpleBlockRenderingHandler } } } - return false; + return true; } void renderLayer(SmelteryLogic logic, int start, int posX, int posY, int posZ, RenderBlocks renderer, IBlockAccess world) diff --git a/mods/tinker/tconstruct/client/TProxyClient.java b/mods/tinker/tconstruct/client/TProxyClient.java index ec984f0..c971b63 100644 --- a/mods/tinker/tconstruct/client/TProxyClient.java +++ b/mods/tinker/tconstruct/client/TProxyClient.java @@ -198,10 +198,10 @@ public class TProxyClient extends TProxyCommon "Slime Crystal Fragment", "Paper", "Cobalt Chunk", "Ardite Chunk", "Manyullyn Chunk", "Copper Chunk", "Bronze Chunk", "Alumite Chunk", "Steel Chunk", "Slime Crystal Fragment" }; public static final String[] materialItemInternalNames = new String[] { "PaperStack", "SlimeCrystal", "SearedBrick", "CobaltIngot", "ArditeIngot", "ManyullynIngot", "Mossball", "LavaCrystal", - "NecroticBone", "CopperIngot", "TinIngot", "AluminumIngot", "RawAluminum", "BronzeIngot", "AlBrassIngot", "AlumiteIngot", "SteelIngot", "BlueSlimeCrystal" }; + "NecroticBone", "CopperIngot", "TinIngot", "AluminumIngot", "RawAluminum", "BronzeIngot", "AlBrassIngot", "AlumiteIngot", "SteelIngot", "BlueSlimeCrystal", "ObsidianIngot" }; public static final String[] materialItemNames = new String[] { "Paper Stack", "Slime Crystal", "Seared Brick", "Cobalt Ingot", "Ardite Ingot", "Manyullyn Ingot", "Ball of Moss", "Lava Crystal", - "Necrotic Bone", "Copper Ingot", "Tin Ingot", "Aluminum Ingot", "Raw Aluminum", "Bronze Ingot", "Aluminum Brass Ingot", "Alumite Ingot", "Steel Ingot", "Slime Crystal" }; + "Necrotic Bone", "Copper Ingot", "Tin Ingot", "Aluminum Ingot", "Raw Aluminum", "Bronze Ingot", "Aluminum Brass Ingot", "Alumite Ingot", "Steel Ingot", "Slime Crystal", "Obsidian Ingot" }; public static final String[] toolMaterialNames = new String[] { "Wood", "Stone", "Iron", "Flint", "Cactus", "Bone", "Obsidian", "Netherrack", "Slime", "Paper", "Cobalt", "Ardite", "Manyullyn", "Copper", "Bronze", "Alumite", "Steel", "Blue Slime" }; @@ -219,15 +219,18 @@ public class TProxyClient extends TProxyCommon public static Document diary; public static Document volume1; + public static Document volume2; public static Document smelter; public void readManuals () { DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance(); diary = readManual("/mods/tinker/resources/manuals/diary.xml", dbFactory); - volume1 = readManual("/mods/tinker/resources/manuals/materials.xml", dbFactory); + volume1 = readManual("/mods/tinker/resources/manuals/firstday.xml", dbFactory); + volume2 = readManual("/mods/tinker/resources/manuals/materials.xml", dbFactory); smelter = readManual("/mods/tinker/resources/manuals/smeltery.xml", dbFactory); initManualIcons(); + initManualRecipes(); } Document readManual (String location, DocumentBuilderFactory dbFactory) @@ -262,6 +265,72 @@ public class TProxyClient extends TProxyCommon TConstructClientRegistry.registerManualIcon("alubrassingot", new ItemStack(TContent.materials, 1, 14)); TConstructClientRegistry.registerManualIcon("manyullyningot", new ItemStack(TContent.materials, 1, 5)); TConstructClientRegistry.registerManualIcon("alumiteingot", new ItemStack(TContent.materials, 1, 15)); + TConstructClientRegistry.registerManualIcon("blankpattern", new ItemStack(TContent.blankPattern, 1, 0)); + TConstructClientRegistry.registerManualIcon("toolstation", new ItemStack(TContent.toolStationWood, 1, 0)); + TConstructClientRegistry.registerManualIcon("partcrafter", new ItemStack(TContent.toolStationWood, 1, 1)); + TConstructClientRegistry.registerManualIcon("patternchest", new ItemStack(TContent.toolStationWood, 1, 5)); + TConstructClientRegistry.registerManualIcon("stenciltable", new ItemStack(TContent.toolStationWood, 1, 10)); + TConstructClientRegistry.registerManualIcon("torch", new ItemStack(Block.torchWood)); + TConstructClientRegistry.registerManualIcon("sapling", new ItemStack(Block.sapling)); + TConstructClientRegistry.registerManualIcon("workbench", new ItemStack(Block.workbench)); + TConstructClientRegistry.registerManualIcon("coal", new ItemStack(Item.coal)); + + TConstructClientRegistry.registerManualIcon("obsidianingot", new ItemStack(TContent.materials, 1, 18)); + TConstructClientRegistry.registerManualIcon("lavacrystal", new ItemStack(TContent.materials, 1, 7)); + + TConstructClientRegistry.registerManualIcon("woodplanks", new ItemStack(Block.planks)); + TConstructClientRegistry.registerManualIcon("stoneblock", new ItemStack(Block.stone)); + TConstructClientRegistry.registerManualIcon("ironingot", new ItemStack(Item.ingotIron)); + TConstructClientRegistry.registerManualIcon("flint", new ItemStack(Item.flint)); + TConstructClientRegistry.registerManualIcon("cactus", new ItemStack(Block.cactus)); + TConstructClientRegistry.registerManualIcon("bone", new ItemStack(Item.bone)); + TConstructClientRegistry.registerManualIcon("obsidian", new ItemStack(Block.obsidian)); + TConstructClientRegistry.registerManualIcon("netherrack", new ItemStack(Block.netherrack)); + TConstructClientRegistry.registerManualIcon("blueslimecrystal", new ItemStack(TContent.materials, 1, 17)); + TConstructClientRegistry.registerManualIcon("slimecrystal", new ItemStack(TContent.materials, 1, 1)); + TConstructClientRegistry.registerManualIcon("paperstack", new ItemStack(TContent.materials, 1, 0)); + TConstructClientRegistry.registerManualIcon("cobaltingot", new ItemStack(TContent.materials, 1, 3)); + TConstructClientRegistry.registerManualIcon("arditeingot", new ItemStack(TContent.materials, 1, 4)); + TConstructClientRegistry.registerManualIcon("copperingot", new ItemStack(TContent.materials, 1, 9)); + TConstructClientRegistry.registerManualIcon("steelingot", new ItemStack(TContent.materials, 1, 16)); + } + + public void initManualRecipes() + { + ItemStack pattern = new ItemStack(TContent.blankPattern, 1, 0); + + ItemStack stick = new ItemStack(Item.stick, 1, 0); + ItemStack plank = new ItemStack(Block.planks, 1, 0); + ItemStack workbench = new ItemStack(Block.workbench, 1, 0); + ItemStack chest = new ItemStack(Block.chest, 1, 0); + ItemStack log = new ItemStack(Block.wood, 1, 0); + + ItemStack sand = new ItemStack(Block.sand, 1, 0); + ItemStack gravel = new ItemStack(Block.gravel, 1, 0); + ItemStack clay = new ItemStack(Item.clay, 1, 0); + ItemStack glass = new ItemStack(Block.glass, 1, 0); + + ItemStack grout = new ItemStack(TContent.craftedSoil, 2, 1); + ItemStack searedbrick = new ItemStack(TContent.materials, 1, 2); + + TConstructClientRegistry.registerManualSmallRecipe("blankpattern", pattern, plank, stick, stick, plank); + TConstructClientRegistry.registerManualSmallRecipe("toolstation", new ItemStack(TContent.toolStationWood, 1, 0), null, pattern, null, workbench); + TConstructClientRegistry.registerManualSmallRecipe("partcrafter", new ItemStack(TContent.toolStationWood, 1, 1), null, pattern, null, plank); + TConstructClientRegistry.registerManualSmallRecipe("patternchest", new ItemStack(TContent.toolStationWood, 1, 5), null, pattern, null, chest); + TConstructClientRegistry.registerManualSmallRecipe("stenciltable", new ItemStack(TContent.toolStationWood, 1, 10), null, pattern, null, log); + + TConstructClientRegistry.registerManualSmallRecipe("grout", grout, sand, gravel, null, clay); + TConstructClientRegistry.registerManualFurnaceRecipe("searedbrick", searedbrick, grout); + TConstructClientRegistry.registerManualSmallRecipe("searedbricks", new ItemStack(TContent.smeltery, 1, 2), searedbrick, searedbrick, searedbrick, searedbrick); + TConstructClientRegistry.registerManualLargeRecipe("smelterycontroller", new ItemStack(TContent.smeltery, 1, 0), searedbrick, searedbrick, searedbrick, searedbrick, null, searedbrick, searedbrick, searedbrick, searedbrick); + TConstructClientRegistry.registerManualLargeRecipe("smelterydrain", new ItemStack(TContent.smeltery, 1, 1), searedbrick, null, searedbrick, searedbrick, null, searedbrick, searedbrick, searedbrick, searedbrick); + + TConstructClientRegistry.registerManualLargeRecipe("smelterytank1", new ItemStack(TContent.lavaTank, 1, 0), searedbrick, searedbrick, searedbrick, searedbrick, glass, searedbrick, searedbrick, searedbrick, searedbrick); + TConstructClientRegistry.registerManualLargeRecipe("smelterytank2", new ItemStack(TContent.lavaTank, 1, 1), searedbrick, glass, searedbrick, glass, glass, glass, searedbrick, glass, searedbrick); + TConstructClientRegistry.registerManualLargeRecipe("smelterytank3", new ItemStack(TContent.lavaTank, 1, 2), searedbrick, glass, searedbrick, searedbrick, glass, searedbrick, searedbrick, glass, searedbrick); + + TConstructClientRegistry.registerManualLargeRecipe("smelterytable", new ItemStack(TContent.searedBlock, 1, 0), searedbrick, searedbrick, searedbrick, searedbrick, null, searedbrick, searedbrick, null, searedbrick); + TConstructClientRegistry.registerManualLargeRecipe("smelteryfaucet", new ItemStack(TContent.searedBlock, 1, 1), searedbrick, null, searedbrick, null, searedbrick, null, null, null, null); } public static Document getManualFromStack (ItemStack stack) @@ -269,11 +338,13 @@ public class TProxyClient extends TProxyCommon switch (stack.getItemDamage()) { case 0: - return diary; - case 1: return volume1; + case 1: + return volume2; case 2: return smelter; + case 3: + return diary; } return null; @@ -349,7 +420,7 @@ public class TProxyClient extends TProxyCommon void addRenderMappings () { String[] partTypes = { "wood", "stone", "iron", "flint", "cactus", "bone", "obsidian", "netherrack", "slime", "paper", "cobalt", "ardite", "manyullyn", "copper", "bronze", "alumite", "steel", "blueslime" }; - String[] effectTypes = { "diamond", "emerald", "redstone", "glowstone", "moss", "ice", "lava", "blaze", "necrotic", "electric", "lapis" }; + String[] effectTypes = { "diamond", "emerald", "redstone", "glowstone", "moss", "ice", "lava", "blaze", "necrotic", "electric", "lapis", "quartz" }; for (int partIter = 0; partIter < partTypes.length; partIter++) { TConstructClientRegistry.addMaterialRenderMapping(partIter, "tinker", partTypes[partIter], true); @@ -614,48 +685,5 @@ public class TProxyClient extends TProxyCommon { return null; } - /*if (this.mc.renderViewEntity != null && this.mc.effectRenderer != null) - { - int i = this.mc.gameSettings.particleSetting; - - if (i == 1 && mc.theWorld.rand.nextInt(3) == 0) - { - i = 2; - } - - double d6 = this.mc.renderViewEntity.posX - par2; - double d7 = this.mc.renderViewEntity.posY - par4; - double d8 = this.mc.renderViewEntity.posZ - par6; - EntityFX entityfx = null; - double d9 = 16.0D; - - if (d6 * d6 + d7 * d7 + d8 * d8 > d9 * d9) - { - return null; - } - else if (i > 1) - { - return null; - } - else - { - if (par1Str.equals("blueslime")) - { - entityfx = new EntityBreakingFX(mc.theWorld, par2, par4, par6, Item.appleGold, mc.renderEngine);RenderGlobal - } - - else if (par1Str.equals("metalslime")) - { - entityfx = new BreakingFX(mc.theWorld, par2, par4, par6, metalBall, mc.renderEngine); - } - - return (EntityFX) entityfx; - - } - } - else - { - return null; - }*/ } } diff --git a/mods/tinker/tconstruct/client/TableRender.java b/mods/tinker/tconstruct/client/TableRender.java index 7a6b953..950a4bd 100644 --- a/mods/tinker/tconstruct/client/TableRender.java +++ b/mods/tinker/tconstruct/client/TableRender.java @@ -64,7 +64,7 @@ public class TableRender implements ISimpleBlockRenderingHandler renderer.renderStandardBlock(block, x, y, z); } } - return false; + return true; } @Override diff --git a/mods/tinker/tconstruct/client/TankRender.java b/mods/tinker/tconstruct/client/TankRender.java index 2405b17..c004be5 100644 --- a/mods/tinker/tconstruct/client/TankRender.java +++ b/mods/tinker/tconstruct/client/TankRender.java @@ -64,7 +64,7 @@ public class TankRender implements ISimpleBlockRenderingHandler } } } - return false; + return true; } @Override diff --git a/mods/tinker/tconstruct/client/gui/GuiManual.java b/mods/tinker/tconstruct/client/gui/GuiManual.java index b63a1b8..c67b2e1 100644 --- a/mods/tinker/tconstruct/client/gui/GuiManual.java +++ b/mods/tinker/tconstruct/client/gui/GuiManual.java @@ -1,15 +1,23 @@ package mods.tinker.tconstruct.client.gui; +import java.util.List; + import mods.tinker.tconstruct.client.TProxyClient; +import mods.tinker.tconstruct.crafting.PatternBuilder; +import mods.tinker.tconstruct.library.TConstructRegistry; +import mods.tinker.tconstruct.library.ToolMaterial; import mods.tinker.tconstruct.library.client.TConstructClientRegistry; import net.minecraft.client.Minecraft; import net.minecraft.client.gui.GuiButton; import net.minecraft.client.gui.GuiParticle; import net.minecraft.client.gui.GuiScreen; +import net.minecraft.client.renderer.RenderHelper; import net.minecraft.client.renderer.entity.RenderItem; import net.minecraft.item.ItemStack; +import net.minecraft.util.StatCollector; import org.lwjgl.opengl.GL11; +import org.lwjgl.opengl.GL12; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.Node; @@ -21,322 +29,647 @@ import cpw.mods.fml.relauncher.SideOnly; @SideOnly(Side.CLIENT) public class GuiManual extends GuiScreen { - ItemStack itemstackBook; - Document manual; - private RenderItem renderitem = new RenderItem(); - int bookImageWidth = 206; - int bookImageHeight = 200; - int bookTotalPages = 1; - int currentPage; - int maxPages; + ItemStack itemstackBook; + Document manual; + private RenderItem renderitem = new RenderItem(); + int bookImageWidth = 206; + int bookImageHeight = 200; + int bookTotalPages = 1; + int currentPage; + int maxPages; - private TurnPageButton buttonNextPage; - private TurnPageButton buttonPreviousPage; - String pageLeftType; - String textLeft; - ItemStack[] iconsLeft; - String[] multiTextLeft; + private TurnPageButton buttonNextPage; + private TurnPageButton buttonPreviousPage; + String pageLeftType; + String textLeft; + ItemStack[] iconsLeft; + String[] multiTextLeft; + ToolMaterial materialLeft; - String pageRightType; - String textRight; - ItemStack[] iconsRight; - String[] multiTextRight; + String pageRightType; + String textRight; + ItemStack[] iconsRight; + String[] multiTextRight; + ToolMaterial materialRight; - public GuiManual(ItemStack stack, Document doc) - { - this.mc = Minecraft.getMinecraft(); - this.itemstackBook = stack; - currentPage = 0; //Stack page - manual = doc; - } + public GuiManual(ItemStack stack, Document doc) + { + this.mc = Minecraft.getMinecraft(); + this.itemstackBook = stack; + currentPage = 0; //Stack page + manual = doc; + renderitem.renderInFrame = true; + } - @Override - public void setWorldAndResolution (Minecraft minecraft, int w, int h) - { - this.guiParticles = new GuiParticle(minecraft); - this.mc = minecraft; - this.fontRenderer = TProxyClient.smallFontRenderer; - this.width = w; - this.height = h; - this.buttonList.clear(); - this.initGui(); - } + @Override + public void setWorldAndResolution (Minecraft minecraft, int w, int h) + { + this.guiParticles = new GuiParticle(minecraft); + this.mc = minecraft; + this.fontRenderer = TProxyClient.smallFontRenderer; + this.width = w; + this.height = h; + this.buttonList.clear(); + this.initGui(); + } - public void initGui () - { - maxPages = manual.getElementsByTagName("page").getLength(); - updateText(); - int xPos = (this.width) / 2; - this.buttonList.add(this.buttonNextPage = new TurnPageButton(1, xPos + bookImageWidth - 50, 180, true)); - this.buttonList.add(this.buttonPreviousPage = new TurnPageButton(2, xPos - bookImageWidth + 24, 180, false)); - } + public void initGui () + { + multiTextLeft = new String[] { "" }; + multiTextRight = new String[] { "" }; + iconsLeft = new ItemStack[1]; + iconsRight = new ItemStack[1]; + maxPages = manual.getElementsByTagName("page").getLength(); + updateText(); + int xPos = (this.width) / 2; + this.buttonList.add(this.buttonNextPage = new TurnPageButton(1, xPos + bookImageWidth - 50, 180, true)); + this.buttonList.add(this.buttonPreviousPage = new TurnPageButton(2, xPos - bookImageWidth + 24, 180, false)); + } - protected void actionPerformed (GuiButton button) - { - if (button.enabled) - { - if (button.id == 1) - currentPage += 2; - if (button.id == 2) - currentPage -= 2; + protected void actionPerformed (GuiButton button) + { + if (button.enabled) + { + if (button.id == 1) + currentPage += 2; + if (button.id == 2) + currentPage -= 2; - updateText(); - } - } + updateText(); + } + } - void updateText () - { - if (currentPage >= maxPages) - currentPage = maxPages - 2; - if (currentPage % 2 == 1) - currentPage--; - if (currentPage < 0) - currentPage = 0; + void updateText () //TODO: OOP this + { + if (currentPage >= maxPages) + currentPage = maxPages - 2; + if (currentPage % 2 == 1) + currentPage--; + if (currentPage < 0) + currentPage = 0; - NodeList nList = manual.getElementsByTagName("page"); + NodeList nList = manual.getElementsByTagName("page"); - Node node = nList.item(currentPage); - if (node.getNodeType() == Node.ELEMENT_NODE) - { - Element element = (Element) node; - pageLeftType = element.getAttribute("type"); + Node node = nList.item(currentPage); + if (node.getNodeType() == Node.ELEMENT_NODE) + { + Element element = (Element) node; + pageLeftType = element.getAttribute("type"); - if (pageLeftType.equals("text") || pageLeftType.equals("intro")) - { - NodeList nodes = element.getElementsByTagName("text"); - if (nodes != null) - textLeft = nodes.item(0).getTextContent(); - } + if (pageLeftType.equals("text") || pageLeftType.equals("intro")) + { + NodeList nodes = element.getElementsByTagName("text"); + if (nodes != null) + textLeft = nodes.item(0).getTextContent(); + } - else if (pageLeftType.equals("contents")) - { - NodeList nodes = element.getElementsByTagName("text"); - if (nodes != null) - textLeft = nodes.item(0).getTextContent(); - - nodes = element.getElementsByTagName("link"); - multiTextLeft = new String[nodes.getLength()]; - iconsLeft = new ItemStack[nodes.getLength()]; - for (int i = 0; i < nodes.getLength(); i++) - { - NodeList children = nodes.item(i).getChildNodes(); - multiTextLeft[i] = children.item(1).getTextContent(); - iconsLeft[i] = TConstructClientRegistry.getManualIcon(children.item(3).getTextContent()); - } - } + else if (pageLeftType.equals("contents")) + { + NodeList nodes = element.getElementsByTagName("text"); + if (nodes != null) + textLeft = nodes.item(0).getTextContent(); - else if (pageLeftType.equals("sidebar")) - { - NodeList nodes = element.getElementsByTagName("text"); - if (nodes != null) - textLeft = nodes.item(0).getTextContent(); - - nodes = element.getElementsByTagName("item"); - multiTextLeft = new String[nodes.getLength()]; - iconsLeft = new ItemStack[nodes.getLength()]; - for (int i = 0; i < nodes.getLength(); i++) - { - NodeList children = nodes.item(i).getChildNodes(); - multiTextLeft[i] = children.item(1).getTextContent(); - iconsLeft[i] = TConstructClientRegistry.getManualIcon(children.item(3).getTextContent()); - } - } + nodes = element.getElementsByTagName("link"); + multiTextLeft = new String[nodes.getLength()]; + iconsLeft = new ItemStack[nodes.getLength()]; + for (int i = 0; i < nodes.getLength(); i++) + { + NodeList children = nodes.item(i).getChildNodes(); + multiTextLeft[i] = children.item(1).getTextContent(); + iconsLeft[i] = TConstructClientRegistry.getManualIcon(children.item(3).getTextContent()); + } + } - else if (pageLeftType.equals("picture")) - { - NodeList nodes = element.getElementsByTagName("text"); - if (nodes != null) - textLeft = nodes.item(0).getTextContent(); - - nodes = element.getElementsByTagName("picture"); - if (nodes != null) - multiTextLeft[0] = nodes.item(0).getTextContent(); - } - } + else if (pageLeftType.equals("sidebar")) + { + NodeList nodes = element.getElementsByTagName("text"); + if (nodes != null) + textLeft = nodes.item(0).getTextContent(); - node = nList.item(currentPage + 1); - if (node != null && node.getNodeType() == Node.ELEMENT_NODE) - { - Element element = (Element) node; - pageRightType = element.getAttribute("type"); + nodes = element.getElementsByTagName("item"); + multiTextLeft = new String[nodes.getLength()]; + iconsLeft = new ItemStack[nodes.getLength()]; + for (int i = 0; i < nodes.getLength(); i++) + { + NodeList children = nodes.item(i).getChildNodes(); + multiTextLeft[i] = children.item(1).getTextContent(); + iconsLeft[i] = TConstructClientRegistry.getManualIcon(children.item(3).getTextContent()); + } + } - if (pageRightType.equals("text") || pageRightType.equals("intro")) - { - NodeList nodes = element.getElementsByTagName("text"); - if (nodes != null) - textRight = nodes.item(0).getTextContent(); - } + else if (pageLeftType.equals("picture")) + { + NodeList nodes = element.getElementsByTagName("text"); + if (nodes != null) + textLeft = nodes.item(0).getTextContent(); - else if (pageRightType.equals("contents")) - { - NodeList nodes = element.getElementsByTagName("text"); - if (nodes != null) - textRight = nodes.item(0).getTextContent(); - - nodes = element.getElementsByTagName("link"); - multiTextRight = new String[nodes.getLength()]; - iconsRight = new ItemStack[nodes.getLength()]; - for (int i = 0; i < nodes.getLength(); i++) - { - NodeList children = nodes.item(i).getChildNodes(); - multiTextRight[i] = children.item(1).getTextContent(); - iconsRight[i] = TConstructClientRegistry.getManualIcon(children.item(3).getTextContent()); - } - } - - else if (pageRightType.equals("sidebar")) - { - NodeList nodes = element.getElementsByTagName("text"); - if (nodes != null) - textRight = nodes.item(0).getTextContent(); - - nodes = element.getElementsByTagName("item"); - multiTextRight = new String[nodes.getLength()]; - iconsRight = new ItemStack[nodes.getLength()]; - for (int i = 0; i < nodes.getLength(); i++) - { - NodeList children = nodes.item(i).getChildNodes(); - multiTextRight[i] = children.item(1).getTextContent(); - iconsRight[i] = TConstructClientRegistry.getManualIcon(children.item(3).getTextContent()); - } - } - - else if (pageRightType.equals("picture")) - { - NodeList nodes = element.getElementsByTagName("text"); - if (nodes != null) - textRight = nodes.item(0).getTextContent(); - - nodes = element.getElementsByTagName("picture"); - if (nodes != null) - multiTextRight[0] = nodes.item(0).getTextContent(); - } - } - else - { - pageRightType = "blank"; - textRight = null; - } - } + nodes = element.getElementsByTagName("picture"); + if (nodes != null) + multiTextLeft[0] = nodes.item(0).getTextContent(); + } - public void drawScreen (int par1, int par2, float par3) - { - GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F); - this.mc.renderEngine.bindTexture("/mods/tinker/textures/gui/bookright.png"); - int localWidth = (this.width) / 2; - byte localHeight = 8; - this.drawTexturedModalRect(localWidth, localHeight, 0, 0, this.bookImageWidth, this.bookImageHeight); + else if (pageLeftType.equals("crafting")) + { + NodeList nodes = element.getElementsByTagName("text"); + if (nodes != null) + textLeft = nodes.item(0).getTextContent(); - GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F); - this.mc.renderEngine.bindTexture("/mods/tinker/textures/gui/bookleft.png"); - localWidth = localWidth - this.bookImageWidth; - this.drawTexturedModalRect(localWidth, localHeight, 256 - this.bookImageWidth, 0, this.bookImageWidth, this.bookImageHeight); + nodes = element.getElementsByTagName("name"); + if (nodes != null) + iconsLeft = TConstructClientRegistry.getRecipeIcons(nodes.item(0).getTextContent()); - super.drawScreen(par1, par2, par3); - - //Workaround - if (pageLeftType.equals("picture")) - { - drawPicture(multiTextLeft[0], localWidth + 16, localHeight + 12); - } - if (pageRightType.equals("picture")) - { - drawPicture(multiTextRight[0], localWidth + 220, localHeight + 12); - } + nodes = element.getElementsByTagName("size"); + if (nodes != null) + multiTextLeft[0] = nodes.item(0).getTextContent(); + } - if (pageLeftType.equals("text")) - { - if (textLeft != null) - drawTextPage(textLeft, localWidth + 16, localHeight + 12); - } - else if (pageLeftType.equals("intro")) - { - if (textLeft != null) - drawTitlePage(textLeft, localWidth + 16, localHeight + 12); - } - else if (pageLeftType.equals("contents")) - { - drawContentTablePage(textLeft, iconsLeft, multiTextLeft, localWidth + 16, localHeight + 12); - } - else if (pageLeftType.equals("sidebar")) - { - drawSidebarPage(textLeft, iconsLeft, multiTextLeft, localWidth + 16, localHeight + 12); - } - else if (pageLeftType.equals("picture")) - { - drawPicturePage(textLeft, localWidth + 16, localHeight + 12); - } + else if (pageLeftType.equals("smelting")) + { + NodeList nodes = element.getElementsByTagName("text"); + if (nodes != null) + textLeft = nodes.item(0).getTextContent(); - if (pageRightType.equals("text")) - { - if (textRight != null) - drawTextPage(textRight, localWidth + 220, localHeight + 12); - } - else if (pageRightType.equals("intro")) - { - if (textRight != null) - drawTitlePage(textRight, localWidth + 220, localHeight + 12); - } - else if (pageRightType.equals("contents")) - { - drawContentTablePage(textRight, iconsRight, multiTextRight, localWidth + 220, localHeight + 12); - } - else if (pageRightType.equals("sidebar")) - { - drawSidebarPage(textRight, iconsRight, multiTextRight, localWidth + 220, localHeight + 12); - } - else if (pageRightType.equals("picture")) - { - drawPicturePage(textRight, localWidth + 220, localHeight + 12); - } - } + nodes = element.getElementsByTagName("recipe"); + if (nodes != null) + iconsLeft = TConstructClientRegistry.getRecipeIcons(nodes.item(0).getTextContent()); + } + + else if (pageLeftType.equals("materialstats")) + { + NodeList nodes = element.getElementsByTagName("title"); + if (nodes != null) + textLeft = nodes.item(0).getTextContent(); + + iconsLeft = new ItemStack[4]; - /* Page types */ - public void drawTextPage (String text, int localWidth, int localHeight) - { - this.fontRenderer.drawSplitString(text, localWidth, localHeight, 178, 0); - } + nodes = element.getElementsByTagName("text"); + if (nodes != null) + multiTextLeft[0] = nodes.item(0).getTextContent(); + + nodes = element.getElementsByTagName("icon"); + if (nodes != null) + iconsLeft[0] = TConstructClientRegistry.getManualIcon(nodes.item(0).getTextContent()); - public void drawTitlePage (String text, int localWidth, int localHeight) - { - this.fontRenderer.drawSplitString(text, localWidth, localHeight, 178, 0); - } + nodes = element.getElementsByTagName("toolmaterial"); + if (nodes != null && nodes.getLength() > 0) + materialLeft = TConstructRegistry.getMaterial(nodes.item(0).getTextContent()); + else + materialLeft = TConstructRegistry.getMaterial(textLeft); + + nodes = element.getElementsByTagName("material").item(0).getChildNodes(); - public void drawContentTablePage (String info, ItemStack[] icons, String[] multiText, int localWidth, int localHeight) - { - if (info != null) - this.fontRenderer.drawString("\u00a7n"+info, localWidth + 50, localHeight + 4, 0); - for (int i = 0; i < icons.length; i++) - { - renderitem.renderItemIntoGUI(fontRenderer, mc.renderEngine, icons[i], localWidth + 16, localHeight + 18 * i + 18); - int yOffset = 18; - if (multiText[i].length() > 40) - yOffset = 13; - this.fontRenderer.drawString(multiText[i], localWidth + 38, localHeight + 18 * i + yOffset, 0); - } - } - - public void drawSidebarPage (String info, ItemStack[] icons, String[] multiText, int localWidth, int localHeight) - { - this.fontRenderer.drawSplitString(info, localWidth, localHeight, 178, 0); - for (int i = 0; i < icons.length; i++) - { - renderitem.renderItemIntoGUI(fontRenderer, mc.renderEngine, icons[i], localWidth + 8, localHeight + 18 * i + 36); - int yOffset = 39; - if (multiText[i].length() > 40) - yOffset = 34; - this.fontRenderer.drawSplitString(multiText[i], localWidth + 30, localHeight + 18 * i + yOffset, 140, 0); - } - } - - public void drawPicture(String picture, int localWidth, int localHeight) - { - this.mc.renderEngine.bindTexture(picture); - this.drawTexturedModalRect(localWidth, localHeight+12, 0, 0, 170, 144); - } - - public void drawPicturePage(String info, int localWidth, int localHeight) - { - this.fontRenderer.drawSplitString(info, localWidth+8, localHeight, 178, 0); - } + iconsLeft[1] = TConstructClientRegistry.getManualIcon(nodes.item(1).getTextContent()); + iconsLeft[2] = PatternBuilder.instance.getShardFromSet(materialLeft.name()); + iconsLeft[3] = PatternBuilder.instance.getRodFromSet(materialLeft.name()); + } + } + + node = nList.item(currentPage + 1); + if (node != null && node.getNodeType() == Node.ELEMENT_NODE) + { + Element element = (Element) node; + pageRightType = element.getAttribute("type"); + + if (pageRightType.equals("text") || pageRightType.equals("intro")) + { + NodeList nodes = element.getElementsByTagName("text"); + if (nodes != null) + textRight = nodes.item(0).getTextContent(); + } + + else if (pageRightType.equals("contents")) + { + NodeList nodes = element.getElementsByTagName("text"); + if (nodes != null) + textRight = nodes.item(0).getTextContent(); + + nodes = element.getElementsByTagName("link"); + multiTextRight = new String[nodes.getLength()]; + iconsRight = new ItemStack[nodes.getLength()]; + for (int i = 0; i < nodes.getLength(); i++) + { + NodeList children = nodes.item(i).getChildNodes(); + multiTextRight[i] = children.item(1).getTextContent(); + iconsRight[i] = TConstructClientRegistry.getManualIcon(children.item(3).getTextContent()); + } + } + + else if (pageRightType.equals("sidebar")) + { + NodeList nodes = element.getElementsByTagName("text"); + if (nodes != null) + textRight = nodes.item(0).getTextContent(); + + nodes = element.getElementsByTagName("item"); + multiTextRight = new String[nodes.getLength()]; + iconsRight = new ItemStack[nodes.getLength()]; + for (int i = 0; i < nodes.getLength(); i++) + { + NodeList children = nodes.item(i).getChildNodes(); + multiTextRight[i] = children.item(1).getTextContent(); + iconsRight[i] = TConstructClientRegistry.getManualIcon(children.item(3).getTextContent()); + } + } + + else if (pageRightType.equals("picture")) + { + NodeList nodes = element.getElementsByTagName("text"); + if (nodes != null) + textRight = nodes.item(0).getTextContent(); + + nodes = element.getElementsByTagName("picture"); + if (nodes != null) + multiTextRight[0] = nodes.item(0).getTextContent(); + } + + else if (pageRightType.equals("crafting")) + { + NodeList nodes = element.getElementsByTagName("text"); + if (nodes != null) + textRight = nodes.item(0).getTextContent(); + + nodes = element.getElementsByTagName("name"); + if (nodes != null) + iconsRight = TConstructClientRegistry.getRecipeIcons(nodes.item(0).getTextContent()); + + nodes = element.getElementsByTagName("size"); + if (nodes != null) + multiTextRight[0] = nodes.item(0).getTextContent(); + } + + else if (pageRightType.equals("smelting")) + { + NodeList nodes = element.getElementsByTagName("text"); + if (nodes != null) + textRight = nodes.item(0).getTextContent(); + + nodes = element.getElementsByTagName("recipe"); + if (nodes != null) + iconsRight = TConstructClientRegistry.getRecipeIcons(nodes.item(0).getTextContent()); + } + + else if (pageRightType.equals("materialstats")) + { + NodeList nodes = element.getElementsByTagName("title"); + if (nodes != null) + textRight = nodes.item(0).getTextContent(); + + iconsRight = new ItemStack[4]; + + nodes = element.getElementsByTagName("text"); + if (nodes != null) + multiTextRight[0] = nodes.item(0).getTextContent(); + + nodes = element.getElementsByTagName("icon"); + if (nodes != null) + iconsRight[0] = TConstructClientRegistry.getManualIcon(nodes.item(0).getTextContent()); + + nodes = element.getElementsByTagName("toolmaterial"); + if (nodes != null && nodes.getLength() > 0) + materialRight = TConstructRegistry.getMaterial(nodes.item(0).getTextContent()); + else + materialRight = TConstructRegistry.getMaterial(textRight); + + nodes = element.getElementsByTagName("material").item(0).getChildNodes(); + + iconsRight[1] = TConstructClientRegistry.getManualIcon(nodes.item(1).getTextContent()); + iconsRight[2] = PatternBuilder.instance.getShardFromSet(materialRight.name()); + iconsRight[3] = PatternBuilder.instance.getRodFromSet(materialRight.name()); + + } + } + else + { + pageRightType = "blank"; + textRight = null; + } + } + + public void drawScreen (int par1, int par2, float par3) + { + GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F); + this.mc.renderEngine.bindTexture("/mods/tinker/textures/gui/bookright.png"); + int localWidth = (this.width) / 2; + byte localHeight = 8; + this.drawTexturedModalRect(localWidth, localHeight, 0, 0, this.bookImageWidth, this.bookImageHeight); + + GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F); + this.mc.renderEngine.bindTexture("/mods/tinker/textures/gui/bookleft.png"); + localWidth = localWidth - this.bookImageWidth; + this.drawTexturedModalRect(localWidth, localHeight, 256 - this.bookImageWidth, 0, this.bookImageWidth, this.bookImageHeight); + + super.drawScreen(par1, par2, par3); + + //Workaround + if (pageLeftType.equals("picture")) //TODO: OOP this + { + drawPicture(multiTextLeft[0], localWidth + 16, localHeight + 12); + } + if (pageRightType.equals("picture")) + { + drawPicture(multiTextRight[0], localWidth + 220, localHeight + 12); + } + + if (pageLeftType.equals("crafting")) + { + if (multiTextLeft[0].equals("two")) + drawCrafting(2, localWidth + 16, localHeight + 12); + + if (multiTextLeft[0].equals("three")) + drawCrafting(3, localWidth + 22, localHeight + 12); + } + if (pageRightType.equals("crafting")) + { + int size = 2; + if (multiTextRight[0].equals("three")) + size = 3; + drawCrafting(size, localWidth + 220, localHeight + 12); + } + if (pageLeftType.equals("smelting")) + { + drawSmelting(localWidth + 16, localHeight + 12); + } + if (pageRightType.equals("smelting")) + { + drawSmelting(localWidth + 220, localHeight + 12); + } + + //Text + if (pageLeftType.equals("text")) + { + if (textLeft != null) + drawTextPage(textLeft, localWidth + 16, localHeight + 12); + } + else if (pageLeftType.equals("intro")) + { + if (textLeft != null) + drawTitlePage(textLeft, localWidth + 16, localHeight + 12); + } + else if (pageLeftType.equals("contents")) + { + drawContentTablePage(textLeft, iconsLeft, multiTextLeft, localWidth + 16, localHeight + 12); + } + else if (pageLeftType.equals("sidebar")) + { + drawSidebarPage(textLeft, iconsLeft, multiTextLeft, localWidth + 16, localHeight + 12); + } + else if (pageLeftType.equals("picture")) + { + drawPicturePage(textLeft, localWidth + 16, localHeight + 12); + } + else if (pageLeftType.equals("crafting")) + { + if (multiTextLeft[0].equals("two")) + drawCraftingPage(textLeft, iconsLeft, 2, localWidth + 16, localHeight + 12); + if (multiTextLeft[0].equals("three")) + drawCraftingPage(textLeft, iconsLeft, 3, localWidth + 22, localHeight + 12); + } + else if (pageLeftType.equals("smelting")) + { + drawSmeltingPage(textLeft, iconsLeft, localWidth + 16, localHeight + 12); + } + else if (pageLeftType.equals("materialstats")) + { + drawMaterialPage(textLeft, iconsLeft, multiTextLeft, materialLeft, localWidth + 16, localHeight + 12); + } + + if (pageRightType.equals("text")) + { + if (textRight != null) + drawTextPage(textRight, localWidth + 220, localHeight + 12); + } + else if (pageRightType.equals("intro")) + { + if (textRight != null) + drawTitlePage(textRight, localWidth + 220, localHeight + 12); + } + else if (pageRightType.equals("contents")) + { + drawContentTablePage(textRight, iconsRight, multiTextRight, localWidth + 220, localHeight + 12); + } + else if (pageRightType.equals("sidebar")) + { + drawSidebarPage(textRight, iconsRight, multiTextRight, localWidth + 220, localHeight + 12); + } + else if (pageRightType.equals("picture")) + { + drawPicturePage(textRight, localWidth + 220, localHeight + 12); + } + else if (pageRightType.equals("crafting")) + { + int size = 2; + if (multiTextRight[0].equals("three")) + size = 3; + drawCraftingPage(textRight, iconsRight, size, localWidth + 220, localHeight + 12); + } + else if (pageRightType.equals("smelting")) + { + drawSmeltingPage(textRight, iconsRight, localWidth + 220, localHeight + 12); + } + else if (pageRightType.equals("materialstats")) + { + drawMaterialPage(textRight, iconsRight, multiTextRight, materialRight, localWidth + 220, localHeight + 12); + } + } + + /* Page types */ + public void drawTextPage (String text, int localWidth, int localHeight) + { + this.fontRenderer.drawSplitString(text, localWidth, localHeight, 178, 0); + } + + public void drawTitlePage (String text, int localWidth, int localHeight) + { + this.fontRenderer.drawSplitString(text, localWidth, localHeight, 178, 0); + } + + public void drawContentTablePage (String info, ItemStack[] icons, String[] multiText, int localWidth, int localHeight) + { + if (info != null) + this.fontRenderer.drawString("\u00a7n" + info, localWidth + 50, localHeight + 4, 0); + GL11.glEnable(GL12.GL_RESCALE_NORMAL); + RenderHelper.enableGUIStandardItemLighting(); + for (int i = 0; i < icons.length; i++) + { + renderitem.renderItemIntoGUI(fontRenderer, mc.renderEngine, icons[i], localWidth + 16, localHeight + 18 * i + 18); + int yOffset = 18; + if (multiText[i].length() > 40) + yOffset = 13; + this.fontRenderer.drawString(multiText[i], localWidth + 38, localHeight + 18 * i + yOffset, 0); + } + RenderHelper.disableStandardItemLighting(); + GL11.glDisable(GL12.GL_RESCALE_NORMAL); + } + + public void drawSidebarPage (String info, ItemStack[] icons, String[] multiText, int localWidth, int localHeight) + { + this.fontRenderer.drawSplitString(info, localWidth, localHeight, 178, 0); + GL11.glEnable(GL12.GL_RESCALE_NORMAL); + RenderHelper.enableGUIStandardItemLighting(); + for (int i = 0; i < icons.length; i++) + { + renderitem.renderItemIntoGUI(fontRenderer, mc.renderEngine, icons[i], localWidth + 8, localHeight + 18 * i + 36); + int yOffset = 39; + if (multiText[i].length() > 40) + yOffset = 34; + this.fontRenderer.drawSplitString(multiText[i], localWidth + 30, localHeight + 18 * i + yOffset, 140, 0); + } + RenderHelper.disableStandardItemLighting(); + GL11.glDisable(GL12.GL_RESCALE_NORMAL); + } + + public void drawPicture (String picture, int localWidth, int localHeight) + { + this.mc.renderEngine.bindTexture(picture); + this.drawTexturedModalRect(localWidth, localHeight + 12, 0, 0, 170, 144); + } + + public void drawPicturePage (String info, int localWidth, int localHeight) + { + this.fontRenderer.drawSplitString(info, localWidth + 8, localHeight, 178, 0); + } + + public void drawCrafting (int size, int localWidth, int localHeight) + { + this.mc.renderEngine.bindTexture("/mods/tinker/textures/gui/bookcrafting.png"); + if (size == 2) + this.drawTexturedModalRect(localWidth + 8, localHeight + 46, 0, 116, 154, 78); + if (size == 3) + this.drawTexturedModalRect(localWidth - 8, localHeight + 28, 0, 0, 183, 114); + } + + public void drawCraftingPage (String info, ItemStack[] icons, int recipeSize, int localWidth, int localHeight) + { + if (info != null) + this.fontRenderer.drawString("\u00a7n" + info, localWidth + 50, localHeight + 4, 0); + + GL11.glScalef(2f, 2f, 2f); + GL11.glEnable(GL12.GL_RESCALE_NORMAL); + RenderHelper.enableGUIStandardItemLighting(); + + if (recipeSize == 2) + { + renderitem.renderItemAndEffectIntoGUI(fontRenderer, mc.renderEngine, icons[0], (localWidth + 126) / 2, (localHeight + 68) / 2); + if (icons[0].stackSize > 1) + renderitem.renderItemStack(fontRenderer, mc.renderEngine, icons[0], (localWidth + 126) / 2, (localHeight + 68) / 2, String.valueOf(icons[0].stackSize)); + for (int i = 0; i < icons.length - 1; i++) + { + if (icons[i + 1] != null) + renderitem.renderItemAndEffectIntoGUI(fontRenderer, mc.renderEngine, icons[i + 1], (localWidth + 14 + 36 * (i % 2)) / 2, (localHeight + 36 * (i / 2) + 52) / 2); + } + } + + if (recipeSize == 3) + { + renderitem.renderItemAndEffectIntoGUI(fontRenderer, mc.renderEngine, icons[0], (localWidth + 138) / 2, (localHeight + 70) / 2); + if (icons[0].stackSize > 1) + renderitem.renderItemStack(fontRenderer, mc.renderEngine, icons[0], (localWidth + 126) / 2, (localHeight + 68) / 2, String.valueOf(icons[0].stackSize)); + for (int i = 0; i < icons.length - 1; i++) + { + if (icons[i + 1] != null) + renderitem.renderItemAndEffectIntoGUI(fontRenderer, mc.renderEngine, icons[i + 1], (localWidth - 2 + 36 * (i % 3)) / 2, (localHeight + 36 * (i / 3) + 34) / 2); + } + } + + GL11.glScalef(0.5F, 0.5F, 0.5F); + RenderHelper.disableStandardItemLighting(); + GL11.glDisable(GL12.GL_RESCALE_NORMAL); + } + + public void drawSmelting (int localWidth, int localHeight) + { + this.mc.renderEngine.bindTexture("/mods/tinker/textures/gui/bookfurnace.png"); + this.drawTexturedModalRect(localWidth + 32, localHeight + 32, 0, 0, 111, 114); + } + + public void drawSmeltingPage (String info, ItemStack[] icons, int localWidth, int localHeight) + { + if (info != null) + this.fontRenderer.drawString("\u00a7n" + info, localWidth + 50, localHeight + 4, 0); + + GL11.glScalef(2f, 2f, 2f); + GL11.glEnable(GL12.GL_RESCALE_NORMAL); + RenderHelper.enableGUIStandardItemLighting(); + + renderitem.renderItemAndEffectIntoGUI(fontRenderer, mc.renderEngine, TConstructClientRegistry.getManualIcon("coal"), (localWidth + 38) / 2, (localHeight + 110) / 2); + renderitem.renderItemAndEffectIntoGUI(fontRenderer, mc.renderEngine, icons[0], (localWidth + 106) / 2, (localHeight + 74) / 2); + renderitem.renderItemAndEffectIntoGUI(fontRenderer, mc.renderEngine, icons[1], (localWidth + 38) / 2, (localHeight + 38) / 2); + /*for (int i = 0; i < icons.length - 1; i++) + { + if (icons[i + 1] != null) + renderitem.renderItemIntoGUI(fontRenderer, mc.renderEngine, icons[i + 1], (localWidth + 14 + 36 * (i % 2)) / 2, (localHeight + 36 * (i / 2) + 52) / 2); + }*/ + + if (icons[0].stackSize > 1) + renderitem.renderItemStack(fontRenderer, mc.renderEngine, icons[0], (localWidth + 106) / 2, (localHeight + 74) / 2, String.valueOf(icons[0].stackSize)); + + GL11.glScalef(0.5F, 0.5F, 0.5F); + RenderHelper.disableStandardItemLighting(); + GL11.glDisable(GL12.GL_RESCALE_NORMAL); + } + + public void drawMaterialPage (String title, ItemStack[] icons, String[] multiText, ToolMaterial material, int localWidth, int localHeight) + { + this.fontRenderer.drawString("\u00a7n" + title, localWidth + 70, localHeight + 4, 0); + this.fontRenderer.drawSplitString(multiText[0], localWidth, localHeight + 16, 178, 0); + + this.fontRenderer.drawString("Material: ", localWidth+108, localHeight + 40, 0); + this.fontRenderer.drawString("Shard: ", localWidth+108, localHeight + 72, 0); + this.fontRenderer.drawString("Rod: ", localWidth+108, localHeight + 104, 0); + + GL11.glEnable(GL12.GL_RESCALE_NORMAL); + RenderHelper.enableGUIStandardItemLighting(); + //renderitem.renderItemAndEffectIntoGUI(fontRenderer, mc.renderEngine, icons[0], localWidth + 50, localHeight + 0); + renderitem.renderItemAndEffectIntoGUI(fontRenderer, mc.renderEngine, icons[1], localWidth + 108, localHeight + 50); + renderitem.renderItemAndEffectIntoGUI(fontRenderer, mc.renderEngine, icons[2], localWidth + 108, localHeight + 82); + renderitem.renderItemAndEffectIntoGUI(fontRenderer, mc.renderEngine, icons[3], localWidth + 108, localHeight + 114); + RenderHelper.disableStandardItemLighting(); + GL11.glDisable(GL12.GL_RESCALE_NORMAL); + + this.fontRenderer.drawSplitString(icons[1].getTooltip(this.mc.thePlayer, false).get((0)).toString(), localWidth + 128, localHeight + 53, 52, 0); + this.fontRenderer.drawSplitString(icons[2].getTooltip(this.mc.thePlayer, false).get((0)).toString(), localWidth + 128, localHeight + 85, 52, 0); + this.fontRenderer.drawSplitString(icons[3].getTooltip(this.mc.thePlayer, false).get((0)).toString(), localWidth + 128, localHeight + 117, 52, 0); + + this.fontRenderer.drawString("Durability: " + material.durability(), localWidth, localHeight + 40, 0); + this.fontRenderer.drawString("Handle Modifier: " + material.handleDurability()+"x", localWidth, localHeight + 50, 0); + this.fontRenderer.drawString("Full Tool Durability: " + (int)(material.durability()*material.handleDurability()), localWidth, localHeight + 60, 0); + + this.fontRenderer.drawString("Mining Speed: " + material.toolSpeed()/100f, localWidth, localHeight + 80, 0); + this.fontRenderer.drawString("Harvest Level: " + material.harvestLevel()+" ("+PartCrafterGui.getHarvestLevelName(material.harvestLevel())+")", localWidth, localHeight + 90, 0); + int attack = material.attack(); + String heart = attack == 2 ? " Heart" : " Hearts"; + if (attack % 2 == 0) + this.fontRenderer.drawString("Base Attack: " + material.attack()/2 + heart, localWidth, localHeight + 100, 0); + else + this.fontRenderer.drawString("Base Attack: " + material.attack()/2f + heart, localWidth, localHeight + 100, 0); + + int offset = 0; + String ability = material.ability(); + if (!ability.equals("")) + { + this.fontRenderer.drawString("Material ability: " + material.ability(), localWidth, localHeight + 120 + 10*offset, 0); + offset++; + if (ability.equals("Writable")) + this.fontRenderer.drawString("+1 Modifiers", localWidth, localHeight + 120 + 10*offset, 0); + } + + if (material.reinforced() > 0) + { + this.fontRenderer.drawString("Material ability: Reinforced", localWidth, localHeight + 120 + 10*offset, 0); + offset++; + this.fontRenderer.drawString("Reinforced level: " + material.reinforced(), localWidth, localHeight + 120 + 10*offset, 0); + offset++; + } + + if (material.shoddy() > 0) + { + this.fontRenderer.drawString("Shoddy level: " + material.shoddy(), localWidth, localHeight + 120 + 10*offset, 0); + offset++; + } + else if (material.shoddy() < 0) + { + this.fontRenderer.drawString("Spiny level: " + -material.shoddy(), localWidth, localHeight + 120 + 10*offset, 0); + offset++; + } + } } diff --git a/mods/tinker/tconstruct/client/gui/PartCrafterGui.java b/mods/tinker/tconstruct/client/gui/PartCrafterGui.java index 7abc63e..c688eda 100644 --- a/mods/tinker/tconstruct/client/gui/PartCrafterGui.java +++ b/mods/tinker/tconstruct/client/gui/PartCrafterGui.java @@ -108,7 +108,7 @@ public class PartCrafterGui extends GuiContainer drawDefaultInformation(); } - String getHarvestLevelName (int num) + public static String getHarvestLevelName (int num) { switch (num) { diff --git a/mods/tinker/tconstruct/client/gui/ToolStationGui.java b/mods/tinker/tconstruct/client/gui/ToolStationGui.java index 9350adf..a7e6a28 100644 --- a/mods/tinker/tconstruct/client/gui/ToolStationGui.java +++ b/mods/tinker/tconstruct/client/gui/ToolStationGui.java @@ -168,8 +168,14 @@ public class ToolStationGui extends GuiContainer int maxDur = tags.getInteger("TotalDurability"); dur = maxDur - dur; fontRenderer.drawString("Durability: " + dur + "/" + maxDur, xSize + 8, 24, 0xffffff); - int damage = tags.getInteger("Attack"); - fontRenderer.drawString("Damage: " + damage, xSize + 8, 35, 0xffffff); + int attack = tags.getInteger("Attack"); + + String heart = attack == 2 ? " Heart" : " Hearts"; + if (attack % 2 == 0) + this.fontRenderer.drawString("Attack: " + attack/2 + heart, xSize + 8, 35, 0xffffff); + else + this.fontRenderer.drawString("Attack: " +attack/2f + heart, xSize + 8, 35, 0xffffff); + //fontRenderer.drawString("Attack: " + damage, xSize + 8, 35, 0xffffff); fontRenderer.drawString("Modifiers remaining: " + tags.getInteger("Modifiers"), xSize + 8, 57, 0xffffff); if (tags.hasKey("Tooltip1")) diff --git a/mods/tinker/tconstruct/crafting/PatternBuilder.java b/mods/tinker/tconstruct/crafting/PatternBuilder.java index 3b0b38d..4698872 100644 --- a/mods/tinker/tconstruct/crafting/PatternBuilder.java +++ b/mods/tinker/tconstruct/crafting/PatternBuilder.java @@ -146,6 +146,22 @@ public class PatternBuilder } return null; } + + public ItemStack getShardFromSet(String materialset) + { + MaterialSet set = (MaterialSet) materialSets.get(materialset); + if (set != null) + return set.shard.copy(); + return null; + } + + public ItemStack getRodFromSet(String materialset) + { + MaterialSet set = (MaterialSet) materialSets.get(materialset); + if (set != null) + return set.rod.copy(); + return null; + } //Small data classes. I would prefer the struct from C#, but we do what we can. public class ItemKey diff --git a/mods/tinker/tconstruct/entity/BlueSlime.java b/mods/tinker/tconstruct/entity/BlueSlime.java index 88a454a..668676d 100644 --- a/mods/tinker/tconstruct/entity/BlueSlime.java +++ b/mods/tinker/tconstruct/entity/BlueSlime.java @@ -92,6 +92,15 @@ public class BlueSlime extends EntityLiving implements IMob this.motionX -= (double) (MathHelper.sin(f) * 0.2F); this.motionZ += (double) (MathHelper.cos(f) * 0.2F); } + + if (this.getBrightness(1.0F) > 0.9F && rand.nextInt(5) == 0 && this.worldObj.canBlockSeeTheSky(MathHelper.floor_double(this.posX), MathHelper.floor_double(this.posY), MathHelper.floor_double(this.posZ))) + { + int size = this.getSlimeSize() - 1; + if (size <= 0) + this.kill(); + else + this.setSlimeSize(size); + } this.isAirBorne = true; ForgeHooks.onLivingJump(this); @@ -118,6 +127,11 @@ public class BlueSlime extends EntityLiving implements IMob int x = MathHelper.floor_double(this.posX); int y = MathHelper.floor_double(this.boundingBox.minY); int z = MathHelper.floor_double(this.posZ); + + if (y < 60 && rand.nextInt(5) != 0) + { + return false; + } if (this.worldObj.getSavedLightValue(EnumSkyBlock.Sky, x, y, z) > this.rand.nextInt(32)) { diff --git a/mods/tinker/tconstruct/items/PatternManual.java b/mods/tinker/tconstruct/items/PatternManual.java index 3036995..39c4af5 100644 --- a/mods/tinker/tconstruct/items/PatternManual.java +++ b/mods/tinker/tconstruct/items/PatternManual.java @@ -13,7 +13,7 @@ import net.minecraft.world.World; public class PatternManual extends CraftingItem { - static String[] name = new String[] { "diary", "toolstation", "smeltery" }; + static String[] name = new String[] { "beginner", "toolstation", "smeltery" }; static String[] textureName = new String[] { "tinkerbook_diary", "tinkerbook_toolstation", "tinkerbook_smeltery" }; public PatternManual(int id) { @@ -37,7 +37,7 @@ public class PatternManual extends CraftingItem switch (stack.getItemDamage()) { case 0: - list.add("\u00a7oBy: Unknown"); + list.add("\u00a7oBy: Skyla"); break; case 1: list.add("\u00a7oBy: Skyla"); diff --git a/mods/tinker/tconstruct/items/StrangeFood.java b/mods/tinker/tconstruct/items/StrangeFood.java index 24a98be..b45c550 100644 --- a/mods/tinker/tconstruct/items/StrangeFood.java +++ b/mods/tinker/tconstruct/items/StrangeFood.java @@ -11,7 +11,7 @@ public class StrangeFood extends SpecialFood { public StrangeFood(int id) { - super(id, new int[] { 1 }, new float[] { 1f }, new String[] { "edibleslime" }, new String[] { "edibleslime" }); + super(id, new int[] { 2 }, new float[] { 1f }, new String[] { "edibleslime" }, new String[] { "edibleslime" }); } @Override diff --git a/mods/tinker/tconstruct/library/AbilityHelper.java b/mods/tinker/tconstruct/library/AbilityHelper.java index 354f0a0..caa1eec 100644 --- a/mods/tinker/tconstruct/library/AbilityHelper.java +++ b/mods/tinker/tconstruct/library/AbilityHelper.java @@ -489,8 +489,9 @@ public class AbilityHelper if (!player.worldObj.isRemote) { EntityItem entityitem = new EntityItem(player.worldObj, player.posX + 0.5D, player.posY + 0.5D, player.posZ + 0.5D, stack); - entityitem.delayBeforeCanPickup = 10; + //entityitem.delayBeforeCanPickup = 10; player.worldObj.spawnEntityInWorld(entityitem); + entityitem.onCollideWithPlayer(player); } } } diff --git a/mods/tinker/tconstruct/library/TConstructRegistry.java b/mods/tinker/tconstruct/library/TConstructRegistry.java index 3d78ec7..cbfe6f6 100644 --- a/mods/tinker/tconstruct/library/TConstructRegistry.java +++ b/mods/tinker/tconstruct/library/TConstructRegistry.java @@ -14,7 +14,8 @@ public class TConstructRegistry { public static TConstructRegistry instance = new TConstructRegistry(); public static ArrayList tools = new ArrayList(20); - public static HashMap toolMaterials = new HashMap(60); + public static HashMap toolMaterials = new HashMap(40); + public static HashMap toolMaterialStrings = new HashMap(40); public static TabTools toolTab; public static TabTools materialTab; @@ -43,14 +44,21 @@ public class TConstructRegistry ToolMaterial mat = toolMaterials.get(materialID); if (mat == null) { - toolMaterials.put(materialID, new ToolMaterial(materialName, craftingTier, harvestLevel, durability, miningspeed, attack, handleModifier, reinforced, shoddy, style, ability)); + mat = new ToolMaterial(materialName, craftingTier, harvestLevel, durability, miningspeed, attack, handleModifier, reinforced, shoddy, style, ability); + toolMaterials.put(materialID, mat); + toolMaterialStrings.put(materialName, mat); } else - throw new RuntimeException("TConstruct material ID " + materialID + " is already occupied by " + mat.materialName); + throw new RuntimeException("[TConstruct] Material ID " + materialID + " is already occupied by " + mat.materialName); } public static ToolMaterial getMaterial (int key) { return (toolMaterials.get(key)); } + + public static ToolMaterial getMaterial (String key) + { + return (toolMaterialStrings.get(key)); + } } diff --git a/mods/tinker/tconstruct/library/ToolMaterial.java b/mods/tinker/tconstruct/library/ToolMaterial.java index 855e94f..c2ff1ef 100644 --- a/mods/tinker/tconstruct/library/ToolMaterial.java +++ b/mods/tinker/tconstruct/library/ToolMaterial.java @@ -7,7 +7,7 @@ public class ToolMaterial //mining level, durability, mining speed, baseDamage, handle modifier, Reinforced level, shoddy/spiny level, color/style on name public final String materialName; - public final int craftingTier; + public final int craftingTier; //Not used public final int harvestLevel; public final int durability; public final int miningspeed; // <-- divided by 100 diff --git a/mods/tinker/tconstruct/library/client/TConstructClientRegistry.java b/mods/tinker/tconstruct/library/client/TConstructClientRegistry.java index 277cbbf..09d9931 100644 --- a/mods/tinker/tconstruct/library/client/TConstructClientRegistry.java +++ b/mods/tinker/tconstruct/library/client/TConstructClientRegistry.java @@ -13,6 +13,7 @@ public class TConstructClientRegistry { public static ArrayList toolButtons = new ArrayList(20); public static Map manualIcons = new HashMap(); + public static Map recipeIcons = new HashMap(); public static ItemStack defaultStack = new ItemStack(Item.ingotIron); public static void addMaterialRenderMapping (int materialID, String domain, String renderName, boolean useDefaultFolder) @@ -49,12 +50,41 @@ public class TConstructClientRegistry manualIcons.put(name, stack); } - public static ItemStack getManualIcon (String textContent) + public static ItemStack getManualIcon (String textContent) + { + ItemStack stack = manualIcons.get(textContent); + if (stack != null) + return stack; + return defaultStack; + } + + public static void registerManualSmallRecipe(String name, ItemStack output, ItemStack... stacks) { - ItemStack stack = manualIcons.get(textContent); - if (stack != null) - return stack; - return defaultStack; + ItemStack[] recipe = new ItemStack[5]; + recipe[0] = output; + System.arraycopy(stacks, 0, recipe, 1, 4); + recipeIcons.put(name, recipe); + } + + public static void registerManualLargeRecipe(String name, ItemStack output, ItemStack... stacks) + { + ItemStack[] recipe = new ItemStack[10]; + recipe[0] = output; + System.arraycopy(stacks, 0, recipe, 1, 9); + recipeIcons.put(name, recipe); + } + + public static void registerManualFurnaceRecipe(String name, ItemStack output, ItemStack input) + { + ItemStack[] recipe = new ItemStack[2]; + recipe[0] = output; + recipe[1] = input; + recipeIcons.put(name, recipe); + } + + public static ItemStack[] getRecipeIcons(String recipeName) + { + return recipeIcons.get(recipeName); } //Gui diff --git a/mods/tinker/tconstruct/logic/CastingTableLogic.java b/mods/tinker/tconstruct/logic/CastingTableLogic.java index d2fee57..623a93e 100644 --- a/mods/tinker/tconstruct/logic/CastingTableLogic.java +++ b/mods/tinker/tconstruct/logic/CastingTableLogic.java @@ -1,6 +1,5 @@ package mods.tinker.tconstruct.logic; -import cpw.mods.fml.common.FMLLog; import mods.tinker.common.IPattern; import mods.tinker.common.InventoryLogic; import mods.tinker.tconstruct.TConstruct; @@ -8,6 +7,7 @@ import mods.tinker.tconstruct.crafting.CastingRecipe; import mods.tinker.tconstruct.crafting.LiquidCasting; import net.minecraft.entity.player.InventoryPlayer; import net.minecraft.inventory.Container; +import net.minecraft.inventory.ISidedInventory; import net.minecraft.item.ItemStack; import net.minecraft.nbt.NBTTagCompound; import net.minecraft.network.INetworkManager; @@ -19,7 +19,8 @@ import net.minecraftforge.liquids.ILiquidTank; import net.minecraftforge.liquids.ITankContainer; import net.minecraftforge.liquids.LiquidStack; -public class CastingTableLogic extends InventoryLogic implements ILiquidTank, ITankContainer +public class CastingTableLogic extends InventoryLogic + implements ILiquidTank, ITankContainer, ISidedInventory { public LiquidStack liquid; int castingDelay = 0; @@ -129,6 +130,20 @@ public class CastingTableLogic extends InventoryLogic implements ILiquidTank, IT return resource.amount; } } + + @Override + public void onInventoryChanged() + { + super.onInventoryChanged(); + worldObj.markBlockForRenderUpdate(xCoord, yCoord, zCoord); + } + + public ItemStack decrStackSize(int slot, int quantity) + { + ItemStack stack = super.decrStackSize(slot, quantity); + worldObj.markBlockForRenderUpdate(xCoord, yCoord, zCoord); + return stack; + } @Override public LiquidStack drain (int maxDrain, boolean doDrain) //Doesn't actually drain @@ -147,9 +162,9 @@ public class CastingTableLogic extends InventoryLogic implements ILiquidTank, IT @Override public int fill (ForgeDirection from, LiquidStack resource, boolean doFill) { - if (from == ForgeDirection.UP) + //if (from == ForgeDirection.UP) return fill(0, resource, doFill); - return 0; + //return 0; } @Override @@ -268,4 +283,29 @@ public class CastingTableLogic extends InventoryLogic implements ILiquidTank, IT worldObj.markBlockForRenderUpdate(xCoord, yCoord, zCoord); } + @Override + public int[] getSizeInventorySide (int var1) + { + return new int[] {1, 1, 1, 1, 1, 1, 1}; + } + + @Override + public boolean func_102007_a (int i, ItemStack itemstack, int j) + { + if (j == 0) + return false; + else + return true; + } + + @Override + public boolean func_102008_b (int i, ItemStack itemstack, int j) + { + /*if (j == 0) + return false; + else + return true;*/ + return true; + } + } diff --git a/mods/tinker/tconstruct/modifiers/ModAttack.java b/mods/tinker/tconstruct/modifiers/ModAttack.java new file mode 100644 index 0000000..eaeb052 --- /dev/null +++ b/mods/tinker/tconstruct/modifiers/ModAttack.java @@ -0,0 +1,100 @@ +package mods.tinker.tconstruct.modifiers; + +import mods.tinker.common.ToolMod; +import net.minecraft.item.ItemStack; +import net.minecraft.nbt.NBTTagCompound; + +public class ModAttack extends ToolMod +{ + String tooltipName; + int increase; + int max = 72; + String guiType; + + public ModAttack(String type, ItemStack[] items, int effect, int inc) + { + super(items, effect, "ModAttack"); + tooltipName = "\u00a7fSharpness"; + guiType = type; + increase = inc; + } + + @Override + protected boolean canModify (ItemStack tool, ItemStack[] input) + { + + NBTTagCompound tags = tool.getTagCompound().getCompoundTag("InfiTool"); + if (!tags.hasKey(key)) + return tags.getInteger("Modifiers") > 0; + + int keyPair[] = tags.getIntArray(key); + if (keyPair[0] + increase <= keyPair[1]) + return true; + + + else if (keyPair[0] == keyPair[1]) + return tags.getInteger("Modifiers") > 0; + + else + return false; + } + + @Override + public void modify (ItemStack[] input, ItemStack tool) + { + NBTTagCompound tags = tool.getTagCompound().getCompoundTag("InfiTool"); + if (tags.hasKey(key)) + { + int[] keyPair = tags.getIntArray(key); + + int leftToBoost = 36 - (keyPair[0] % 36); + if (increase >= leftToBoost) + { + int attack = tags.getInteger("Attack"); + attack += 1; + tags.setInteger("Attack", attack); + } + + if (keyPair[0] % max == 0) + { + keyPair[0] += increase; + keyPair[1] += max; + tags.setIntArray(key, keyPair); + + int modifiers = tags.getInteger("Modifiers"); + modifiers -= 1; + tags.setInteger("Modifiers", modifiers); + } + else + { + keyPair[0] += increase; + tags.setIntArray(key, keyPair); + } + updateModTag(tool, keyPair); + + + } + else + { + int modifiers = tags.getInteger("Modifiers"); + modifiers -= 1; + tags.setInteger("Modifiers", modifiers); + String modName = "\u00a7f"+guiType+" ("+increase+"/"+max+")"; + int tooltipIndex = addToolTip(tool, tooltipName, modName); + int[] keyPair = new int[] { increase, max, tooltipIndex }; + tags.setIntArray(key, keyPair); + + int attack = tags.getInteger("Attack"); + attack += 1; + tags.setInteger("Attack", attack); + } + } + + void updateModTag(ItemStack tool, int[] keys) + { + NBTTagCompound tags = tool.getTagCompound().getCompoundTag("InfiTool"); + String tip = "ModifierTip"+keys[2]; + String modName = "\u00a7f"+guiType+" ("+keys[0]+"/"+keys[1]+")"; + tags.setString(tip, modName); + } +} diff --git a/mods/tinker/tconstruct/modifiers/ModBlaze.java b/mods/tinker/tconstruct/modifiers/ModBlaze.java index 823654b..4e16fc3 100644 --- a/mods/tinker/tconstruct/modifiers/ModBlaze.java +++ b/mods/tinker/tconstruct/modifiers/ModBlaze.java @@ -41,7 +41,6 @@ public class ModBlaze extends ToolMod @Override public void modify (ItemStack[] input, ItemStack tool) { - //System.out.println("Moood"); NBTTagCompound tags = tool.getTagCompound().getCompoundTag("InfiTool"); if (tags.hasKey(key)) { @@ -76,7 +75,6 @@ public class ModBlaze extends ToolMod int fiery = tags.getInteger("Fiery"); fiery += (increase); - System.out.println("Fiery "+fiery); tags.setInteger("Fiery", fiery); } diff --git a/mods/tinker/tconstruct/modifiers/ModElectric.java b/mods/tinker/tconstruct/modifiers/ModElectric.java index 899ae4f..bc6ada7 100644 --- a/mods/tinker/tconstruct/modifiers/ModElectric.java +++ b/mods/tinker/tconstruct/modifiers/ModElectric.java @@ -1,7 +1,10 @@ package mods.tinker.tconstruct.modifiers; +import ic2.api.IElectricItem; + import java.util.ArrayList; +import mods.tinker.tconstruct.library.ToolCore; import net.minecraft.item.ItemStack; import net.minecraft.nbt.NBTTagCompound; @@ -34,8 +37,14 @@ public class ModElectric extends ModBoolean for (ItemStack stack : batteries) { - if (stack.isItemEqual(input[0]) || stack.isItemEqual(input[1])) - battery = true; + if (stack.itemID == input[0].itemID && input[0].getItem() instanceof IElectricItem) + { + battery = true; + } + if (stack.itemID == input[1].itemID && input[1].getItem() instanceof IElectricItem) + { + battery = true; + } } return circuit && battery && canModify(tool, input); } @@ -62,10 +71,16 @@ public class ModElectric extends ModBoolean int modifiers = tags.getCompoundTag("InfiTool").getInteger("Modifiers"); modifiers -= 1; tags.getCompoundTag("InfiTool").setInteger("Modifiers", modifiers); - tags.setInteger("charge", 0); - tags.setDouble("electricity", 0); + int charge = 0; + if (input[0].getItem() instanceof IElectricItem && input[0].hasTagCompound()) + charge = input[0].getTagCompound().getInteger("charge"); + if (input[1].getItem() instanceof IElectricItem && input[1].hasTagCompound()) + charge = input[1].getTagCompound().getInteger("charge"); + tags.setInteger("charge", charge); tags.setInteger(key, 1); addModifierTip(tool, "\u00a7eElectric"); + ToolCore toolcore = (ToolCore) tool.getItem(); + tool.setItemDamage(1 + (toolcore.getMaxCharge(tool) - charge) * (tool.getMaxDamage() - 1) / toolcore.getMaxCharge(tool)); } } } diff --git a/mods/tinker/tconstruct/modifiers/ModExtraModifier.java b/mods/tinker/tconstruct/modifiers/ModExtraModifier.java new file mode 100644 index 0000000..1e24652 --- /dev/null +++ b/mods/tinker/tconstruct/modifiers/ModExtraModifier.java @@ -0,0 +1,39 @@ +package mods.tinker.tconstruct.modifiers; + +import net.minecraft.item.ItemStack; +import net.minecraft.nbt.NBTTagCompound; +import mods.tinker.common.ToolMod; +import mods.tinker.tconstruct.crafting.PatternBuilder; + +public class ModExtraModifier extends ToolMod +{ + + public ModExtraModifier(ItemStack[] items, String dataKey) + { + super(items, 0, dataKey); + } + + @Override + protected boolean canModify (ItemStack tool, ItemStack[] input) + { + if ((input[0] == null && input[1] == null) || (input[0] != null && input[1] != null)) //Only valid for one itemstack + return false; + + NBTTagCompound tags = tool.getTagCompound().getCompoundTag("InfiTool"); + if (tags.getBoolean(key)) + { + return false; + } + return true; + } + + @Override + public void modify (ItemStack[] input, ItemStack tool) + { + NBTTagCompound tags = tool.getTagCompound().getCompoundTag("InfiTool"); + tags.setBoolean(key, true); + int modifiers = tags.getInteger("Modifiers"); + tags.setInteger("Modifiers", modifiers + 1); + } + +} diff --git a/mods/tinker/tconstruct/modifiers/ModLapis.java b/mods/tinker/tconstruct/modifiers/ModLapis.java index bd689e6..c04015f 100644 --- a/mods/tinker/tconstruct/modifiers/ModLapis.java +++ b/mods/tinker/tconstruct/modifiers/ModLapis.java @@ -43,34 +43,7 @@ public class ModLapis extends ToolMod public void modify (ItemStack[] input, ItemStack tool) { NBTTagCompound tags = tool.getTagCompound().getCompoundTag("InfiTool"); - if (tags.hasKey(key)) - { - - int keyPair[] = tags.getIntArray(key); - keyPair[0] += increase; - tags.setIntArray(key, keyPair); - if (tool.getItem() instanceof Weapon) - { - if (keyPair[0] >= 100) - addEnchantment(tool, Enchantment.looting, 3); - else if (keyPair[0] >= 50) - addEnchantment(tool, Enchantment.looting, 2); - else if (keyPair[0] >= 20) - addEnchantment(tool, Enchantment.looting, 1); - } - else - { - if (keyPair[0] >= 100) - addEnchantment(tool, Enchantment.fortune, 3); - else if (keyPair[0] >= 50) - addEnchantment(tool, Enchantment.fortune, 2); - else if (keyPair[0] >= 20) - addEnchantment(tool, Enchantment.fortune, 1); - } - - updateModTag(tool, keyPair); - } - else + if (!tags.hasKey(key)) { tags.setBoolean(key, true); @@ -83,6 +56,30 @@ public class ModLapis extends ToolMod modifiers -= 1; tags.setInteger("Modifiers", modifiers); } + + int keyPair[] = tags.getIntArray(key); + keyPair[0] += increase; + tags.setIntArray(key, keyPair); + if (tool.getItem() instanceof Weapon) + { + if (keyPair[0] >= 100) + addEnchantment(tool, Enchantment.looting, 3); + else if (keyPair[0] >= 50) + addEnchantment(tool, Enchantment.looting, 2); + else if (keyPair[0] >= 20) + addEnchantment(tool, Enchantment.looting, 1); + } + else + { + if (keyPair[0] >= 100) + addEnchantment(tool, Enchantment.fortune, 3); + else if (keyPair[0] >= 50) + addEnchantment(tool, Enchantment.fortune, 2); + else if (keyPair[0] >= 20) + addEnchantment(tool, Enchantment.fortune, 1); + } + + updateModTag(tool, keyPair); } public void addEnchantment(ItemStack tool, Enchantment enchant, int level) diff --git a/mods/tinker/tconstruct/modifiers/ModLapisBase.java b/mods/tinker/tconstruct/modifiers/ModLapisBase.java deleted file mode 100644 index 4bd89c7..0000000 --- a/mods/tinker/tconstruct/modifiers/ModLapisBase.java +++ /dev/null @@ -1,41 +0,0 @@ -package mods.tinker.tconstruct.modifiers; - -import mods.tinker.common.ToolMod; -import net.minecraft.item.ItemStack; -import net.minecraft.nbt.NBTTagCompound; - -/* Little mod for actually adding the lapis modifier */ - -public class ModLapisBase extends ToolMod -{ - public ModLapisBase(ItemStack[] items, int effect) - { - super(items, effect, "Lapis"); - } - - @Override - protected boolean canModify (ItemStack tool, ItemStack[] input) - { - NBTTagCompound tags = tool.getTagCompound().getCompoundTag("InfiTool"); - if (!tags.hasKey(key)) - return tags.getInteger("Modifiers") > 0; - - return false; - } - - @Override - public void modify (ItemStack[] input, ItemStack tool) - { - NBTTagCompound tags = tool.getTagCompound().getCompoundTag("InfiTool"); - tags.setBoolean(key, true); - - String modName = "\u00a79Lapis (0/100)"; - int tooltipIndex = addToolTip(tool, "\u00a79Luck", modName); - int[] keyPair = new int[] { 0, tooltipIndex }; - tags.setIntArray(key, keyPair); - - int modifiers = tags.getInteger("Modifiers"); - modifiers -= 1; - tags.setInteger("Modifiers", modifiers); - } -} diff --git a/mods/tinker/tconstruct/modifiers/ModLapisIncrease.java b/mods/tinker/tconstruct/modifiers/ModLapisIncrease.java deleted file mode 100644 index 2cb4d0b..0000000 --- a/mods/tinker/tconstruct/modifiers/ModLapisIncrease.java +++ /dev/null @@ -1,113 +0,0 @@ -package mods.tinker.tconstruct.modifiers; - -import java.util.Iterator; -import java.util.Map; - -import mods.tinker.common.ToolMod; -import mods.tinker.tconstruct.library.Weapon; -import net.minecraft.enchantment.Enchantment; -import net.minecraft.enchantment.EnchantmentHelper; -import net.minecraft.item.ItemStack; -import net.minecraft.nbt.NBTTagCompound; -import net.minecraft.nbt.NBTTagList; - -public class ModLapisIncrease extends ToolMod -{ - int increase; - - public ModLapisIncrease(ItemStack[] items, int effect, int inc) - { - super(items, effect, "Lapis"); - increase = inc; - } - - @Override - protected boolean canModify (ItemStack tool, ItemStack[] input) - { - NBTTagCompound tags = tool.getTagCompound().getCompoundTag("InfiTool"); - if (!tags.hasKey(key)) - return false; - - int keyPair[] = tags.getIntArray(key); - - if (keyPair[0] + increase <= 100) - return true; - else - return false; - - } - - @Override - public void modify (ItemStack[] input, ItemStack tool) - { - NBTTagCompound tags = tool.getTagCompound().getCompoundTag("InfiTool"); - int keyPair[] = tags.getIntArray(key); - keyPair[0] += increase; - tags.setIntArray(key, keyPair); - if (tool.getItem() instanceof Weapon) - { - if (keyPair[0] >= 100) - addEnchantment(tool, Enchantment.looting, 3); - else if (keyPair[0] >= 40) - addEnchantment(tool, Enchantment.looting, 2); - else if (keyPair[0] >= 10) - addEnchantment(tool, Enchantment.looting, 1); - } - else - { - if (keyPair[0] >= 100) - addEnchantment(tool, Enchantment.fortune, 3); - else if (keyPair[0] >= 40) - addEnchantment(tool, Enchantment.fortune, 2); - else if (keyPair[0] >= 10) - addEnchantment(tool, Enchantment.fortune, 1); - } - - updateModTag(tool, keyPair); - } - - public void addEnchantment(ItemStack tool, Enchantment enchant, int level) - { - NBTTagList tags = new NBTTagList("ench"); - Map enchantMap = EnchantmentHelper.getEnchantments(tool); - Iterator iterator = enchantMap.keySet().iterator(); - int index; - int lvl; - boolean hasEnchant = false; - while (iterator.hasNext()) - { - NBTTagCompound enchantTag = new NBTTagCompound(); - index = ((Integer)iterator.next()).intValue(); - lvl = (Integer) enchantMap.get(index); - if (index == enchant.effectId) - { - hasEnchant = true; - enchantTag.setShort("id", (short)index); - enchantTag.setShort("lvl", (short)((byte)level)); - tags.appendTag(enchantTag); - } - else - { - enchantTag.setShort("id", (short)index); - enchantTag.setShort("lvl", (short)((byte)lvl)); - tags.appendTag(enchantTag); - } - } - if (!hasEnchant) - { - NBTTagCompound enchantTag = new NBTTagCompound(); - enchantTag.setShort("id", (short)enchant.effectId); - enchantTag.setShort("lvl", (short)((byte)level)); - tags.appendTag(enchantTag); - } - tool.stackTagCompound.setTag("ench", tags); - } - - void updateModTag (ItemStack tool, int[] keys) - { - NBTTagCompound tags = tool.getTagCompound().getCompoundTag("InfiTool"); - String tip = "ModifierTip"+keys[1]; - String modName = "\u00a79Lapis ("+keys[0]+"/100)"; - tags.setString(tip, modName); - } -} diff --git a/mods/tinker/tconstruct/modifiers/ModPotion.java b/mods/tinker/tconstruct/modifiers/ModPotion.java new file mode 100644 index 0000000..ee7252d --- /dev/null +++ b/mods/tinker/tconstruct/modifiers/ModPotion.java @@ -0,0 +1,32 @@ +package mods.tinker.tconstruct.modifiers; + +import mods.tinker.common.ToolMod; +import net.minecraft.item.Item; +import net.minecraft.item.ItemStack; +import net.minecraft.nbt.NBTTagCompound; + +public class ModPotion extends ToolMod +{ + + public ModPotion(ItemStack[] items, int effect, String dataKey) + { + super(new ItemStack[] { new ItemStack(Item.potion, 1, Short.MAX_VALUE) }, 0, ""); + } + + protected boolean canModify (ItemStack tool, ItemStack[] input) + { + NBTTagCompound tags = tool.getTagCompound().getCompoundTag("InfiTool"); + NBTTagCompound potion = tool.getTagCompound().getCompoundTag("Potion"); + if (potion == null) + return true; + + return false; + } + + @Override + public void modify (ItemStack[] input, ItemStack tool) + { + + } + +} diff --git a/mods/tinker/tconstruct/modifiers/ModRedstone.java b/mods/tinker/tconstruct/modifiers/ModRedstone.java index 991b535..7dbc3c5 100644 --- a/mods/tinker/tconstruct/modifiers/ModRedstone.java +++ b/mods/tinker/tconstruct/modifiers/ModRedstone.java @@ -45,7 +45,7 @@ public class ModRedstone extends ToolMod if (tags.hasKey(key)) { int[] keyPair = tags.getIntArray(key); - if (keyPair[0] == max) + if (keyPair[0] % max == 0) { keyPair[0] += increase; keyPair[1] += max; diff --git a/mods/tinker/tconstruct/player/TPlayerHandler.java b/mods/tinker/tconstruct/player/TPlayerHandler.java index a54d306..57d3922 100644 --- a/mods/tinker/tconstruct/player/TPlayerHandler.java +++ b/mods/tinker/tconstruct/player/TPlayerHandler.java @@ -45,12 +45,12 @@ public class TPlayerHandler implements IPlayerTracker stats.level = entityplayer.experienceLevel; stats.health = 20; //More hp in the future stats.hunger = entityplayer.getFoodStats().getFoodLevel(); - stats.diary = tags.getCompoundTag("TConstruct").getBoolean("diary"); - stats.stationManual = tags.getCompoundTag("TConstruct").getBoolean("stationManual"); + stats.beginnerManual = tags.getCompoundTag("TConstruct").getBoolean("beginnerManual"); + stats.materialManual = tags.getCompoundTag("TConstruct").getBoolean("materialManual"); stats.smelteryManual = tags.getCompoundTag("TConstruct").getBoolean("smelteryManual"); - if (!stats.diary) + if (!stats.beginnerManual) { - tags.getCompoundTag("TConstruct").setBoolean("diary", true); + tags.getCompoundTag("TConstruct").setBoolean("beginnerManual", true); ItemStack diary = new ItemStack(TContent.manualBook); if (!entityplayer.inventory.addItemStackToInventory(diary)) { @@ -87,8 +87,8 @@ public class TPlayerHandler implements IPlayerTracker entityplayer.getFoodStats().addStats(-1*(20 - stats.hunger), 0); NBTTagCompound tags = entityplayer.getEntityData(); NBTTagCompound tTag = new NBTTagCompound(); - tTag.setBoolean("diary", stats.diary); - tTag.setBoolean("stationManual", stats.stationManual); + tTag.setBoolean("beginnerManual", stats.beginnerManual); + tTag.setBoolean("materialManual", stats.materialManual); tTag.setBoolean("smelteryManual", stats.smelteryManual); tags.setCompoundTag("TConstruct", tTag); diff --git a/mods/tinker/tconstruct/player/TPlayerStats.java b/mods/tinker/tconstruct/player/TPlayerStats.java index 6c377c8..203d8a7 100644 --- a/mods/tinker/tconstruct/player/TPlayerStats.java +++ b/mods/tinker/tconstruct/player/TPlayerStats.java @@ -10,8 +10,8 @@ public class TPlayerStats public int level; public int health; public int hunger; - public boolean diary; - public boolean stationManual; + public boolean beginnerManual; + public boolean materialManual; public boolean smelteryManual; //public boolean prevOnGround; diff --git a/mods/tinker/tconstruct/tools/Pickaxe.java b/mods/tinker/tconstruct/tools/Pickaxe.java index b50cd8d..b2b095b 100644 --- a/mods/tinker/tconstruct/tools/Pickaxe.java +++ b/mods/tinker/tconstruct/tools/Pickaxe.java @@ -31,7 +31,7 @@ public class Pickaxe extends HarvestTool return materials; } - static Material[] materials = new Material[] { Material.rock, Material.iron, Material.ice, Material.glass, Material.piston, Material.anvil }; + static Material[] materials = new Material[] { Material.rock, Material.iron, Material.ice, Material.glass, Material.piston, Material.anvil, Material.circuits }; @Override protected Item getHeadItem () diff --git a/mods/tinker/tconstruct/worldgen/TBaseWorldGenerator.java b/mods/tinker/tconstruct/worldgen/TBaseWorldGenerator.java index 87dba27..8d65440 100644 --- a/mods/tinker/tconstruct/worldgen/TBaseWorldGenerator.java +++ b/mods/tinker/tconstruct/worldgen/TBaseWorldGenerator.java @@ -75,7 +75,7 @@ public class TBaseWorldGenerator { if (PHConstruct.generateCobalt) { - xPos = xChunk + random.nextInt(16); yPos = random.nextInt(64); zPos = zChunk + random.nextInt(16); + xPos = xChunk + random.nextInt(16); yPos = random.nextInt(64)+32; zPos = zChunk + random.nextInt(16); cobalt.generate(world, random, xPos, yPos, zPos); } if (PHConstruct.generateArdite) diff --git a/mods/tinker/textures/blocks/torch_stone.png b/mods/tinker/textures/blocks/torch_stone.png new file mode 100644 index 0000000..5c845fe Binary files /dev/null and b/mods/tinker/textures/blocks/torch_stone.png differ diff --git a/mods/tinker/textures/gui/bookcrafting.png b/mods/tinker/textures/gui/bookcrafting.png new file mode 100644 index 0000000..dad3239 Binary files /dev/null and b/mods/tinker/textures/gui/bookcrafting.png differ diff --git a/mods/tinker/textures/gui/bookfurnace.png b/mods/tinker/textures/gui/bookfurnace.png new file mode 100644 index 0000000..9356944 Binary files /dev/null and b/mods/tinker/textures/gui/bookfurnace.png differ diff --git a/mods/tinker/textures/gui/bookright.png b/mods/tinker/textures/gui/bookright.png index b0f4efe..599f17b 100644 Binary files a/mods/tinker/textures/gui/bookright.png and b/mods/tinker/textures/gui/bookright.png differ diff --git a/mods/tinker/textures/items/axe/quartz_axe_effect.png b/mods/tinker/textures/items/axe/quartz_axe_effect.png new file mode 100644 index 0000000..1cc66e1 Binary files /dev/null and b/mods/tinker/textures/items/axe/quartz_axe_effect.png differ diff --git a/mods/tinker/textures/items/battlesign/quartz_battlesign_effect.png b/mods/tinker/textures/items/battlesign/quartz_battlesign_effect.png new file mode 100644 index 0000000..066df53 Binary files /dev/null and b/mods/tinker/textures/items/battlesign/quartz_battlesign_effect.png differ diff --git a/mods/tinker/textures/items/broadsword/quartz_sword_effect.png b/mods/tinker/textures/items/broadsword/quartz_sword_effect.png new file mode 100644 index 0000000..79ee033 Binary files /dev/null and b/mods/tinker/textures/items/broadsword/quartz_sword_effect.png differ diff --git a/mods/tinker/textures/items/frypan/quartz_frypan_effect.png b/mods/tinker/textures/items/frypan/quartz_frypan_effect.png new file mode 100644 index 0000000..db9c0b9 Binary files /dev/null and b/mods/tinker/textures/items/frypan/quartz_frypan_effect.png differ diff --git a/mods/tinker/textures/items/longsword/quartz_longsword_effect.png b/mods/tinker/textures/items/longsword/quartz_longsword_effect.png new file mode 100644 index 0000000..fb8e104 Binary files /dev/null and b/mods/tinker/textures/items/longsword/quartz_longsword_effect.png differ diff --git a/mods/tinker/textures/items/materials/material_fancydiamond.png b/mods/tinker/textures/items/materials/material_fancydiamond.png new file mode 100644 index 0000000..b559100 Binary files /dev/null and b/mods/tinker/textures/items/materials/material_fancydiamond.png differ diff --git a/mods/tinker/textures/items/materials/material_obsidianingot.png b/mods/tinker/textures/items/materials/material_obsidianingot.png new file mode 100644 index 0000000..6c2f42f Binary files /dev/null and b/mods/tinker/textures/items/materials/material_obsidianingot.png differ diff --git a/mods/tinker/textures/items/mattock/alumite_mattock_back.png b/mods/tinker/textures/items/mattock/alumite_mattock_back.png index b2c130c..d97146f 100644 Binary files a/mods/tinker/textures/items/mattock/alumite_mattock_back.png and b/mods/tinker/textures/items/mattock/alumite_mattock_back.png differ diff --git a/mods/tinker/textures/items/mattock/quartz_mattock_effect.png b/mods/tinker/textures/items/mattock/quartz_mattock_effect.png new file mode 100644 index 0000000..5ae6fcc Binary files /dev/null and b/mods/tinker/textures/items/mattock/quartz_mattock_effect.png differ diff --git a/mods/tinker/textures/items/pickaxe/diamond_pickaxe_effect.png b/mods/tinker/textures/items/pickaxe/diamond_pickaxe_effect.png index 2592c2d..35eaf18 100644 Binary files a/mods/tinker/textures/items/pickaxe/diamond_pickaxe_effect.png and b/mods/tinker/textures/items/pickaxe/diamond_pickaxe_effect.png differ diff --git a/mods/tinker/textures/items/pickaxe/quartz_pickaxe_effect.png b/mods/tinker/textures/items/pickaxe/quartz_pickaxe_effect.png new file mode 100644 index 0000000..5fc67b4 Binary files /dev/null and b/mods/tinker/textures/items/pickaxe/quartz_pickaxe_effect.png differ diff --git a/mods/tinker/textures/items/rapier/quartz_rapier_effect.png b/mods/tinker/textures/items/rapier/quartz_rapier_effect.png new file mode 100644 index 0000000..6dda46e Binary files /dev/null and b/mods/tinker/textures/items/rapier/quartz_rapier_effect.png differ diff --git a/mods/tinker/textures/items/shovel/quartz_shovel_effect.png b/mods/tinker/textures/items/shovel/quartz_shovel_effect.png new file mode 100644 index 0000000..f9f5dc3 Binary files /dev/null and b/mods/tinker/textures/items/shovel/quartz_shovel_effect.png differ