From 2ed7e01e5eee89c7addcdd46790044421f7f8600 Mon Sep 17 00:00:00 2001 From: Calclavia Date: Sat, 3 Aug 2013 14:59:07 -0400 Subject: [PATCH 1/7] Improved Tesla transfer mechanism --- src/resonantinduction/fx/FXElectricBolt.java | 4 +- .../tesla/TileEntityTesla.java | 67 ++++++++++++++++--- 2 files changed, 60 insertions(+), 11 deletions(-) diff --git a/src/resonantinduction/fx/FXElectricBolt.java b/src/resonantinduction/fx/FXElectricBolt.java index 9792061d6..40fde6fa2 100644 --- a/src/resonantinduction/fx/FXElectricBolt.java +++ b/src/resonantinduction/fx/FXElectricBolt.java @@ -350,7 +350,7 @@ public class FXElectricBolt extends EntityFX tessellator.startDrawingQuads(); } - public class BoltPoint extends Vector3 + private class BoltPoint extends Vector3 { public Vector3 base; public Vector3 offset; @@ -368,7 +368,7 @@ public class FXElectricBolt extends EntityFX } } - public class BoltSegment + private class BoltSegment { public BoltPoint start; public BoltPoint end; diff --git a/src/resonantinduction/tesla/TileEntityTesla.java b/src/resonantinduction/tesla/TileEntityTesla.java index f7dfbb95e..5429b32a5 100644 --- a/src/resonantinduction/tesla/TileEntityTesla.java +++ b/src/resonantinduction/tesla/TileEntityTesla.java @@ -4,7 +4,10 @@ package resonantinduction.tesla; import java.util.ArrayList; +import java.util.Collections; +import java.util.Comparator; import java.util.HashSet; +import java.util.List; import java.util.Set; import net.minecraft.block.BlockFurnace; @@ -35,7 +38,9 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe private float energy = 0; private boolean doTransfer = false; - private Set connectedTeslas = new HashSet(); + /** Prevents transfer loops */ + public final Set temporarilyBlacklist = new HashSet(); + private final Set connectedTeslas = new HashSet(); @Override public void initiate() @@ -56,16 +61,21 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe // TODO: Fix client side issue. || this.worldObj.isRemote if (this.ticks % 2 == 0 && this.isController() && ((this.getEnergyStored() > 0 && this.doTransfer) || this.worldObj.isRemote) && !this.worldObj.isBlockIndirectlyGettingPowered(this.xCoord, this.yCoord, this.zCoord)) { - Set transferTeslaCoils = new HashSet(); + List transferTeslaCoils = new ArrayList(); for (ITesla tesla : TeslaGrid.instance().get()) { if (new Vector3((TileEntity) tesla).distance(new Vector3(this)) < this.getRange()) { - if (!this.connectedTeslas.contains(tesla)) + if (!this.connectedTeslas.contains(tesla) && !this.temporarilyBlacklist.contains(tesla)) { if (tesla instanceof TileEntityTesla) { + if (((TileEntityTesla) tesla).getHeight() <= 1) + { + continue; + } + tesla = ((TileEntityTesla) tesla).getControllingTelsa(); } @@ -74,30 +84,69 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe } } + final TileEntityTesla topTesla = this.getTopTelsa(); + + /** + * 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)); + + 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.ticks % 20 == 0) { - this.worldObj.playSoundEffect(this.xCoord + 0.5, this.yCoord + 0.5, this.zCoord + 0.5, ResonantInduction.PREFIX + "electricshock", this.getEnergyStored() / 10, (float) (1 - 0.2 * (this.dyeID / 16))); + this.worldObj.playSoundEffect(this.xCoord + 0.5, this.yCoord + 0.5, this.zCoord + 0.5, ResonantInduction.PREFIX + "electricshock", this.getEnergyStored() / 12, (float) (1 - 0.2 * (this.dyeID / 16))); } Vector3 teslaVector = new Vector3((TileEntity) tesla); if (tesla instanceof TileEntityTesla) { - teslaVector = new Vector3(((TileEntityTesla) tesla).getControllingTelsa()); + ((TileEntityTesla) tesla).getControllingTelsa().temporarilyBlacklist.add(this); + teslaVector = new Vector3(((TileEntityTesla) tesla).getTopTelsa()); } - ResonantInduction.proxy.renderElectricShock(this.worldObj, new Vector3(this.getTopTelsa()).translate(new Vector3(0.5)), teslaVector.translate(new Vector3(0.5)), (float) dyeColors[this.dyeID].x, (float) dyeColors[this.dyeID].y, (float) dyeColors[this.dyeID].z); + ResonantInduction.proxy.renderElectricShock(this.worldObj, new Vector3(topTesla).translate(new Vector3(0.5)), teslaVector.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))); this.transfer(-transferEnergy); + + if (count++ > 2) + { + break; + } } } + + this.temporarilyBlacklist.clear(); } /* @@ -179,7 +228,7 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe { return PacketHandler.getTileEntityPacket(this, (byte) 1, this.getEnergyStored(), this.dyeID); } - + @Override public ArrayList getNetworkedData(ArrayList data) { @@ -235,7 +284,7 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe public int getRange() { - return 5 * (this.getHeight() - 1); + return Math.min(4 * (this.getHeight() - 1), 50); } public void updatePositionStatus() From 489154b92d331a52c70e9cf799430927427f8c7c Mon Sep 17 00:00:00 2001 From: Calclavia Date: Sat, 3 Aug 2013 15:09:08 -0400 Subject: [PATCH 2/7] Cached Tesla objects; improving performance --- src/resonantinduction/fx/FXElectricBolt.java | 15 ++++++++-- .../tesla/TileEntityTesla.java | 30 +++++++++++++++++-- 2 files changed, 41 insertions(+), 4 deletions(-) diff --git a/src/resonantinduction/fx/FXElectricBolt.java b/src/resonantinduction/fx/FXElectricBolt.java index 40fde6fa2..0a6e1638d 100644 --- a/src/resonantinduction/fx/FXElectricBolt.java +++ b/src/resonantinduction/fx/FXElectricBolt.java @@ -1,5 +1,13 @@ package resonantinduction.fx; +import static org.lwjgl.opengl.GL11.GL_BLEND; +import static org.lwjgl.opengl.GL11.GL_ONE_MINUS_SRC_ALPHA; +import static org.lwjgl.opengl.GL11.GL_SMOOTH; +import static org.lwjgl.opengl.GL11.GL_SRC_ALPHA; +import static org.lwjgl.opengl.GL11.glBlendFunc; +import static org.lwjgl.opengl.GL11.glEnable; +import static org.lwjgl.opengl.GL11.glShadeModel; + import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; @@ -271,6 +279,10 @@ public class FXElectricBolt extends EntityFX GL11.glDepthMask(false); GL11.glEnable(3042); + glShadeModel(GL_SMOOTH); + glEnable(GL_BLEND); + glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); + FMLClientHandler.instance().getClient().renderEngine.func_110577_a(TEXTURE); /** * Render the actual bolts. @@ -278,7 +290,6 @@ public class FXElectricBolt extends EntityFX tessellator.startDrawingQuads(); tessellator.setBrightness(15728880); Vector3 playerVector = new Vector3(sinYaw * -cosPitch, -cosSinPitch / cosYaw, cosYaw * cosPitch); - float voltage = this.particleAge >= 0 ? ((float) this.particleAge / (float) this.particleMaxAge) : 0.0F; int renderlength = (int) ((this.particleAge + partialframe + (int) (this.boltLength * 3.0F)) / (int) (this.boltLength * 3.0F) * this.segmentCount); @@ -302,7 +313,7 @@ public class FXElectricBolt extends EntityFX float ry2 = (float) (endVec.y - interpPosY); float rz2 = (float) (endVec.z - interpPosZ); - tessellator.setColorRGBA_F(this.particleRed, this.particleGreen, this.particleBlue, (1.0F - voltage * 0.5f) * segment.alpha); + tessellator.setColorRGBA_F(this.particleRed, this.particleGreen, this.particleBlue, (1.0F - (this.particleAge >= 0 ? ((float) this.particleAge / (float) this.particleMaxAge) : 0.0F) * 0.6f) * segment.alpha); tessellator.addVertexWithUV(rx2 - diffNext.x, ry2 - diffNext.y, rz2 - diffNext.z, 0.5D, 0.0D); tessellator.addVertexWithUV(rx1 - diffPrev.x, ry1 - diffPrev.y, rz1 - diffPrev.z, 0.5D, 0.0D); tessellator.addVertexWithUV(rx1 + diffPrev.x, ry1 + diffPrev.y, rz1 + diffPrev.z, 0.5D, 1.0D); diff --git a/src/resonantinduction/tesla/TileEntityTesla.java b/src/resonantinduction/tesla/TileEntityTesla.java index 5429b32a5..d37ef45e9 100644 --- a/src/resonantinduction/tesla/TileEntityTesla.java +++ b/src/resonantinduction/tesla/TileEntityTesla.java @@ -42,6 +42,12 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe public final Set temporarilyBlacklist = new HashSet(); private final Set connectedTeslas = new HashSet(); + /** + * Caching + */ + private TileEntityTesla topCache = null; + private TileEntityTesla controlCache = null; + @Override public void initiate() { @@ -139,7 +145,7 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe tesla.transfer(transferEnergy * (1 - (this.worldObj.rand.nextFloat() * 0.1f))); this.transfer(-transferEnergy); - if (count++ > 2) + if (count++ > 1) { break; } @@ -221,6 +227,8 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe { this.worldObj.markBlockForUpdate(this.xCoord, this.yCoord, this.zCoord); } + + this.clearCache(); } @Override @@ -262,6 +270,12 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe return this.worldObj.getBlockMetadata(this.xCoord, this.yCoord, this.zCoord) == 0; } + private void clearCache() + { + this.topCache = null; + this.controlCache = null; + } + @Override public void transfer(float transferEnergy) { @@ -284,7 +298,7 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe public int getRange() { - return Math.min(4 * (this.getHeight() - 1), 50); + return Math.min(5 * (this.getHeight() - 1), 50); } public void updatePositionStatus() @@ -313,6 +327,11 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe */ public TileEntityTesla getTopTelsa() { + if (this.topCache != null) + { + return this.topCache; + } + this.connectedTeslas.clear(); Vector3 checkPosition = new Vector3(this); TileEntityTesla returnTile = this; @@ -334,6 +353,7 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe checkPosition.y++; } + this.topCache = returnTile; return returnTile; } @@ -344,6 +364,11 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe */ public TileEntityTesla getControllingTelsa() { + if (this.controlCache != null) + { + return this.controlCache; + } + Vector3 checkPosition = new Vector3(this); TileEntityTesla returnTile = this; @@ -363,6 +388,7 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe checkPosition.y--; } + this.controlCache = returnTile; return returnTile; } From ab0567c875492ad66d211d4098a9e2d08c9984cb Mon Sep 17 00:00:00 2001 From: Calclavia Date: Sat, 3 Aug 2013 15:44:11 -0400 Subject: [PATCH 3/7] Added receive mode toggle and color tunes --- src/resonantinduction/ITesla.java | 4 ++ src/resonantinduction/tesla/BlockTesla.java | 17 +++++-- .../tesla/TileEntityTesla.java | 50 +++++++++++++++---- 3 files changed, 58 insertions(+), 13 deletions(-) diff --git a/src/resonantinduction/ITesla.java b/src/resonantinduction/ITesla.java index 4678c222c..563e1be95 100644 --- a/src/resonantinduction/ITesla.java +++ b/src/resonantinduction/ITesla.java @@ -3,6 +3,8 @@ */ package resonantinduction; +import net.minecraft.tileentity.TileEntity; + /** * @author Calclavia * @@ -11,4 +13,6 @@ public interface ITesla { public void transfer(float transferEnergy); + public boolean canReceive(TileEntity tileEntity); + } diff --git a/src/resonantinduction/tesla/BlockTesla.java b/src/resonantinduction/tesla/BlockTesla.java index c70035310..0efeef521 100644 --- a/src/resonantinduction/tesla/BlockTesla.java +++ b/src/resonantinduction/tesla/BlockTesla.java @@ -38,17 +38,28 @@ public class BlockTesla extends BlockBase implements ITileEntityProvider @Override public boolean onBlockActivated(World world, int x, int y, int z, EntityPlayer entityPlayer, int par6, float par7, float par8, float par9) { - TileEntity tileEntity = world.getBlockTileEntity(x, y, z); - tileEntity = ((TileEntityTesla) tileEntity).getControllingTelsa(); + TileEntity t = world.getBlockTileEntity(x, y, z); + TileEntityTesla tileEntity = ((TileEntityTesla) t).getControllingTelsa(); if (entityPlayer.getCurrentEquippedItem() != null) { if (entityPlayer.getCurrentEquippedItem().itemID == Item.dyePowder.itemID) { - ((TileEntityTesla) tileEntity).setDye(entityPlayer.getCurrentEquippedItem().getItemDamage()); + tileEntity.setDye(entityPlayer.getCurrentEquippedItem().getItemDamage()); return true; } } + else + { + boolean receiveMode = tileEntity.toggleReceive(); + + if (world.isRemote) + { + entityPlayer.addChatMessage("Tesla receive mode is now " + receiveMode); + } + return true; + + } return false; } diff --git a/src/resonantinduction/tesla/TileEntityTesla.java b/src/resonantinduction/tesla/TileEntityTesla.java index d37ef45e9..bc7883be8 100644 --- a/src/resonantinduction/tesla/TileEntityTesla.java +++ b/src/resonantinduction/tesla/TileEntityTesla.java @@ -26,20 +26,26 @@ import resonantinduction.base.Vector3; import com.google.common.io.ByteArrayDataInput; /** + * The Tesla TileEntity. + * + * - Redstone (Prevent Output Toggle) - Right click (Prevent Input Toggle) + * * @author Calclavia * */ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketReceiver { - public static final Vector3[] dyeColors = new Vector3[] { new Vector3(), new Vector3(1, 0, 0), new Vector3(0, 1, 0), new Vector3(0.5, 0.5, 0), new Vector3(0, 0, 1), new Vector3(0.5, 0, 05), new Vector3(0, 0.3, 1), new Vector3(0.8, 0.8, 0.8), new Vector3(0.3, 0.3, 0.3), new Vector3(0.7, 0.2, 0.2), new Vector3(0.1, 0.872, 0.884), new Vector3(0, 0.8, 0.8), new Vector3(0.46f, 0.932, 1), new Vector3(0.5, 0.2, 0.5), new Vector3(0.7, 0.5, 0.1), new Vector3(1, 1, 1) }; - private int dyeID = 12; + private final int DEFAULT_COLOR = 12; + private int dyeID = DEFAULT_COLOR; private float energy = 0; private boolean doTransfer = false; + private boolean canReceive = true; + /** Prevents transfer loops */ - public final Set temporarilyBlacklist = new HashSet(); + private final Set outputBlacklist = new HashSet(); private final Set connectedTeslas = new HashSet(); /** @@ -48,6 +54,11 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe private TileEntityTesla topCache = null; private TileEntityTesla controlCache = null; + /** + * Client + */ + private int soundTick = 0; + @Override public void initiate() { @@ -65,7 +76,7 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe * Only transfer if it is the bottom controlling Tesla tower. */ // TODO: Fix client side issue. || this.worldObj.isRemote - if (this.ticks % 2 == 0 && this.isController() && ((this.getEnergyStored() > 0 && this.doTransfer) || this.worldObj.isRemote) && !this.worldObj.isBlockIndirectlyGettingPowered(this.xCoord, this.yCoord, this.zCoord)) + if (this.ticks % (7 + this.worldObj.rand.nextInt(2)) == 0 && this.isController() && ((this.getEnergyStored() > 0 && this.doTransfer) || this.worldObj.isRemote) && !this.worldObj.isBlockIndirectlyGettingPowered(this.xCoord, this.yCoord, this.zCoord)) { List transferTeslaCoils = new ArrayList(); @@ -73,7 +84,10 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe { if (new Vector3((TileEntity) tesla).distance(new Vector3(this)) < this.getRange()) { - if (!this.connectedTeslas.contains(tesla) && !this.temporarilyBlacklist.contains(tesla)) + /** + * Make sure Tesla is not part of this tower. + */ + if (!this.connectedTeslas.contains(tesla) && tesla.canReceive(this)) { if (tesla instanceof TileEntityTesla) { @@ -127,16 +141,16 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe int count = 0; for (ITesla tesla : transferTeslaCoils) { - if (this.ticks % 20 == 0) + if (this.soundTick % 4 == 0) { - this.worldObj.playSoundEffect(this.xCoord + 0.5, this.yCoord + 0.5, this.zCoord + 0.5, ResonantInduction.PREFIX + "electricshock", this.getEnergyStored() / 12, (float) (1 - 0.2 * (this.dyeID / 16))); + this.worldObj.playSoundEffect(this.xCoord + 0.5, this.yCoord + 0.5, this.zCoord + 0.5, ResonantInduction.PREFIX + "electricshock", this.getEnergyStored() / 20, (float) (1.3f - 0.5f * ((float) this.dyeID / 16f))); } Vector3 teslaVector = new Vector3((TileEntity) tesla); if (tesla instanceof TileEntityTesla) { - ((TileEntityTesla) tesla).getControllingTelsa().temporarilyBlacklist.add(this); + ((TileEntityTesla) tesla).getControllingTelsa().outputBlacklist.add(this); teslaVector = new Vector3(((TileEntityTesla) tesla).getTopTelsa()); } @@ -152,7 +166,8 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe } } - this.temporarilyBlacklist.clear(); + this.soundTick++; + this.outputBlacklist.clear(); } /* @@ -231,10 +246,16 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe this.clearCache(); } + @Override + public boolean canReceive(TileEntity tileEntity) + { + return this.canReceive && !this.outputBlacklist.contains(tileEntity); + } + @Override public Packet getDescriptionPacket() { - return PacketHandler.getTileEntityPacket(this, (byte) 1, this.getEnergyStored(), this.dyeID); + return PacketHandler.getTileEntityPacket(this, (byte) 1, this.getEnergyStored(), this.dyeID, this.canReceive); } @Override @@ -253,6 +274,7 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe case 1: this.energy = input.readFloat(); this.dyeID = input.readInt(); + this.canReceive = input.readBoolean(); break; } @@ -434,6 +456,11 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe this.worldObj.markBlockForUpdate(this.xCoord, this.yCoord, this.zCoord); } + public boolean toggleReceive() + { + return this.canReceive = !this.canReceive; + } + /** * Reads a tile entity from NBT. */ @@ -441,6 +468,7 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe { super.readFromNBT(nbt); this.dyeID = nbt.getInteger("dyeID"); + this.canReceive = nbt.getBoolean("canReceive"); } /** @@ -450,5 +478,7 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe { super.writeToNBT(nbt); nbt.setInteger("dyeID", this.dyeID); + nbt.setBoolean("canReceive", this.canReceive); } + } From eee616a58c535fac147ede3b857095157871cf0c Mon Sep 17 00:00:00 2001 From: Calclavia Date: Sat, 3 Aug 2013 15:56:27 -0400 Subject: [PATCH 4/7] Added entity attack and redstone upgrade --- src/resonantinduction/base/Vector3.java | 5 +++ src/resonantinduction/tesla/BlockTesla.java | 5 +++ .../tesla/TileEntityTesla.java | 44 ++++++++++++------- 3 files changed, 38 insertions(+), 16 deletions(-) diff --git a/src/resonantinduction/base/Vector3.java b/src/resonantinduction/base/Vector3.java index 9762d1cdf..e47e1f95f 100644 --- a/src/resonantinduction/base/Vector3.java +++ b/src/resonantinduction/base/Vector3.java @@ -129,6 +129,11 @@ public class Vector3 return new Vector3(this.x + offset.x, this.y + offset.y, this.z + offset.z); } + public Vector3 translate(int offset) + { + return new Vector3(this.x + offset, this.y + offset, this.z + offset); + } + public Vector3 normalize() { double d = getMagnitude(); diff --git a/src/resonantinduction/tesla/BlockTesla.java b/src/resonantinduction/tesla/BlockTesla.java index 0efeef521..97997ffef 100644 --- a/src/resonantinduction/tesla/BlockTesla.java +++ b/src/resonantinduction/tesla/BlockTesla.java @@ -46,6 +46,11 @@ public class BlockTesla extends BlockBase implements ITileEntityProvider if (entityPlayer.getCurrentEquippedItem().itemID == Item.dyePowder.itemID) { tileEntity.setDye(entityPlayer.getCurrentEquippedItem().getItemDamage()); + + if (!entityPlayer.capabilities.isCreativeMode) + { + entityPlayer.inventory.decrStackSize(entityPlayer.inventory.currentItem, 1); + } return true; } } diff --git a/src/resonantinduction/tesla/TileEntityTesla.java b/src/resonantinduction/tesla/TileEntityTesla.java index bc7883be8..e9f5390c3 100644 --- a/src/resonantinduction/tesla/TileEntityTesla.java +++ b/src/resonantinduction/tesla/TileEntityTesla.java @@ -11,11 +11,14 @@ import java.util.List; import java.util.Set; import net.minecraft.block.BlockFurnace; +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.tileentity.TileEntity; import net.minecraft.tileentity.TileEntityFurnace; +import net.minecraft.util.AxisAlignedBB; +import net.minecraft.util.DamageSource; import resonantinduction.ITesla; import resonantinduction.PacketHandler; import resonantinduction.ResonantInduction; @@ -43,6 +46,7 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe private boolean doTransfer = false; private boolean canReceive = true; + private boolean attackEntities = true; /** Prevents transfer loops */ private final Set outputBlacklist = new HashSet(); @@ -57,7 +61,7 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe /** * Client */ - private int soundTick = 0; + private int zapCounter = 0; @Override public void initiate() @@ -76,7 +80,7 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe * Only transfer if it is the bottom controlling Tesla tower. */ // TODO: Fix client side issue. || this.worldObj.isRemote - if (this.ticks % (7 + this.worldObj.rand.nextInt(2)) == 0 && this.isController() && ((this.getEnergyStored() > 0 && this.doTransfer) || this.worldObj.isRemote) && !this.worldObj.isBlockIndirectlyGettingPowered(this.xCoord, this.yCoord, this.zCoord)) + if (this.ticks % (5 + this.worldObj.rand.nextInt(2)) == 0 && this.isController() && ((this.getEnergyStored() > 0 && this.doTransfer) || this.worldObj.isRemote) && !this.worldObj.isBlockIndirectlyGettingPowered(this.xCoord, this.yCoord, this.zCoord)) { List transferTeslaCoils = new ArrayList(); @@ -141,9 +145,9 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe int count = 0; for (ITesla tesla : transferTeslaCoils) { - if (this.soundTick % 4 == 0) + if (this.zapCounter % 5 == 0) { - this.worldObj.playSoundEffect(this.xCoord + 0.5, this.yCoord + 0.5, this.zCoord + 0.5, ResonantInduction.PREFIX + "electricshock", this.getEnergyStored() / 20, (float) (1.3f - 0.5f * ((float) this.dyeID / 16f))); + this.worldObj.playSoundEffect(this.xCoord + 0.5, this.yCoord + 0.5, this.zCoord + 0.5, ResonantInduction.PREFIX + "electricshock", this.getEnergyStored() / 25, (float) (1.3f - 0.5f * ((float) this.dyeID / 16f))); } Vector3 teslaVector = new Vector3((TileEntity) tesla); @@ -164,23 +168,24 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe break; } } + + if (this.attackEntities && this.zapCounter % 10 == 0) + { + int radius = 3; + List entities = this.worldObj.getEntitiesWithinAABB(EntityLivingBase.class, AxisAlignedBB.getAABBPool().getAABB(this.xCoord - radius, this.yCoord - radius, this.zCoord - radius, this.xCoord + radius, this.yCoord + radius, this.zCoord + radius)); + + for (EntityLivingBase entity : entities) + { + entity.attackEntityFrom(DamageSource.magic, 1); + ResonantInduction.proxy.renderElectricShock(this.worldObj, new Vector3(topTesla).translate(new Vector3(0.5)), new Vector3(entity)); + } + } } - this.soundTick++; + this.zapCounter++; this.outputBlacklist.clear(); } - /* - * int radius = 10; List entities = - * this.worldObj.getEntitiesWithinAABBExcludingEntity(null, - * AxisAlignedBB.getAABBPool().getAABB(this.xCoord - radius, this.yCoord - radius, - * this.zCoord - radius, this.xCoord + radius, this.yCoord + radius, this.zCoord + radius)); - * - * for (Entity entity : entities) { - * ResonantInduction.proxy.renderElectricShock(this.worldObj, new - * Vector3(this).translate(new Vector3(0.5)), new Vector3(entity)); } - */ - /** * Draws power from furnace below it. * @@ -461,6 +466,11 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe return this.canReceive = !this.canReceive; } + public boolean toggleEntityAttack() + { + return this.attackEntities = !this.attackEntities; + } + /** * Reads a tile entity from NBT. */ @@ -469,6 +479,7 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe super.readFromNBT(nbt); this.dyeID = nbt.getInteger("dyeID"); this.canReceive = nbt.getBoolean("canReceive"); + this.attackEntities = nbt.getBoolean("attackEntities"); } /** @@ -479,6 +490,7 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe super.writeToNBT(nbt); nbt.setInteger("dyeID", this.dyeID); nbt.setBoolean("canReceive", this.canReceive); + nbt.setBoolean("attackEntities", this.attackEntities); } } From 0496b44c0d32e6befaf38ffa2a5d72d3dd0504ea Mon Sep 17 00:00:00 2001 From: Calclavia Date: Sat, 3 Aug 2013 16:39:11 -0400 Subject: [PATCH 5/7] Added some raytrace functions --- src/resonantinduction/base/Vector3.java | 67 +++++++++++++++++++++++++ 1 file changed, 67 insertions(+) diff --git a/src/resonantinduction/base/Vector3.java b/src/resonantinduction/base/Vector3.java index e47e1f95f..e19b74326 100644 --- a/src/resonantinduction/base/Vector3.java +++ b/src/resonantinduction/base/Vector3.java @@ -3,8 +3,13 @@ */ package resonantinduction.base; +import java.util.List; + import net.minecraft.entity.Entity; import net.minecraft.tileentity.TileEntity; +import net.minecraft.util.AxisAlignedBB; +import net.minecraft.util.MovingObjectPosition; +import net.minecraft.util.Vec3; import net.minecraft.world.World; /** @@ -218,6 +223,68 @@ public class Vector3 return world.getBlockTileEntity((int) this.x, (int) this.y, (int) this.z); } + public MovingObjectPosition rayTraceEntities(World world, float rotationYaw, float rotationPitch, boolean collisionFlag, double reachDistance) + { + MovingObjectPosition pickedEntity = null; + Vec3 startingPosition = this.toVec3(); + Vec3 look = getDeltaPositionFromRotation(rotationYaw, rotationPitch).toVec3(); + Vec3 reachPoint = Vec3.createVectorHelper(startingPosition.xCoord + look.xCoord * reachDistance, startingPosition.yCoord + look.yCoord * reachDistance, startingPosition.zCoord + look.zCoord * reachDistance); + + double playerBorder = 1.1 * reachDistance; + AxisAlignedBB boxToScan = AxisAlignedBB.getAABBPool().getAABB(-playerBorder, -playerBorder, -playerBorder, playerBorder, playerBorder, playerBorder); + + @SuppressWarnings("unchecked") + List entitiesHit = world.getEntitiesWithinAABBExcludingEntity(null, boxToScan); + double closestEntity = reachDistance; + + if (entitiesHit == null || entitiesHit.isEmpty()) + { + return null; + } + for (Entity entityHit : entitiesHit) + { + if (entityHit != null && entityHit.canBeCollidedWith() && entityHit.boundingBox != null) + { + float border = entityHit.getCollisionBorderSize(); + AxisAlignedBB aabb = entityHit.boundingBox.expand(border, border, border); + MovingObjectPosition hitMOP = aabb.calculateIntercept(startingPosition, reachPoint); + + if (hitMOP != null) + { + if (aabb.isVecInside(startingPosition)) + { + if (0.0D < closestEntity || closestEntity == 0.0D) + { + pickedEntity = new MovingObjectPosition(entityHit); + if (pickedEntity != null) + { + pickedEntity.hitVec = hitMOP.hitVec; + closestEntity = 0.0D; + } + } + } + else + { + double distance = startingPosition.distanceTo(hitMOP.hitVec); + + if (distance < closestEntity || closestEntity == 0.0D) + { + pickedEntity = new MovingObjectPosition(entityHit); + pickedEntity.hitVec = hitMOP.hitVec; + closestEntity = distance; + } + } + } + } + } + return pickedEntity; + } + + private Vec3 toVec3() + { + return Vec3.createVectorHelper(this.x, this.y, this.z); + } + @Override public Vector3 clone() { From d18265e44bf78460329ec65f8a7f1e51f92eb5a7 Mon Sep 17 00:00:00 2001 From: Calclavia Date: Sat, 3 Aug 2013 16:50:37 -0400 Subject: [PATCH 6/7] Made Tesla do raytrace --- src/resonantinduction/base/Vector3.java | 9 + src/resonantinduction/tesla/BlockTesla.java | 10 + .../tesla/TileEntityTesla.java | 271 +++++++++--------- 3 files changed, 159 insertions(+), 131 deletions(-) diff --git a/src/resonantinduction/base/Vector3.java b/src/resonantinduction/base/Vector3.java index e19b74326..176c2b98e 100644 --- a/src/resonantinduction/base/Vector3.java +++ b/src/resonantinduction/base/Vector3.java @@ -208,6 +208,15 @@ public class Vector3 return new Vector3(Math.cos(Math.toRadians(rotationYaw)), Math.sin(Math.toRadians(rotationPitch)), Math.sin(Math.toRadians(rotationYaw))); } + public double[] getDeltaRotationFromPosition() + { + double rotationYaw = Math.toDegrees(Math.atan2(this.z, this.x)); + double rotationPitch = Math.toDegrees(Math.asin(this.y)); + rotationYaw = rotationYaw - 90; + rotationPitch = -rotationPitch; + return new double[] { rotationPitch, rotationYaw }; + } + public double getAngle(Vector3 vector) { return this.getAnglePreNorm(vector.clone().normalize()); diff --git a/src/resonantinduction/tesla/BlockTesla.java b/src/resonantinduction/tesla/BlockTesla.java index 97997ffef..6a687c6b6 100644 --- a/src/resonantinduction/tesla/BlockTesla.java +++ b/src/resonantinduction/tesla/BlockTesla.java @@ -47,6 +47,16 @@ public class BlockTesla extends BlockBase implements ITileEntityProvider { tileEntity.setDye(entityPlayer.getCurrentEquippedItem().getItemDamage()); + if (!entityPlayer.capabilities.isCreativeMode) + { + entityPlayer.inventory.decrStackSize(entityPlayer.inventory.currentItem, 1); + } + return true; + } + else if (entityPlayer.getCurrentEquippedItem().itemID == Item.redstone.itemID) + { + tileEntity.toggleEntityAttack(); + if (!entityPlayer.capabilities.isCreativeMode) { entityPlayer.inventory.decrStackSize(entityPlayer.inventory.currentItem, 1); diff --git a/src/resonantinduction/tesla/TileEntityTesla.java b/src/resonantinduction/tesla/TileEntityTesla.java index e9f5390c3..c7e5cc152 100644 --- a/src/resonantinduction/tesla/TileEntityTesla.java +++ b/src/resonantinduction/tesla/TileEntityTesla.java @@ -19,6 +19,7 @@ import net.minecraft.tileentity.TileEntity; import net.minecraft.tileentity.TileEntityFurnace; import net.minecraft.util.AxisAlignedBB; import net.minecraft.util.DamageSource; +import net.minecraft.util.MovingObjectPosition; import resonantinduction.ITesla; import resonantinduction.PacketHandler; import resonantinduction.ResonantInduction; @@ -79,175 +80,183 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe /** * Only transfer if it is the bottom controlling Tesla tower. */ - // TODO: Fix client side issue. || this.worldObj.isRemote - if (this.ticks % (5 + this.worldObj.rand.nextInt(2)) == 0 && this.isController() && ((this.getEnergyStored() > 0 && this.doTransfer) || this.worldObj.isRemote) && !this.worldObj.isBlockIndirectlyGettingPowered(this.xCoord, this.yCoord, this.zCoord)) + if (this.isController()) { - List transferTeslaCoils = new ArrayList(); - - for (ITesla tesla : TeslaGrid.instance().get()) + // 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 (new Vector3((TileEntity) tesla).distance(new Vector3(this)) < this.getRange()) + List transferTeslaCoils = new ArrayList(); + + for (ITesla tesla : TeslaGrid.instance().get()) { - /** - * Make sure Tesla is not part of this tower. - */ - if (!this.connectedTeslas.contains(tesla) && tesla.canReceive(this)) + if (new Vector3((TileEntity) tesla).distance(new Vector3(this)) < this.getRange()) { - if (tesla instanceof TileEntityTesla) + /** + * Make sure Tesla is not part of this tower. + */ + if (!this.connectedTeslas.contains(tesla) && tesla.canReceive(this)) { - if (((TileEntityTesla) tesla).getHeight() <= 1) + if (tesla instanceof TileEntityTesla) { - continue; + if (((TileEntityTesla) tesla).getHeight() <= 1) + { + continue; + } + + tesla = ((TileEntityTesla) tesla).getControllingTelsa(); } - tesla = ((TileEntityTesla) tesla).getControllingTelsa(); + transferTeslaCoils.add(tesla); + } + } + } + + 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)); + + if (distance1 < distance2) + { + return 1; + } + else if (distance1 > distance2) + { + return -1; } - transferTeslaCoils.add(tesla); + 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) + { + this.worldObj.playSoundEffect(this.xCoord + 0.5, this.yCoord + 0.5, this.zCoord + 0.5, ResonantInduction.PREFIX + "electricshock", this.getEnergyStored() / 25, (float) (1.3f - 0.5f * ((float) 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); + + tesla.transfer(transferEnergy * (1 - (this.worldObj.rand.nextFloat() * 0.1f))); + this.transfer(-transferEnergy); + + if (this.attackEntities && this.zapCounter % 10 == 0) + { + double[] rotations = topTeslaVector.getDeltaRotationFromPosition(); + MovingObjectPosition mop = topTeslaVector.rayTraceEntities(this.worldObj, (float) rotations[1], (float) rotations[0], true, distance); + System.out.println("HIT " + mop); + + if (mop != null && mop.entityHit != null) + { + if (mop.entityHit instanceof EntityLivingBase) + { + mop.entityHit.attackEntityFrom(DamageSource.magic, 1); + ResonantInduction.proxy.renderElectricShock(this.worldObj, new Vector3(topTesla).translate(new Vector3(0.5)), new Vector3(mop.entityHit)); + } + } + } + + if (count++ > 1) + { + break; + } } } - } - final TileEntityTesla topTesla = this.getTopTelsa(); + this.zapCounter++; + this.outputBlacklist.clear(); + } /** - * Sort by distance. + * Draws power from furnace below it. + * + * @author Calclavia */ - Collections.sort(transferTeslaCoils, new Comparator() + TileEntity tileEntity = this.worldObj.getBlockTileEntity(this.xCoord, this.yCoord - 1, this.zCoord); + + if (tileEntity instanceof TileEntityFurnace) { - public int compare(ITesla o1, ITesla o2) + TileEntityFurnace furnaceTile = (TileEntityFurnace) tileEntity; + + if (furnaceTile.getStackInSlot(0) == null) { - double distance1 = new Vector3(topTesla).distance(new Vector3((TileEntity) o1)); - double distance2 = new Vector3(topTesla).distance(new Vector3((TileEntity) o2)); + /** + * Steal power from furnace. + */ + boolean doBlockStateUpdate = furnaceTile.furnaceBurnTime > 0; - if (distance1 < distance2) + if (furnaceTile.furnaceBurnTime == 0) { - return 1; + int burnTime = TileEntityFurnace.getItemBurnTime(furnaceTile.getStackInSlot(1)); + + if (burnTime > 0) + { + furnaceTile.decrStackSize(1, 1); + furnaceTile.furnaceBurnTime = burnTime; + } } - else if (distance1 > distance2) + else { - return -1; + this.transfer(ResonantInduction.POWER_PER_COAL / 20); + this.worldObj.markBlockForUpdate(this.xCoord, this.yCoord, this.zCoord); } - 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) + if (doBlockStateUpdate != furnaceTile.furnaceBurnTime > 0) { - this.worldObj.playSoundEffect(this.xCoord + 0.5, this.yCoord + 0.5, this.zCoord + 0.5, ResonantInduction.PREFIX + "electricshock", this.getEnergyStored() / 25, (float) (1.3f - 0.5f * ((float) this.dyeID / 16f))); - } - - Vector3 teslaVector = new Vector3((TileEntity) tesla); - - if (tesla instanceof TileEntityTesla) - { - ((TileEntityTesla) tesla).getControllingTelsa().outputBlacklist.add(this); - teslaVector = new Vector3(((TileEntityTesla) tesla).getTopTelsa()); - } - - ResonantInduction.proxy.renderElectricShock(this.worldObj, new Vector3(topTesla).translate(new Vector3(0.5)), teslaVector.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))); - this.transfer(-transferEnergy); - - if (count++ > 1) - { - break; + BlockFurnace.updateFurnaceBlockState(furnaceTile.furnaceBurnTime > 0, furnaceTile.worldObj, furnaceTile.xCoord, furnaceTile.yCoord, furnaceTile.zCoord); } } - - if (this.attackEntities && this.zapCounter % 10 == 0) + else if (this.getEnergyStored() > ResonantInduction.POWER_PER_COAL / 20 && furnaceTile.getStackInSlot(1) == null && FurnaceRecipes.smelting().getSmeltingResult(furnaceTile.getStackInSlot(0)) != null) { - int radius = 3; - List entities = this.worldObj.getEntitiesWithinAABB(EntityLivingBase.class, AxisAlignedBB.getAABBPool().getAABB(this.xCoord - radius, this.yCoord - radius, this.zCoord - radius, this.xCoord + radius, this.yCoord + radius, this.zCoord + radius)); + /** + * Inject power to furnace. + */ + boolean doBlockStateUpdate = furnaceTile.furnaceBurnTime > 0; - for (EntityLivingBase entity : entities) - { - entity.attackEntityFrom(DamageSource.magic, 1); - ResonantInduction.proxy.renderElectricShock(this.worldObj, new Vector3(topTesla).translate(new Vector3(0.5)), new Vector3(entity)); - } - } - } - - this.zapCounter++; - this.outputBlacklist.clear(); - } - - /** - * Draws power from furnace below it. - * - * @author Calclavia - */ - TileEntity tileEntity = this.worldObj.getBlockTileEntity(this.xCoord, this.yCoord - 1, this.zCoord); - - if (tileEntity instanceof TileEntityFurnace) - { - TileEntityFurnace furnaceTile = (TileEntityFurnace) tileEntity; - - if (furnaceTile.getStackInSlot(0) == null) - { - /** - * Steal power from furnace. - */ - boolean doBlockStateUpdate = furnaceTile.furnaceBurnTime > 0; - - if (furnaceTile.furnaceBurnTime == 0) - { - int burnTime = TileEntityFurnace.getItemBurnTime(furnaceTile.getStackInSlot(1)); - - if (burnTime > 0) - { - furnaceTile.decrStackSize(1, 1); - furnaceTile.furnaceBurnTime = burnTime; - } - } - else - { - this.transfer(ResonantInduction.POWER_PER_COAL / 20); + furnaceTile.furnaceBurnTime += 2; + this.transfer(-ResonantInduction.POWER_PER_COAL / 20); this.worldObj.markBlockForUpdate(this.xCoord, this.yCoord, this.zCoord); - } - if (doBlockStateUpdate != furnaceTile.furnaceBurnTime > 0) - { - BlockFurnace.updateFurnaceBlockState(furnaceTile.furnaceBurnTime > 0, furnaceTile.worldObj, furnaceTile.xCoord, furnaceTile.yCoord, furnaceTile.zCoord); + if (doBlockStateUpdate != furnaceTile.furnaceBurnTime > 0) + { + BlockFurnace.updateFurnaceBlockState(furnaceTile.furnaceBurnTime > 0, furnaceTile.worldObj, furnaceTile.xCoord, furnaceTile.yCoord, furnaceTile.zCoord); + } } } - else if (this.getEnergyStored() > ResonantInduction.POWER_PER_COAL / 20 && furnaceTile.getStackInSlot(1) == null && FurnaceRecipes.smelting().getSmeltingResult(furnaceTile.getStackInSlot(0)) != null) + + if (!this.worldObj.isRemote && this.getEnergyStored() > 0 != doPacketUpdate) { - /** - * Inject power to furnace. - */ - boolean doBlockStateUpdate = furnaceTile.furnaceBurnTime > 0; - - furnaceTile.furnaceBurnTime += 2; - this.transfer(-ResonantInduction.POWER_PER_COAL / 20); this.worldObj.markBlockForUpdate(this.xCoord, this.yCoord, this.zCoord); - - if (doBlockStateUpdate != furnaceTile.furnaceBurnTime > 0) - { - BlockFurnace.updateFurnaceBlockState(furnaceTile.furnaceBurnTime > 0, furnaceTile.worldObj, furnaceTile.xCoord, furnaceTile.yCoord, furnaceTile.zCoord); - } } } - if (!this.worldObj.isRemote && this.getEnergyStored() > 0 != doPacketUpdate) - { - this.worldObj.markBlockForUpdate(this.xCoord, this.yCoord, this.zCoord); - } - this.clearCache(); } From 3aab19b32e8f015cfe5f3ea6c3f4acd888a83cec Mon Sep 17 00:00:00 2001 From: Calclavia Date: Sat, 3 Aug 2013 17:19:04 -0400 Subject: [PATCH 7/7] Some more work on entity shock raytrace --- src/resonantinduction/base/Vector3.java | 16 ++++++++-------- src/resonantinduction/tesla/TileEntityTesla.java | 9 +++++---- 2 files changed, 13 insertions(+), 12 deletions(-) diff --git a/src/resonantinduction/base/Vector3.java b/src/resonantinduction/base/Vector3.java index 176c2b98e..cb6d73862 100644 --- a/src/resonantinduction/base/Vector3.java +++ b/src/resonantinduction/base/Vector3.java @@ -8,6 +8,7 @@ import java.util.List; import net.minecraft.entity.Entity; import net.minecraft.tileentity.TileEntity; import net.minecraft.util.AxisAlignedBB; +import net.minecraft.util.MathHelper; import net.minecraft.util.MovingObjectPosition; import net.minecraft.util.Vec3; import net.minecraft.world.World; @@ -201,7 +202,7 @@ public class Vector3 return axis.getRotationMatrix(angle); } - public static Vector3 getDeltaPositionFromRotation(float rotationYaw, float rotationPitch) + public static Vector3 getDeltaPositionFromRotation(double rotationYaw, double rotationPitch) { rotationYaw = rotationYaw + 90; rotationPitch = -rotationPitch; @@ -210,11 +211,11 @@ public class Vector3 public double[] getDeltaRotationFromPosition() { - double rotationYaw = Math.toDegrees(Math.atan2(this.z, this.x)); double rotationPitch = Math.toDegrees(Math.asin(this.y)); + double rotationYaw = Math.toDegrees(Math.atan2(this.z, this.x)); rotationYaw = rotationYaw - 90; rotationPitch = -rotationPitch; - return new double[] { rotationPitch, rotationYaw }; + return new double[] { MathHelper.wrapAngleTo180_double(rotationYaw), MathHelper.wrapAngleTo180_double(rotationPitch) }; } public double getAngle(Vector3 vector) @@ -232,20 +233,19 @@ public class Vector3 return world.getBlockTileEntity((int) this.x, (int) this.y, (int) this.z); } - public MovingObjectPosition rayTraceEntities(World world, float rotationYaw, float rotationPitch, boolean collisionFlag, double reachDistance) + public MovingObjectPosition rayTraceEntities(World world, double rotationYaw, double rotationPitch, double reachDistance) { MovingObjectPosition pickedEntity = null; Vec3 startingPosition = this.toVec3(); Vec3 look = getDeltaPositionFromRotation(rotationYaw, rotationPitch).toVec3(); Vec3 reachPoint = Vec3.createVectorHelper(startingPosition.xCoord + look.xCoord * reachDistance, startingPosition.yCoord + look.yCoord * reachDistance, startingPosition.zCoord + look.zCoord * reachDistance); - double playerBorder = 1.1 * reachDistance; - AxisAlignedBB boxToScan = AxisAlignedBB.getAABBPool().getAABB(-playerBorder, -playerBorder, -playerBorder, playerBorder, playerBorder, playerBorder); - + double checkBorder = 1.1 * reachDistance; + AxisAlignedBB boxToScan = AxisAlignedBB.getAABBPool().getAABB(-checkBorder, -checkBorder, -checkBorder, checkBorder, checkBorder, checkBorder).offset(this.x, this.y, this.z);; + @SuppressWarnings("unchecked") List entitiesHit = world.getEntitiesWithinAABBExcludingEntity(null, boxToScan); double closestEntity = reachDistance; - if (entitiesHit == null || entitiesHit.isEmpty()) { return null; diff --git a/src/resonantinduction/tesla/TileEntityTesla.java b/src/resonantinduction/tesla/TileEntityTesla.java index c7e5cc152..f1fa0c9ee 100644 --- a/src/resonantinduction/tesla/TileEntityTesla.java +++ b/src/resonantinduction/tesla/TileEntityTesla.java @@ -167,11 +167,12 @@ public class TileEntityTesla extends TileEntityBase implements ITesla, IPacketRe tesla.transfer(transferEnergy * (1 - (this.worldObj.rand.nextFloat() * 0.1f))); this.transfer(-transferEnergy); - if (this.attackEntities && this.zapCounter % 10 == 0) + if (this.attackEntities && this.zapCounter % 5 == 0) { - double[] rotations = topTeslaVector.getDeltaRotationFromPosition(); - MovingObjectPosition mop = topTeslaVector.rayTraceEntities(this.worldObj, (float) rotations[1], (float) rotations[0], true, distance); - System.out.println("HIT " + mop); + double[] rotations = topTeslaVector.difference(targetVector).normalize().getDeltaRotationFromPosition(); + MovingObjectPosition mop = topTeslaVector.rayTraceEntities(this.worldObj, rotations[0], rotations[1], distance); + // System.out.println(Vector3.getDeltaPositionFromRotation(rotations[0], + // rotations[1]) + " :" + mop); if (mop != null && mop.entityHit != null) {