Posted May 15, 201312 yr I've got an interesting problem for you. Minecraft crashes seemingly randomly when my arrow-like entity is in the world. It only happens occasionally and at any point of the flight path. The weird part is that the console says the crash was caused by some other entity, like a sheep, creeper, etc. instead of my entity. I have no idea what I've done wrong so I've come to the experts. Here's an example of the crash log: 2013-05-14 18:14:50 [iNFO] [sTDERR] net.minecraft.util.ReportedException: Ticking entity 2013-05-14 18:14:50 [iNFO] [sTDERR] at net.minecraft.world.World.updateEntities(World.java:2158) 2013-05-14 18:14:50 [iNFO] [sTDERR] at net.minecraft.client.Minecraft.runTick(Minecraft.java:1849) 2013-05-14 18:14:50 [iNFO] [sTDERR] at net.minecraft.client.Minecraft.runGameLoop(Minecraft.java:831) 2013-05-14 18:14:50 [iNFO] [sTDERR] at net.minecraft.client.Minecraft.run(Minecraft.java:756) 2013-05-14 18:14:50 [iNFO] [sTDERR] at java.lang.Thread.run(Thread.java:680) 2013-05-14 18:14:50 [iNFO] [sTDERR] Caused by: java.lang.NullPointerException 2013-05-14 18:14:50 [iNFO] [sTDERR] at net.minecraft.entity.Entity.moveEntity(Entity.java:762) 2013-05-14 18:14:50 [iNFO] [sTDERR] at net.minecraft.entity.EntityLiving.moveEntityWithHeading(EntityLiving.java:1578) 2013-05-14 18:14:50 [iNFO] [sTDERR] at net.minecraft.entity.EntityLiving.onLivingUpdate(EntityLiving.java:1875) 2013-05-14 18:14:50 [iNFO] [sTDERR] at net.minecraft.entity.monster.EntityMob.onLivingUpdate(EntityMob.java:37) 2013-05-14 18:14:50 [iNFO] [sTDERR] at net.minecraft.entity.EntityLiving.onUpdate(EntityLiving.java:856) 2013-05-14 18:14:50 [iNFO] [sTDERR] at net.minecraft.entity.monster.EntityMob.onUpdate(EntityMob.java:45) 2013-05-14 18:14:50 [iNFO] [sTDERR] at net.minecraft.entity.monster.EntitySpider.onUpdate(EntitySpider.java:34) 2013-05-14 18:14:50 [iNFO] [sTDERR] at net.minecraft.world.World.updateEntityWithOptionalForce(World.java:2327) 2013-05-14 18:14:50 [iNFO] [sTDERR] at net.minecraft.world.World.updateEntity(World.java:2289) 2013-05-14 18:14:50 [iNFO] [sTDERR] at net.minecraft.world.World.updateEntities(World.java:2143) 2013-05-14 18:14:50 [iNFO] [sTDERR] ... 4 more And here's my entity class: package rekkyn.spacetime.entity; import java.util.List; import net.minecraft.block.Block; import net.minecraft.enchantment.EnchantmentThorns; import net.minecraft.entity.Entity; import net.minecraft.entity.EntityLiving; import net.minecraft.entity.IProjectile; import net.minecraft.entity.monster.EntityEnderman; import net.minecraft.entity.player.EntityPlayer; import net.minecraft.entity.player.EntityPlayerMP; import net.minecraft.nbt.NBTTagCompound; import net.minecraft.network.packet.Packet70GameEvent; import net.minecraft.util.AxisAlignedBB; import net.minecraft.util.DamageSource; import net.minecraft.util.MathHelper; import net.minecraft.util.MovingObjectPosition; import net.minecraft.util.Vec3; import net.minecraft.world.World; import rekkyn.spacetime.particles.ParticleEffects; import cpw.mods.fml.common.registry.IThrowableEntity; import cpw.mods.fml.relauncher.Side; import cpw.mods.fml.relauncher.SideOnly; public class EntityCrossbowBolt extends Entity implements IProjectile { private int xTile = -1; private int yTile = -1; private int zTile = -1; private int inTile = 0; private int inData = 0; private boolean inGround = false; /** Seems to be some sort of timer for animating an arrow. */ public int arrowShake = 0; /** The owner of this arrow. */ public Entity shootingEntity; private int ticksInGround; private int ticksInAir = 0; private double damage = 2.0D; /** The amount of knockback an arrow applies when it hits a mob. */ private int knockbackStrength; public EntityCrossbowBolt(World par1World) { super(par1World); renderDistanceWeight = 10.0D; this.setSize(0.5F, 0.5F); } public EntityCrossbowBolt(World world, double posX, double posY, double posZ) { super(world); renderDistanceWeight = 10.0D; this.setSize(0.5F, 0.5F); this.setPosition(posX, posY, posZ); yOffset = 0.0F; } public EntityCrossbowBolt(World world, EntityLiving shootingEntity, EntityLiving par3EntityLiving, float power, float par5) { super(world); renderDistanceWeight = 10.0D; this.shootingEntity = shootingEntity; posY = shootingEntity.posY + shootingEntity.getEyeHeight() - 0.10000000149011612D; double d0 = par3EntityLiving.posX - shootingEntity.posX; double d1 = par3EntityLiving.boundingBox.minY + par3EntityLiving.height / 3.0F - posY; double d2 = par3EntityLiving.posZ - shootingEntity.posZ; double d3 = MathHelper.sqrt_double(d0 * d0 + d2 * d2); if (d3 >= 1.0E-7D) { float f2 = (float) (Math.atan2(d2, d0) * 180.0D / Math.PI) - 90.0F; float f3 = (float) -(Math.atan2(d1, d3) * 180.0D / Math.PI); double d4 = d0 / d3; double d5 = d2 / d3; this.setLocationAndAngles(shootingEntity.posX + d4, posY, shootingEntity.posZ + d5, f2, f3); yOffset = 0.0F; float f4 = (float) d3 * 0.2F; this.setThrowableHeading(d0, d1 + f4, d2, power, par5); } } public EntityCrossbowBolt(World world, EntityLiving shootingEntity, float power) { super(world); renderDistanceWeight = 10.0D; this.shootingEntity = shootingEntity; this.setSize(0.5F, 0.5F); this.setLocationAndAngles(shootingEntity.posX, shootingEntity.posY + shootingEntity.getEyeHeight(), shootingEntity.posZ, shootingEntity.rotationYaw, shootingEntity.rotationPitch); posX -= MathHelper.cos(rotationYaw / 180.0F * (float) Math.PI) * 0.16F; posY -= 0.10000000149011612D; posZ -= MathHelper.sin(rotationYaw / 180.0F * (float) Math.PI) * 0.16F; this.setPosition(posX, posY, posZ); yOffset = 0.0F; motionX = -MathHelper.sin(rotationYaw / 180.0F * (float) Math.PI) * MathHelper.cos(rotationPitch / 180.0F * (float) Math.PI); motionZ = MathHelper.cos(rotationYaw / 180.0F * (float) Math.PI) * MathHelper.cos(rotationPitch / 180.0F * (float) Math.PI); motionY = -MathHelper.sin(rotationPitch / 180.0F * (float) Math.PI); this.setThrowableHeading(motionX, motionY, motionZ, power * 5.0F, 1.0F); } @Override protected void entityInit() { dataWatcher.addObject(16, Byte.valueOf((byte) 0)); } /** * Similar to setArrowHeading, it's point the throwable entity to a x, y, z * direction. */ @Override public void setThrowableHeading(double x, double y, double z, float power, float par8) { float f2 = MathHelper.sqrt_double(x * x + y * y + z * z); x /= f2; y /= f2; z /= f2; x += rand.nextGaussian() * (rand.nextBoolean() ? -1 : 1) * 0.007499999832361937D * par8; y += rand.nextGaussian() * (rand.nextBoolean() ? -1 : 1) * 0.007499999832361937D * par8; z += rand.nextGaussian() * (rand.nextBoolean() ? -1 : 1) * 0.007499999832361937D * par8; x *= power; y *= power; z *= power; motionX = x; motionY = y; motionZ = z; float f3 = MathHelper.sqrt_double(x * x + z * z); prevRotationYaw = rotationYaw = (float) (Math.atan2(x, z) * 180.0D / Math.PI); prevRotationPitch = rotationPitch = (float) (Math.atan2(y, f3) * 180.0D / Math.PI); ticksInGround = 0; } @Override @SideOnly(Side.CLIENT) /** * Sets the position and rotation. Only difference from the other one is no bounding on the rotation. Args: posX, * posY, posZ, yaw, pitch */ public void setPositionAndRotation2(double x, double y, double z, float par7, float par8, int par9) { this.setPosition(x, y, z); this.setRotation(par7, par8); } @Override @SideOnly(Side.CLIENT) /** * Sets the velocity to the args. Args: x, y, z */ public void setVelocity(double motionX, double motionY, double motionZ) { this.motionX = motionX; this.motionY = motionY; this.motionZ = motionZ; if (prevRotationPitch == 0.0F && prevRotationYaw == 0.0F) { float f = MathHelper.sqrt_double(motionX * motionX + motionZ * motionZ); prevRotationYaw = rotationYaw = (float) (Math.atan2(motionX, motionZ) * 180.0D / Math.PI); prevRotationPitch = rotationPitch = (float) (Math.atan2(motionY, f) * 180.0D / Math.PI); prevRotationPitch = rotationPitch; prevRotationYaw = rotationYaw; this.setLocationAndAngles(posX, posY, posZ, rotationYaw, rotationPitch); ticksInGround = 0; } } /** * Called to update the entity's position/logic. */ @Override public void onUpdate() { super.onUpdate(); if (prevRotationPitch == 0.0F && prevRotationYaw == 0.0F) { float f = MathHelper.sqrt_double(motionX * motionX + motionZ * motionZ); prevRotationYaw = rotationYaw = (float) (Math.atan2(motionX, motionZ) * 180.0D / Math.PI); prevRotationPitch = rotationPitch = (float) (Math.atan2(motionY, f) * 180.0D / Math.PI); } int i = worldObj.getBlockId(xTile, yTile, zTile); if (i > 0) { Block.blocksList.setBlockBoundsBasedOnState(worldObj, xTile, yTile, zTile); AxisAlignedBB axisalignedbb = Block.blocksList.getCollisionBoundingBoxFromPool(worldObj, xTile, yTile, zTile); if (axisalignedbb != null && axisalignedbb.isVecInside(worldObj.getWorldVec3Pool().getVecFromPool(posX, posY, posZ))) { inGround = true; } } if (arrowShake > 0) { --arrowShake; } if (inGround) { this.setDead(); int j = worldObj.getBlockId(xTile, yTile, zTile); int k = worldObj.getBlockMetadata(xTile, yTile, zTile); if (j == inTile && k == inData) { ++ticksInGround; if (ticksInGround == 1200) { this.setDead(); } } else { inGround = false; motionX *= rand.nextFloat() * 0.2F; motionY *= rand.nextFloat() * 0.2F; motionZ *= rand.nextFloat() * 0.2F; ticksInGround = 0; ticksInAir = 0; } } else { ++ticksInAir; if (ticksInAir == 1200) { this.setDead(); } /*if (posY >= 256) { this.setDead(); }*/ Vec3 vec3 = worldObj.getWorldVec3Pool().getVecFromPool(posX, posY, posZ); Vec3 vec31 = worldObj.getWorldVec3Pool().getVecFromPool(posX + motionX, posY + motionY, posZ + motionZ); MovingObjectPosition movingobjectposition = worldObj.rayTraceBlocks_do_do(vec3, vec31, false, true); vec3 = worldObj.getWorldVec3Pool().getVecFromPool(posX, posY, posZ); vec31 = worldObj.getWorldVec3Pool().getVecFromPool(posX + motionX, posY + motionY, posZ + motionZ); if (movingobjectposition != null) { vec31 = worldObj.getWorldVec3Pool().getVecFromPool(movingobjectposition.hitVec.xCoord, movingobjectposition.hitVec.yCoord, movingobjectposition.hitVec.zCoord); } Entity entity = null; List list = worldObj.getEntitiesWithinAABBExcludingEntity(this, boundingBox.addCoord(motionX, motionY, motionZ).expand(1.0D, 1.0D, 1.0D)); double d0 = 0.0D; int l; float f1; for (l = 0; l < list.size(); ++l) { Entity entity1 = (Entity) list.get(l); if (entity1.canBeCollidedWith() && (entity1 != shootingEntity || ticksInAir >= 5)) { f1 = 0.3F; AxisAlignedBB axisalignedbb1 = entity1.boundingBox.expand(f1, f1, f1); MovingObjectPosition movingobjectposition1 = axisalignedbb1.calculateIntercept(vec3, vec31); if (movingobjectposition1 != null) { double d1 = vec3.distanceTo(movingobjectposition1.hitVec); if (d1 < d0 || d0 == 0.0D) { entity = entity1; d0 = d1; } } } } if (entity != null) { movingobjectposition = new MovingObjectPosition(entity); } if (movingobjectposition != null && movingobjectposition.entityHit != null && movingobjectposition.entityHit instanceof EntityPlayer) { EntityPlayer entityplayer = (EntityPlayer) movingobjectposition.entityHit; if (entityplayer.capabilities.disableDamage || shootingEntity instanceof EntityPlayer && !((EntityPlayer) shootingEntity).func_96122_a(entityplayer)) { movingobjectposition = null; } } float f2; float f3; if (movingobjectposition != null) { if (movingobjectposition.entityHit != null) { f2 = MathHelper.sqrt_double(motionX * motionX + motionY * motionY + motionZ * motionZ); int i1 = MathHelper.ceiling_double_int(f2 * damage); DamageSource damagesource = null; if (shootingEntity == null) { damagesource = DamageSource.causeThrownDamage(this, this); } else { damagesource = DamageSource.causeThrownDamage(this, shootingEntity); } if (this.isBurning() && !(movingobjectposition.entityHit instanceof EntityEnderman)) { movingobjectposition.entityHit.setFire(5); } if (movingobjectposition.entityHit.attackEntityFrom(damagesource, i1)) { if (movingobjectposition.entityHit instanceof EntityLiving) { EntityLiving entityliving = (EntityLiving) movingobjectposition.entityHit; if (!worldObj.isRemote) { entityliving.setArrowCountInEntity(entityliving.getArrowCountInEntity() + 1); } if (knockbackStrength > 0) { f3 = MathHelper.sqrt_double(motionX * motionX + motionZ * motionZ); if (f3 > 0.0F) { movingobjectposition.entityHit.addVelocity(motionX * knockbackStrength * 0.6000000238418579D / f3, 0.1D, motionZ * knockbackStrength * 0.6000000238418579D / f3); } } if (shootingEntity != null) { EnchantmentThorns.func_92096_a(shootingEntity, entityliving, rand); } if (shootingEntity != null && movingobjectposition.entityHit != shootingEntity && movingobjectposition.entityHit instanceof EntityPlayer && shootingEntity instanceof EntityPlayerMP) { ((EntityPlayerMP) shootingEntity).playerNetServerHandler .sendPacketToPlayer(new Packet70GameEvent(6, 0)); } } this.playSound("random.bowhit", 1.0F, 1.2F / (rand.nextFloat() * 0.2F + 0.9F)); if (!(movingobjectposition.entityHit instanceof EntityEnderman)) { this.setDead(); } } else { motionX *= -0.10000000149011612D; motionY *= -0.10000000149011612D; motionZ *= -0.10000000149011612D; rotationYaw += 180.0F; prevRotationYaw += 180.0F; ticksInAir = 0; } } else { xTile = movingobjectposition.blockX; yTile = movingobjectposition.blockY; zTile = movingobjectposition.blockZ; inTile = worldObj.getBlockId(xTile, yTile, zTile); inData = worldObj.getBlockMetadata(xTile, yTile, zTile); motionX = (float) (movingobjectposition.hitVec.xCoord - posX); motionY = (float) (movingobjectposition.hitVec.yCoord - posY); motionZ = (float) (movingobjectposition.hitVec.zCoord - posZ); f2 = MathHelper.sqrt_double(motionX * motionX + motionY * motionY + motionZ * motionZ); posX -= motionX / f2 * 0.05000000074505806D; posY -= motionY / f2 * 0.05000000074505806D; posZ -= motionZ / f2 * 0.05000000074505806D; this.playSound("random.bowhit", 1.0F, 1.2F / (rand.nextFloat() * 0.2F + 0.9F)); inGround = true; arrowShake = 7; if (inTile != 0) { Block.blocksList[inTile].onEntityCollidedWithBlock(worldObj, xTile, yTile, zTile, this); } } } posX += motionX; posY += motionY; posZ += motionZ; f2 = MathHelper.sqrt_double(motionX * motionX + motionZ * motionZ); rotationYaw = (float) (Math.atan2(motionX, motionZ) * 180.0D / Math.PI); for (rotationPitch = (float) (Math.atan2(motionY, f2) * 180.0D / Math.PI); rotationPitch - prevRotationPitch < -180.0F; prevRotationPitch -= 360.0F) { ; } while (rotationPitch - prevRotationPitch >= 180.0F) { prevRotationPitch += 360.0F; } while (rotationYaw - prevRotationYaw < -180.0F) { prevRotationYaw -= 360.0F; } while (rotationYaw - prevRotationYaw >= 180.0F) { prevRotationYaw += 360.0F; } rotationPitch = prevRotationPitch + (rotationPitch - prevRotationPitch) * 0.2F; rotationYaw = prevRotationYaw + (rotationYaw - prevRotationYaw) * 0.2F; if (this.isInWater()) { for (int j1 = 0; j1 < 4; ++j1) { f3 = 0.25F; worldObj.spawnParticle("bubble", posX - motionX * f3, posY - motionY * f3, posZ - motionZ * f3, motionX, motionY, motionZ); } } for (int lmnop = 0; lmnop < 50; lmnop++) { float rand1 = (rand.nextFloat() - 0.5F) * 2; System.out.println(rand1); ParticleEffects.spawnParticle("crossbowTrail", posX + motionX * l / 4.0D, posY + motionY * l / 4.0D, posZ + motionZ * l / 4.0D, -motionX * rand1, (-motionY) * rand1, -motionZ * rand1); } this.setPosition(posX, posY, posZ); this.doBlockCollisions(); } } /** * (abstract) Protected helper method to write subclass entity data to NBT. */ @Override public void writeEntityToNBT(NBTTagCompound tagcompound) { tagcompound.setShort("xTile", (short) xTile); tagcompound.setShort("yTile", (short) yTile); tagcompound.setShort("zTile", (short) zTile); tagcompound.setByte("inTile", (byte) inTile); tagcompound.setByte("inData", (byte) inData); tagcompound.setByte("shake", (byte) arrowShake); tagcompound.setByte("inGround", (byte) (inGround ? 1 : 0)); tagcompound.setDouble("damage", damage); } /** * (abstract) Protected helper method to read subclass entity data from NBT. */ @Override public void readEntityFromNBT(NBTTagCompound tagcompound) { xTile = tagcompound.getShort("xTile"); yTile = tagcompound.getShort("yTile"); zTile = tagcompound.getShort("zTile"); inTile = tagcompound.getByte("inTile") & 255; inData = tagcompound.getByte("inData") & 255; arrowShake = tagcompound.getByte("shake") & 255; inGround = tagcompound.getByte("inGround") == 1; if (tagcompound.hasKey("damage")) { damage = tagcompound.getDouble("damage"); } } /** * returns if this entity triggers Block.onEntityWalking on the blocks they * walk on. used for spiders and wolves to prevent them from trampling crops */ @Override protected boolean canTriggerWalking() { return false; } @Override @SideOnly(Side.CLIENT) public float getShadowSize() { return 0.0F; } public void setDamage(double damage) { this.damage = damage; } public double getDamage() { return damage; } /** * Sets the amount of knockback the arrow applies when it hits a mob. */ public void setKnockbackStrength(int knockbackStrength) { this.knockbackStrength = knockbackStrength; } /** * If returns false, the item will not inflict any damage against entities. */ @Override public boolean canAttackWithItem() { return false; } } If you need to see more code you can check here: github.com/Rekkyn/spacetimemod Thanks in advance!
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.