summaryrefslogtreecommitdiff
path: root/src/main/java/darkknight/jewelrycraft/tileentity/TileEntityDisplayer.java
diff options
context:
space:
mode:
authorOnyxDarkKnight <sor1n.iliutza16@gmail.com>2014-04-15 23:05:32 +0300
committerOnyxDarkKnight <sor1n.iliutza16@gmail.com>2014-04-15 23:05:32 +0300
commit256653501365eb4f95d3dddbcdfdc23a2a9594d5 (patch)
tree682c8ff1f943936d173299acfa42e77462eb297c /src/main/java/darkknight/jewelrycraft/tileentity/TileEntityDisplayer.java
parent4b8b13b34d7a8fd0ee7c7b13f11be9c2bf3b5d18 (diff)
Moved source files
Diffstat (limited to 'src/main/java/darkknight/jewelrycraft/tileentity/TileEntityDisplayer.java')
-rw-r--r--src/main/java/darkknight/jewelrycraft/tileentity/TileEntityDisplayer.java108
1 files changed, 108 insertions, 0 deletions
diff --git a/src/main/java/darkknight/jewelrycraft/tileentity/TileEntityDisplayer.java b/src/main/java/darkknight/jewelrycraft/tileentity/TileEntityDisplayer.java
new file mode 100644
index 0000000..35def5c
--- /dev/null
+++ b/src/main/java/darkknight/jewelrycraft/tileentity/TileEntityDisplayer.java
@@ -0,0 +1,108 @@
+package darkknight.jewelrycraft.tileentity;
+
+import net.minecraft.item.Item;
+import net.minecraft.item.ItemStack;
+import net.minecraft.nbt.NBTTagCompound;
+import net.minecraft.network.NetworkManager;
+import net.minecraft.network.Packet;
+import net.minecraft.network.play.server.S35PacketUpdateTileEntity;
+import net.minecraft.tileentity.TileEntity;
+
+public class TileEntityDisplayer extends TileEntity
+{
+ public float ringTranslation1, ringTranslation2, ringTranslation3, rotAngle;
+ public boolean isDescending1, isDescending2, isDescending3, isDirty, hasObject;
+ public ItemStack object;
+ public int quantity;
+
+ public TileEntityDisplayer()
+ {
+ this.ringTranslation1 = 0;
+ this.ringTranslation2 = 0;
+ this.ringTranslation3 = 0;
+ this.rotAngle = 0;
+ this.quantity = 0;
+ this.isDescending1 = false;
+ this.isDescending2 = false;
+ this.isDescending3 = false;
+ this.isDirty = false;
+ this.hasObject = false;
+ this.object = new ItemStack(Item.getItemById(0), 0, 0);
+ }
+
+ @Override
+ public void writeToNBT(NBTTagCompound nbt)
+ {
+ super.writeToNBT(nbt);
+ nbt.setFloat("translation1", ringTranslation1);
+ nbt.setFloat("translation2", ringTranslation2);
+ nbt.setFloat("translation3", ringTranslation3);
+ nbt.setFloat("angle", rotAngle);
+ nbt.setInteger("quantity", quantity);
+ nbt.setBoolean("descending1", isDescending1);
+ nbt.setBoolean("descending2", isDescending2);
+ nbt.setBoolean("descending3", isDescending3);
+ nbt.setBoolean("hasObject", hasObject);
+ NBTTagCompound tag = new NBTTagCompound();
+ this.object.writeToNBT(tag);
+ nbt.setTag("object", tag);
+ }
+
+ @Override
+ public void readFromNBT(NBTTagCompound nbt)
+ {
+ super.readFromNBT(nbt);
+ this.ringTranslation1 = nbt.getFloat("translation1");
+ this.ringTranslation2 = nbt.getFloat("translation2");
+ this.ringTranslation3 = nbt.getFloat("translation3");
+ this.rotAngle = nbt.getFloat("angle");
+ this.quantity = nbt.getInteger("quantity");
+ this.isDescending1 = nbt.getBoolean("descending1");
+ this.isDescending2 = nbt.getBoolean("descending2");
+ this.isDescending3 = nbt.getBoolean("descending3");
+ this.hasObject = nbt.getBoolean("hasObject");
+ this.object = new ItemStack(Item.getItemById(0), 0, 0);
+ this.object.readFromNBT(nbt.getCompoundTag("object"));
+ }
+
+ @Override
+ public void updateEntity()
+ {
+ super.updateEntity();
+ if(isDirty)
+ {
+ worldObj.markBlockForUpdate(xCoord, yCoord, zCoord);
+ isDirty = false;
+ }
+ if(ringTranslation1 >= 0.6) isDescending1 = true;
+ if(ringTranslation1 <= 0) isDescending1 = false;
+ if(!isDescending1) ringTranslation1 += 0.05;
+ if(isDescending1) ringTranslation1 -= 0.05;
+
+ if(ringTranslation2 >= 0.6) isDescending2 = true;
+ if(ringTranslation2 <= 0) isDescending2 = false;
+ if(!isDescending2) ringTranslation2 += 0.04;
+ if(isDescending2) ringTranslation2 -= 0.04;
+
+ if(ringTranslation3 >= 0.6) isDescending3 = true;
+ if(ringTranslation3 <= 0) isDescending3 = false;
+ if(!isDescending3) ringTranslation3 += 0.03;
+ if(isDescending3) ringTranslation3 -= 0.03;
+ if(rotAngle < 360F) rotAngle += 6F;
+ if(rotAngle>=360F) rotAngle = 0F;
+ }
+
+ public Packet getDescriptionPacket()
+ {
+ NBTTagCompound nbttagcompound = new NBTTagCompound();
+ this.writeToNBT(nbttagcompound);
+ return new S35PacketUpdateTileEntity(this.xCoord, this.yCoord, this.zCoord, 1, nbttagcompound);
+ }
+
+ @Override
+ public void onDataPacket (NetworkManager net, S35PacketUpdateTileEntity packet)
+ {
+ readFromNBT(packet.func_148857_g());
+ worldObj.func_147479_m(xCoord, yCoord, zCoord);
+ }
+}