From 258afcd33fe92453d0d18f9c19534fbe8ae51a0e Mon Sep 17 00:00:00 2001 From: Calclavia Date: Sun, 4 Aug 2013 22:45:32 -0400 Subject: [PATCH 1/2] Added quantum tesla --- src/resonantinduction/fx/FXElectricBolt.java | 5 +++ src/resonantinduction/tesla/BlockTesla.java | 40 ++++++++++++++++++- .../tesla/TileEntityTesla.java | 37 +++++++++++++++-- 3 files changed, 78 insertions(+), 4 deletions(-) diff --git a/src/resonantinduction/fx/FXElectricBolt.java b/src/resonantinduction/fx/FXElectricBolt.java index c8c87146a..7bc50685e 100644 --- a/src/resonantinduction/fx/FXElectricBolt.java +++ b/src/resonantinduction/fx/FXElectricBolt.java @@ -68,6 +68,11 @@ public class FXElectricBolt extends EntityFX this.start = new BoltPoint(startVec); this.end = new BoltPoint(targetVec); + if (this.end.y == Double.POSITIVE_INFINITY) + { + this.end.y = Minecraft.getMinecraft().thePlayer.posY + 30; + } + /** By default, we do an electrical color */ this.segmentCount = 1; this.particleMaxAge = (3 + this.rand.nextInt(3) - 1); diff --git a/src/resonantinduction/tesla/BlockTesla.java b/src/resonantinduction/tesla/BlockTesla.java index 17245e365..9a6749653 100644 --- a/src/resonantinduction/tesla/BlockTesla.java +++ b/src/resonantinduction/tesla/BlockTesla.java @@ -4,13 +4,14 @@ package resonantinduction.tesla; import net.minecraft.block.ITileEntityProvider; -import net.minecraft.block.material.Material; import net.minecraft.entity.player.EntityPlayer; import net.minecraft.item.Item; import net.minecraft.tileentity.TileEntity; import net.minecraft.world.World; import resonantinduction.ResonantInduction; import resonantinduction.base.BlockBase; +import resonantinduction.base.Vector3; +import resonantinduction.entangler.ItemCoordLink; import resonantinduction.render.BlockRenderingHandler; import cpw.mods.fml.relauncher.Side; import cpw.mods.fml.relauncher.SideOnly; @@ -63,6 +64,43 @@ public class BlockTesla extends BlockBase implements ITileEntityProvider } return true; } + else if (entityPlayer.getCurrentEquippedItem().getItem() instanceof ItemCoordLink) + { + if (tileEntity.linkCoord == null) + { + ItemCoordLink link = ((ItemCoordLink) entityPlayer.getCurrentEquippedItem().getItem()); + Vector3 linkVec = link.getLink(entityPlayer.getCurrentEquippedItem()); + + if (linkVec != null) + { + if (linkVec.getTileEntity(world) instanceof TileEntityTesla) + { + tileEntity.linkCoord = new Vector3(((TileEntityTesla) linkVec.getTileEntity(world)).getTopTelsa()); + tileEntity.dimID = link.getLinkDim(entityPlayer.getCurrentEquippedItem()); + + if (!world.isRemote) + { + entityPlayer.addChatMessage("Linked " + this.getLocalizedName() + " with " + " [" + (int) linkVec.x + ", " + (int) linkVec.y + ", " + (int) linkVec.z + "]"); + } + + link.clearLink(entityPlayer.getCurrentEquippedItem()); + world.playSoundEffect(x + 0.5, y + 0.5, z + 0.5, "ambient.weather.thunder", 5, 1); + return true; + } + } + } + else + { + tileEntity.linkCoord = null; + + if (!world.isRemote) + { + entityPlayer.addChatMessage("Unlinked Tesla."); + } + + return true; + } + } } else { diff --git a/src/resonantinduction/tesla/TileEntityTesla.java b/src/resonantinduction/tesla/TileEntityTesla.java index 188d86ee6..fab2ffa7b 100644 --- a/src/resonantinduction/tesla/TileEntityTesla.java +++ b/src/resonantinduction/tesla/TileEntityTesla.java @@ -15,6 +15,7 @@ import net.minecraft.entity.EntityLivingBase; import net.minecraft.item.crafting.FurnaceRecipes; import net.minecraft.nbt.NBTTagCompound; import net.minecraft.network.packet.Packet; +import net.minecraft.server.MinecraftServer; import net.minecraft.tileentity.TileEntity; import net.minecraft.tileentity.TileEntityFurnace; import net.minecraft.util.DamageSource; @@ -58,6 +59,12 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe private TileEntityTesla topCache = null; private TileEntityTesla controlCache = null; + /** + * Quantum Tesla + */ + public Vector3 linkCoord; + public int dimID; + /** * Client */ @@ -82,8 +89,27 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe if (this.isController()) { // TODO: Fix client side issue. || this.worldObj.isRemote - if (this.ticks % (5 + this.worldObj.rand.nextInt(2)) == 0 && ((this.getEnergyStored() > 0 && this.doTransfer) || this.worldObj.isRemote) && !this.worldObj.isBlockIndirectlyGettingPowered(this.xCoord, this.yCoord, this.zCoord)) + if (((this.doTransfer) || this.worldObj.isRemote) && this.ticks % (5 + this.worldObj.rand.nextInt(2)) == 0 && this.getEnergyStored() > 0 && !this.worldObj.isBlockIndirectlyGettingPowered(this.xCoord, this.yCoord, this.zCoord)) { + /** + * Quantum transportation. + */ + if (this.linkCoord != null) + { + if (!this.worldObj.isRemote) + { + TileEntity tileEntity = MinecraftServer.getServer().worldServerForDimension(this.dimID).getBlockTileEntity((int) this.linkCoord.x, (int) this.linkCoord.y, (int) this.linkCoord.z); + + if (tileEntity instanceof TileEntityTesla && !tileEntity.isInvalid()) + { + this.transfer(((TileEntityTesla) tileEntity), this.getEnergyStored()); + } + } + + final TileEntityTesla topTesla = this.getTopTelsa(); + final Vector3 topTeslaVector = new Vector3(topTesla); + } + List transferTeslaCoils = new ArrayList(); for (ITesla tesla : TeslaGrid.instance().get()) @@ -163,8 +189,7 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe double distance = topTeslaVector.distance(targetVector); ResonantInduction.proxy.renderElectricShock(this.worldObj, new Vector3(topTesla).translate(new Vector3(0.5)), targetVector.translate(new Vector3(0.5)), (float) dyeColors[this.dyeID].x, (float) dyeColors[this.dyeID].y, (float) dyeColors[this.dyeID].z); - tesla.transfer(transferEnergy * (1 - (this.worldObj.rand.nextFloat() * 0.1f)), true); - this.transfer(-transferEnergy, true); + this.transfer(tesla, transferEnergy); if (this.attackEntities && this.zapCounter % 5 == 0) { @@ -257,6 +282,12 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe this.clearCache(); } + private void transfer(ITesla tesla, float transferEnergy) + { + tesla.transfer(transferEnergy * (1 - (this.worldObj.rand.nextFloat() * 0.1f)), true); + this.transfer(-transferEnergy, true); + } + @Override public boolean canReceive(TileEntity tileEntity) { From 9e1feca3e8dbf743c1fce08f21c9c9f3385245ad Mon Sep 17 00:00:00 2001 From: Calclavia Date: Sun, 4 Aug 2013 22:56:45 -0400 Subject: [PATCH 2/2] Inter-dimensional transfer working! --- src/resonantinduction/tesla/BlockTesla.java | 25 ++- .../tesla/TileEntityTesla.java | 202 ++++++++++-------- 2 files changed, 125 insertions(+), 102 deletions(-) diff --git a/src/resonantinduction/tesla/BlockTesla.java b/src/resonantinduction/tesla/BlockTesla.java index 9a6749653..6ea9848f6 100644 --- a/src/resonantinduction/tesla/BlockTesla.java +++ b/src/resonantinduction/tesla/BlockTesla.java @@ -6,6 +6,7 @@ package resonantinduction.tesla; import net.minecraft.block.ITileEntityProvider; import net.minecraft.entity.player.EntityPlayer; import net.minecraft.item.Item; +import net.minecraft.server.MinecraftServer; import net.minecraft.tileentity.TileEntity; import net.minecraft.world.World; import resonantinduction.ResonantInduction; @@ -66,32 +67,34 @@ public class BlockTesla extends BlockBase implements ITileEntityProvider } else if (entityPlayer.getCurrentEquippedItem().getItem() instanceof ItemCoordLink) { - if (tileEntity.linkCoord == null) + if (tileEntity.linked == null) { ItemCoordLink link = ((ItemCoordLink) entityPlayer.getCurrentEquippedItem().getItem()); Vector3 linkVec = link.getLink(entityPlayer.getCurrentEquippedItem()); if (linkVec != null) { - if (linkVec.getTileEntity(world) instanceof TileEntityTesla) + if (!world.isRemote) { - tileEntity.linkCoord = new Vector3(((TileEntityTesla) linkVec.getTileEntity(world)).getTopTelsa()); - tileEntity.dimID = link.getLinkDim(entityPlayer.getCurrentEquippedItem()); + int dimID = link.getLinkDim(entityPlayer.getCurrentEquippedItem()); + World otherWorld = MinecraftServer.getServer().worldServerForDimension(dimID); - if (!world.isRemote) + if (linkVec.getTileEntity(otherWorld) instanceof TileEntityTesla) { - entityPlayer.addChatMessage("Linked " + this.getLocalizedName() + " with " + " [" + (int) linkVec.x + ", " + (int) linkVec.y + ", " + (int) linkVec.z + "]"); - } + tileEntity.setLink(new Vector3(((TileEntityTesla) linkVec.getTileEntity(otherWorld)).getTopTelsa()), dimID); - link.clearLink(entityPlayer.getCurrentEquippedItem()); - world.playSoundEffect(x + 0.5, y + 0.5, z + 0.5, "ambient.weather.thunder", 5, 1); - return true; + entityPlayer.addChatMessage("Linked " + this.getLocalizedName() + " with " + " [" + (int) linkVec.x + ", " + (int) linkVec.y + ", " + (int) linkVec.z + "]"); + + link.clearLink(entityPlayer.getCurrentEquippedItem()); + world.playSoundEffect(x + 0.5, y + 0.5, z + 0.5, "ambient.weather.thunder", 5, 1); + return true; + } } } } else { - tileEntity.linkCoord = null; + tileEntity.linked = null; if (!world.isRemote) { diff --git a/src/resonantinduction/tesla/TileEntityTesla.java b/src/resonantinduction/tesla/TileEntityTesla.java index fab2ffa7b..f325db919 100644 --- a/src/resonantinduction/tesla/TileEntityTesla.java +++ b/src/resonantinduction/tesla/TileEntityTesla.java @@ -62,8 +62,8 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe /** * Quantum Tesla */ - public Vector3 linkCoord; - public int dimID; + public Vector3 linked; + public int linkDim; /** * Client @@ -94,120 +94,120 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe /** * Quantum transportation. */ - if (this.linkCoord != null) + if (this.linked != null) { if (!this.worldObj.isRemote) { - TileEntity tileEntity = MinecraftServer.getServer().worldServerForDimension(this.dimID).getBlockTileEntity((int) this.linkCoord.x, (int) this.linkCoord.y, (int) this.linkCoord.z); + TileEntity tileEntity = MinecraftServer.getServer().worldServerForDimension(this.linkDim).getBlockTileEntity((int) this.linked.x, (int) this.linked.y, (int) this.linked.z); if (tileEntity instanceof TileEntityTesla && !tileEntity.isInvalid()) { this.transfer(((TileEntityTesla) tileEntity), this.getEnergyStored()); } } + } + else + { + + List transferTeslaCoils = new ArrayList(); + + for (ITesla tesla : TeslaGrid.instance().get()) + { + if (new Vector3((TileEntity) tesla).distance(new Vector3(this)) < this.getRange()) + { + /** + * Make sure Tesla is not part of this tower. + */ + if (!this.connectedTeslas.contains(tesla) && tesla.canReceive(this)) + { + if (tesla instanceof TileEntityTesla) + { + if (((TileEntityTesla) tesla).getHeight() <= 1) + { + continue; + } + + tesla = ((TileEntityTesla) tesla).getControllingTelsa(); + } + + transferTeslaCoils.add(tesla); + } + } + } final TileEntityTesla topTesla = this.getTopTelsa(); final Vector3 topTeslaVector = new Vector3(topTesla); - } - - List transferTeslaCoils = new ArrayList(); - - for (ITesla tesla : TeslaGrid.instance().get()) - { - if (new Vector3((TileEntity) tesla).distance(new Vector3(this)) < this.getRange()) + /** + * Sort by distance. + */ + Collections.sort(transferTeslaCoils, new Comparator() { - /** - * Make sure Tesla is not part of this tower. - */ - if (!this.connectedTeslas.contains(tesla) && tesla.canReceive(this)) + public int compare(ITesla o1, ITesla o2) { + double distance1 = new Vector3(topTesla).distance(new Vector3((TileEntity) o1)); + double distance2 = new Vector3(topTesla).distance(new Vector3((TileEntity) o2)); + + if (distance1 < distance2) + { + return 1; + } + else if (distance1 > distance2) + { + return -1; + } + + return 0; + } + + @Override + public int compare(Object obj, Object obj1) + { + return compare((ITesla) obj, (ITesla) obj1); + } + }); + + if (transferTeslaCoils.size() > 0) + { + float transferEnergy = this.getEnergyStored() / transferTeslaCoils.size(); + int count = 0; + for (ITesla tesla : transferTeslaCoils) + { + if (this.zapCounter % 5 == 0 && ResonantInduction.SOUND_FXS) + { + this.worldObj.playSoundEffect(this.xCoord + 0.5, this.yCoord + 0.5, this.zCoord + 0.5, ResonantInduction.PREFIX + "electricshock", this.getEnergyStored() / 25, 1.3f - 0.5f * (this.dyeID / 16f)); + } + + Vector3 targetVector = new Vector3((TileEntity) tesla); + if (tesla instanceof TileEntityTesla) { - if (((TileEntityTesla) tesla).getHeight() <= 1) - { - continue; - } - - tesla = ((TileEntityTesla) tesla).getControllingTelsa(); + ((TileEntityTesla) tesla).getControllingTelsa().outputBlacklist.add(this); + targetVector = new Vector3(((TileEntityTesla) tesla).getTopTelsa()); } - transferTeslaCoils.add(tesla); - } - } - } + double distance = topTeslaVector.distance(targetVector); + ResonantInduction.proxy.renderElectricShock(this.worldObj, new Vector3(topTesla).translate(new Vector3(0.5)), targetVector.translate(new Vector3(0.5)), (float) dyeColors[this.dyeID].x, (float) dyeColors[this.dyeID].y, (float) dyeColors[this.dyeID].z); - final TileEntityTesla topTesla = this.getTopTelsa(); - final Vector3 topTeslaVector = new Vector3(topTesla); - /** - * Sort by distance. - */ - Collections.sort(transferTeslaCoils, new Comparator() - { - public int compare(ITesla o1, ITesla o2) - { - double distance1 = new Vector3(topTesla).distance(new Vector3((TileEntity) o1)); - double distance2 = new Vector3(topTesla).distance(new Vector3((TileEntity) o2)); + this.transfer(tesla, transferEnergy); - if (distance1 < distance2) - { - return 1; - } - else if (distance1 > distance2) - { - return -1; - } - - return 0; - } - - @Override - public int compare(Object obj, Object obj1) - { - return compare((ITesla) obj, (ITesla) obj1); - } - }); - - if (transferTeslaCoils.size() > 0) - { - float transferEnergy = this.getEnergyStored() / transferTeslaCoils.size(); - int count = 0; - for (ITesla tesla : transferTeslaCoils) - { - if (this.zapCounter % 5 == 0 && ResonantInduction.SOUND_FXS) - { - this.worldObj.playSoundEffect(this.xCoord + 0.5, this.yCoord + 0.5, this.zCoord + 0.5, ResonantInduction.PREFIX + "electricshock", this.getEnergyStored() / 25, 1.3f - 0.5f * (this.dyeID / 16f)); - } - - Vector3 targetVector = new Vector3((TileEntity) tesla); - - if (tesla instanceof TileEntityTesla) - { - ((TileEntityTesla) tesla).getControllingTelsa().outputBlacklist.add(this); - targetVector = new Vector3(((TileEntityTesla) tesla).getTopTelsa()); - } - - double distance = topTeslaVector.distance(targetVector); - ResonantInduction.proxy.renderElectricShock(this.worldObj, new Vector3(topTesla).translate(new Vector3(0.5)), targetVector.translate(new Vector3(0.5)), (float) dyeColors[this.dyeID].x, (float) dyeColors[this.dyeID].y, (float) dyeColors[this.dyeID].z); - - this.transfer(tesla, transferEnergy); - - if (this.attackEntities && this.zapCounter % 5 == 0) - { - MovingObjectPosition mop = topTeslaVector.clone().translate(0.5).rayTraceEntities(this.worldObj, targetVector.clone().translate(0.5)); - - if (mop != null && mop.entityHit != null) + if (this.attackEntities && this.zapCounter % 5 == 0) { - if (mop.entityHit instanceof EntityLivingBase) + MovingObjectPosition mop = topTeslaVector.clone().translate(0.5).rayTraceEntities(this.worldObj, targetVector.clone().translate(0.5)); + + if (mop != null && mop.entityHit != null) { - mop.entityHit.attackEntityFrom(DamageSource.magic, 3); - ResonantInduction.proxy.renderElectricShock(this.worldObj, new Vector3(topTesla).clone().translate(0.5), new Vector3(mop.entityHit)); + if (mop.entityHit instanceof EntityLivingBase) + { + mop.entityHit.attackEntityFrom(DamageSource.magic, 3); + ResonantInduction.proxy.renderElectricShock(this.worldObj, new Vector3(topTesla).clone().translate(0.5), new Vector3(mop.entityHit)); + } } } - } - if (count++ > 1) - { - break; + if (count++ > 1) + { + break; + } } } } @@ -524,6 +524,12 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe this.dyeID = nbt.getInteger("dyeID"); this.canReceive = nbt.getBoolean("canReceive"); this.attackEntities = nbt.getBoolean("attackEntities"); + + if (nbt.hasKey("link_x") && nbt.hasKey("link_y") && nbt.hasKey("link_z")) + { + this.linked = new Vector3(nbt.getInteger("link_x"), nbt.getInteger("link_y"), nbt.getInteger("link_z")); + this.linkDim = nbt.getInteger("linkDim"); + } } /** @@ -536,6 +542,20 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe nbt.setInteger("dyeID", this.dyeID); nbt.setBoolean("canReceive", this.canReceive); nbt.setBoolean("attackEntities", this.attackEntities); + + if (this.linked != null) + { + nbt.setInteger("link_x", (int) this.linked.x); + nbt.setInteger("link_y", (int) this.linked.y); + nbt.setInteger("link_z", (int) this.linked.z); + nbt.setInteger("linkDim", this.linkDim); + } + } + + public void setLink(Vector3 vector3, int dimID) + { + this.linked = vector3; + this.linkDim = dimID; } }