summaryrefslogtreecommitdiff
path: root/common
diff options
context:
space:
mode:
authorOnyxDarkKnight <sor1n.iliutza16@gmail.com>2013-12-15 17:38:52 +0200
committerOnyxDarkKnight <sor1n.iliutza16@gmail.com>2013-12-15 17:38:52 +0200
commit3e7036bf39c640b9d0dd94115f8b1f7947d26f71 (patch)
tree191f16ae53a9a5fb854a5f573f4496e7ae690a10 /common
parent06415dc21d71e8ac363dae5c56c5317971f7aede (diff)
Added the molder
Diffstat (limited to 'common')
-rw-r--r--common/darkknight/jewelrycraft/block/BlockList.java5
-rw-r--r--common/darkknight/jewelrycraft/block/BlockMolder.java31
-rw-r--r--common/darkknight/jewelrycraft/model/ModelMolder.java137
-rw-r--r--common/darkknight/jewelrycraft/renders/TileEntityMolderRender.java50
-rw-r--r--common/darkknight/jewelrycraft/tileentity/TileEntityMolder.java64
5 files changed, 215 insertions, 72 deletions
diff --git a/common/darkknight/jewelrycraft/block/BlockList.java b/common/darkknight/jewelrycraft/block/BlockList.java
index e29287d..f783d84 100644
--- a/common/darkknight/jewelrycraft/block/BlockList.java
+++ b/common/darkknight/jewelrycraft/block/BlockList.java
@@ -7,7 +7,9 @@ import cpw.mods.fml.common.event.FMLPreInitializationEvent;
import cpw.mods.fml.common.registry.GameRegistry;
import darkknight.jewelrycraft.JewelrycraftMod;
import darkknight.jewelrycraft.config.ConfigHandler;
+import darkknight.jewelrycraft.renders.TileEntityMolderRender;
import darkknight.jewelrycraft.renders.TileEntitySmelterRender;
+import darkknight.jewelrycraft.tileentity.TileEntityMolder;
import darkknight.jewelrycraft.tileentity.TileEntitySmelter;
public class BlockList
@@ -34,7 +36,10 @@ public class BlockList
GameRegistry.registerBlock(jewelCraftingTable, "jewelCraftingTable");
GameRegistry.registerTileEntity(TileEntitySmelter.class, "30");
+ GameRegistry.registerTileEntity(TileEntityMolder.class, "31");
+
ClientRegistry.bindTileEntitySpecialRenderer(TileEntitySmelter.class, new TileEntitySmelterRender());
+ ClientRegistry.bindTileEntitySpecialRenderer(TileEntityMolder.class, new TileEntityMolderRender());
}
}
}
diff --git a/common/darkknight/jewelrycraft/block/BlockMolder.java b/common/darkknight/jewelrycraft/block/BlockMolder.java
index 05b7b0a..1292f2a 100644
--- a/common/darkknight/jewelrycraft/block/BlockMolder.java
+++ b/common/darkknight/jewelrycraft/block/BlockMolder.java
@@ -3,7 +3,10 @@ package darkknight.jewelrycraft.block;
import darkknight.jewelrycraft.tileentity.TileEntityMolder;
import net.minecraft.block.BlockContainer;
import net.minecraft.block.material.Material;
+import net.minecraft.client.renderer.texture.IconRegister;
+import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.tileentity.TileEntity;
+import net.minecraft.world.IBlockAccess;
import net.minecraft.world.World;
public class BlockMolder extends BlockContainer
@@ -11,6 +14,7 @@ public class BlockMolder extends BlockContainer
protected BlockMolder(int par1, Material par2Material)
{
super(par1, par2Material);
+ this.setBlockBounds(0.1F, 0F, 0.1F, 0.9F, 0.2F, 0.9F);
}
@Override
@@ -24,4 +28,31 @@ public class BlockMolder extends BlockContainer
{
return false;
}
+
+ @Override
+ public boolean onBlockActivated(World world, int i, int j, int k, EntityPlayer entityPlayer, int par6, float par7, float par8, float par9)
+ {
+ TileEntityMolder te = (TileEntityMolder) world.getBlockTileEntity(i, j, k);
+ return true;
+ }
+ public boolean shouldSideBeRendered(IBlockAccess iblockaccess, int i, int j, int k, int l)
+ {
+ return false;
+ }
+
+ public boolean isOpaqueCube()
+ {
+ return false;
+ }
+
+ @Override
+ public int getRenderType()
+ {
+ return -1;
+ }
+
+ public void registerIcons(IconRegister icon)
+ {
+ this.blockIcon = icon.registerIcon("jewelrycraft:molder");
+ }
}
diff --git a/common/darkknight/jewelrycraft/model/ModelMolder.java b/common/darkknight/jewelrycraft/model/ModelMolder.java
index 3c89e7d..172d593 100644
--- a/common/darkknight/jewelrycraft/model/ModelMolder.java
+++ b/common/darkknight/jewelrycraft/model/ModelMolder.java
@@ -1,83 +1,76 @@
-// Date: 12/15/2013 4:51:25 PM
-// Template version 1.1
-// Java generated by Techne
-// Keep in mind that you still need to fill in some blanks
-// - ZeuX
+package darkknight.jewelrycraft.model;
-
-
-
-
-
-package net.minecraft.src;
+import net.minecraft.client.model.ModelBase;
+import net.minecraft.client.model.ModelRenderer;
+import net.minecraft.entity.Entity;
public class ModelMolder extends ModelBase
{
- //fields
+ //fields
ModelRenderer Base;
ModelRenderer Side;
ModelRenderer Side1;
ModelRenderer Side2;
ModelRenderer Side3;
-
- public ModelMolder()
- {
- textureWidth = 64;
- textureHeight = 32;
-
- Base = new ModelRenderer(this, 0, 0);
- Base.addBox(0F, 0F, 0F, 10, 1, 10);
- Base.setRotationPoint(-5F, 23F, -5F);
- Base.setTextureSize(64, 32);
- Base.mirror = true;
- setRotation(Base, 0F, 0F, 0F);
- Side = new ModelRenderer(this, 0, 13);
- Side.addBox(0F, 0F, 0F, 10, 2, 1);
- Side.setRotationPoint(-5F, 21F, 5F);
- Side.setTextureSize(64, 32);
- Side.mirror = true;
- setRotation(Side, 0F, 0F, 0F);
- Side1 = new ModelRenderer(this, 0, 13);
- Side1.addBox(0F, 0F, 0F, 10, 2, 1);
- Side1.setRotationPoint(-5F, 21F, -6F);
- Side1.setTextureSize(64, 32);
- Side1.mirror = true;
- setRotation(Side1, 0F, 0F, 0F);
- Side2 = new ModelRenderer(this, 41, 0);
- Side2.addBox(0F, 0F, 0F, 1, 2, 10);
- Side2.setRotationPoint(-6F, 21F, -5F);
- Side2.setTextureSize(64, 32);
- Side2.mirror = true;
- setRotation(Side2, 0F, 0F, 0F);
- Side3 = new ModelRenderer(this, 41, 0);
- Side3.addBox(0F, 0F, 0F, 1, 2, 10);
- Side3.setRotationPoint(5F, 21F, -5F);
- Side3.setTextureSize(64, 32);
- Side3.mirror = true;
- setRotation(Side3, 0F, 0F, 0F);
- }
-
- public void render(Entity entity, float f, float f1, float f2, float f3, float f4, float f5)
- {
- super.render(entity, f, f1, f2, f3, f4, f5);
- setRotationAngles(f, f1, f2, f3, f4, f5);
- Base.render(f5);
- Side.render(f5);
- Side1.render(f5);
- Side2.render(f5);
- Side3.render(f5);
- }
-
- private void setRotation(ModelRenderer model, float x, float y, float z)
- {
- model.rotateAngleX = x;
- model.rotateAngleY = y;
- model.rotateAngleZ = z;
- }
-
- public void setRotationAngles(float f, float f1, float f2, float f3, float f4, float f5)
- {
- super.setRotationAngles(f, f1, f2, f3, f4, f5);
- }
+
+ public ModelMolder()
+ {
+ textureWidth = 64;
+ textureHeight = 32;
+
+ Base = new ModelRenderer(this, 0, 0);
+ Base.addBox(0F, 0F, 0F, 10, 1, 10);
+ Base.setRotationPoint(-5F, 23F, -5F);
+ Base.setTextureSize(64, 32);
+ Base.mirror = true;
+ setRotation(Base, 0F, 0F, 0F);
+ Side = new ModelRenderer(this, 0, 13);
+ Side.addBox(0F, 0F, 0F, 10, 2, 1);
+ Side.setRotationPoint(-5F, 21F, 5F);
+ Side.setTextureSize(64, 32);
+ Side.mirror = true;
+ setRotation(Side, 0F, 0F, 0F);
+ Side1 = new ModelRenderer(this, 0, 13);
+ Side1.addBox(0F, 0F, 0F, 10, 2, 1);
+ Side1.setRotationPoint(-5F, 21F, -6F);
+ Side1.setTextureSize(64, 32);
+ Side1.mirror = true;
+ setRotation(Side1, 0F, 0F, 0F);
+ Side2 = new ModelRenderer(this, 41, 0);
+ Side2.addBox(0F, 0F, 0F, 1, 2, 10);
+ Side2.setRotationPoint(-6F, 21F, -5F);
+ Side2.setTextureSize(64, 32);
+ Side2.mirror = true;
+ setRotation(Side2, 0F, 0F, 0F);
+ Side3 = new ModelRenderer(this, 41, 0);
+ Side3.addBox(0F, 0F, 0F, 1, 2, 10);
+ Side3.setRotationPoint(5F, 21F, -5F);
+ Side3.setTextureSize(64, 32);
+ Side3.mirror = true;
+ setRotation(Side3, 0F, 0F, 0F);
+ }
+
+ public void render(Entity entity, float f, float f1, float f2, float f3, float f4, float f5)
+ {
+ super.render(entity, f, f1, f2, f3, f4, f5);
+ setRotationAngles(f, f1, f2, f3, f4, f5);
+ Base.render(f5);
+ Side.render(f5);
+ Side1.render(f5);
+ Side2.render(f5);
+ Side3.render(f5);
+ }
+
+ private void setRotation(ModelRenderer model, float x, float y, float z)
+ {
+ model.rotateAngleX = x;
+ model.rotateAngleY = y;
+ model.rotateAngleZ = z;
+ }
+
+ public void setRotationAngles(float f, float f1, float f2, float f3, float f4, float f5)
+ {
+ super.setRotationAngles(f, f1, f2, f3, f4, f5, null);
+ }
}
diff --git a/common/darkknight/jewelrycraft/renders/TileEntityMolderRender.java b/common/darkknight/jewelrycraft/renders/TileEntityMolderRender.java
new file mode 100644
index 0000000..12a54a7
--- /dev/null
+++ b/common/darkknight/jewelrycraft/renders/TileEntityMolderRender.java
@@ -0,0 +1,50 @@
+package darkknight.jewelrycraft.renders;
+
+import org.lwjgl.opengl.GL11;
+
+import darkknight.jewelrycraft.model.ModelMolder;
+
+import net.minecraft.block.Block;
+import net.minecraft.client.Minecraft;
+import net.minecraft.client.renderer.OpenGlHelper;
+import net.minecraft.client.renderer.Tessellator;
+import net.minecraft.client.renderer.tileentity.TileEntitySpecialRenderer;
+import net.minecraft.entity.Entity;
+import net.minecraft.tileentity.TileEntity;
+import net.minecraft.util.ResourceLocation;
+import net.minecraft.world.World;
+
+public class TileEntityMolderRender extends TileEntitySpecialRenderer
+{
+ ModelMolder modelMolder = new ModelMolder();
+ String texture = "textures/tileentities/Molder.png";
+
+ @Override
+ public void renderTileEntityAt (TileEntity te, double x, double y, double z, float scale)
+ {
+ GL11.glPushMatrix();
+ GL11.glTranslatef((float) x + 0.5F, (float) y + 1.5F, (float) z + 0.5F);
+
+ ResourceLocation blockTexture = new ResourceLocation("jewelrycraft", texture);
+ Minecraft.getMinecraft().renderEngine.bindTexture(blockTexture);
+
+ GL11.glPushMatrix();
+ GL11.glRotatef(180F, 0.0F, 0.0F, 1.0F);
+ modelMolder.render((Entity)null, 0.0F, 0.0F, -0.1F, 0.0F, 0.0F, 0.0625F);
+ GL11.glPopMatrix();
+ GL11.glPopMatrix();
+ }
+
+ public void adjustLightFixture (World world, int i, int j, int k, Block block)
+ {
+ Tessellator tess = Tessellator.instance;
+ float brightness = block.getBlockBrightness(world, i, j, k);
+ int skyLight = world.getLightBrightnessForSkyBlocks(i, j, k, 0);
+ int modulousModifier = skyLight % 65536;
+ int divModifier = skyLight / 65536;
+ tess.setColorOpaque_F(brightness, brightness, brightness);
+ OpenGlHelper.setLightmapTextureCoords(OpenGlHelper.lightmapTexUnit, (float) modulousModifier, divModifier);
+ }
+
+
+}
diff --git a/common/darkknight/jewelrycraft/tileentity/TileEntityMolder.java b/common/darkknight/jewelrycraft/tileentity/TileEntityMolder.java
index fbf7203..e3f30cc 100644
--- a/common/darkknight/jewelrycraft/tileentity/TileEntityMolder.java
+++ b/common/darkknight/jewelrycraft/tileentity/TileEntityMolder.java
@@ -1,8 +1,72 @@
package darkknight.jewelrycraft.tileentity;
+import net.minecraft.item.ItemStack;
+import net.minecraft.nbt.NBTTagCompound;
+import net.minecraft.network.packet.Packet;
+import net.minecraft.network.packet.Packet132TileEntityData;
import net.minecraft.tileentity.TileEntity;
public class TileEntityMolder extends TileEntity
{
+ public int jewelBaseID, moltenMetalID, cooling;
+ public boolean hasMoltenMetal, hasJewelBase;
+ public ItemStack metal;
+ public TileEntityMolder()
+ {
+ this.moltenMetalID = 0;
+ this.jewelBaseID = 0;
+ this.cooling = 0;
+ this.hasJewelBase = false;
+ this.hasMoltenMetal= false;
+ }
+
+ @Override
+ public void writeToNBT(NBTTagCompound par1)
+ {
+ super.writeToNBT(par1);
+ par1.setInteger("moltenMetalID", moltenMetalID);
+ par1.setInteger("jewelBaseID", jewelBaseID);
+ par1.setInteger("cooling", cooling);
+ par1.setBoolean("hasJewelBase", hasJewelBase);
+ par1.setBoolean("hasMoltenMetal", hasMoltenMetal);
+ }
+
+ @Override
+ public void readFromNBT(NBTTagCompound par1)
+ {
+ super.readFromNBT(par1);
+ this.moltenMetalID = par1.getInteger("moltenMetalID");
+ this.jewelBaseID = par1.getInteger("jewelBaseID");
+ this.cooling = par1.getInteger("cooling");
+ this.hasJewelBase = par1.getBoolean("hasJewelBase");
+ this.hasMoltenMetal = par1.getBoolean("hasMoltenMetal");
+ }
+
+ public void updateEntity()
+ {
+ super.updateEntity();
+ if(this.hasMoltenMetal && !this.hasJewelBase)
+ {
+ while(cooling > 0)
+ {
+ this.cooling--;
+ System.out.println(cooling);
+ }
+ if(cooling == 0)
+ {
+ this.hasMoltenMetal = false;
+ this.jewelBaseID = moltenMetalID;
+ this.moltenMetalID = 0;
+ this.hasMoltenMetal = true;
+ }
+ }
+ }
+
+ public Packet getDescriptionPacket()
+ {
+ NBTTagCompound nbtTag = new NBTTagCompound();
+ this.writeToNBT(nbtTag);
+ return new Packet132TileEntityData(this.xCoord, this.yCoord, this.zCoord, 1, nbtTag);
+ }
}