From 420faddca46e70e3a70def168fb4e452ef193b0d Mon Sep 17 00:00:00 2001 From: OnyxDarkKnight Date: Sat, 21 Feb 2015 21:31:16 +0000 Subject: Added just a butt ton of stuff, also thanks to pau101 for helping me with the Hand Pedestal animation :) --- .../jewelrycraft/particles/EntityShadowsFX.java | 75 +++++++++++++--------- 1 file changed, 46 insertions(+), 29 deletions(-) (limited to 'java/darkknight/jewelrycraft/particles/EntityShadowsFX.java') diff --git a/java/darkknight/jewelrycraft/particles/EntityShadowsFX.java b/java/darkknight/jewelrycraft/particles/EntityShadowsFX.java index dea107b..85dfae5 100644 --- a/java/darkknight/jewelrycraft/particles/EntityShadowsFX.java +++ b/java/darkknight/jewelrycraft/particles/EntityShadowsFX.java @@ -2,48 +2,65 @@ package darkknight.jewelrycraft.particles; import java.util.Iterator; import java.util.List; - import net.minecraft.client.Minecraft; import net.minecraft.client.particle.EntityFX; import net.minecraft.client.renderer.Tessellator; import net.minecraft.entity.Entity; import net.minecraft.entity.projectile.EntityThrowable; import net.minecraft.util.AxisAlignedBB; -import net.minecraft.util.DamageSource; import net.minecraft.util.ResourceLocation; import net.minecraft.world.World; - import org.lwjgl.opengl.GL11; +import darkknight.jewelrycraft.damage.DamageSourceList; public class EntityShadowsFX extends EntityFX { float moteParticleScale; + ResourceLocation texture; - public EntityShadowsFX(World world, double x, double y, double z, float size, float maxAge) + /** + * @param world + * @param x + * @param y + * @param z + * @param size + * @param maxAge + * @param texture + */ + public EntityShadowsFX(World world, double x, double y, double z, float size, float maxAge, ResourceLocation texture) { super(world, x, y, z, 0D, 0D, 0D); - particleMaxAge = (int) (28D / (Math.random() * 0.3D + 0.7D) * maxAge); + particleMaxAge = (int)(28D / (Math.random() * 0.3D + 0.7D) * maxAge); particleGravity = 0F; motionX = motionY = motionZ = 0; particleScale *= size; moteParticleScale = particleScale; noClip = true; + this.texture = texture; setSize(0.01F, 0.01F); } + /** + * @param tessellator + * @param partialTicks + * @param minX + * @param minY + * @param minZ + * @param maxX + * @param maxZ + */ @Override public void renderParticle(Tessellator tessellator, float partialTicks, float minX, float minY, float minZ, float maxX, float maxZ) { tessellator.draw(); - ResourceLocation particle = new ResourceLocation("jewelrycraft", "textures/particle/shadows.png"); - Minecraft.getMinecraft().renderEngine.bindTexture(particle); + Minecraft.getMinecraft().renderEngine.bindTexture(texture); GL11.glColor4f(1, 1, 1, 1); tessellator.startDrawingQuads(); - tessellator.setBrightness(this.getBrightnessForRender(0)); + tessellator.setBrightness(getBrightnessForRender(0)); float scale = 0.1F * particleScale; - float x = (float) (posX - interpPosX); - float y = (float) (posY - interpPosY); - float z = (float) (posZ - interpPosZ); + float x = (float)(posX - interpPosX); + float y = (float)(posY - interpPosY); + float z = (float)(posZ - interpPosZ); tessellator.setColorRGBA_F(0F, 0F, 0F, 0.5F); tessellator.addVertexWithUV(x - minX * scale - maxX * scale, y - minY * scale, z - minZ * scale - maxZ * scale, 0, 0); tessellator.addVertexWithUV(x - minX * scale + maxX * scale, y + minY * scale, z - minZ * scale + maxZ * scale, 1, 0); @@ -53,35 +70,35 @@ public class EntityShadowsFX extends EntityFX tessellator.startDrawingQuads(); } + /** + * + */ + @Override public void onUpdate() { - this.prevPosX = this.posX; - this.prevPosY = this.posY; - this.prevPosZ = this.posZ; + prevPosX = posX; + prevPosY = posY; + prevPosZ = posZ; motionX = motionY = motionZ = 0; - - if (this.particleAge++ >= this.particleMaxAge) - { - this.setDead(); - } - AxisAlignedBB axisalignedbb = this.boundingBox.expand(16.0D, 16.0D, 16.0D); - List list1 = this.worldObj.getEntitiesWithinAABB(Entity.class, axisalignedbb); - if (!this.worldObj.isRemote && list1 != null && !list1.isEmpty()) - { + if (particleAge++ >= particleMaxAge) setDead(); + AxisAlignedBB axisalignedbb = boundingBox.expand(16.0D, 16.0D, 16.0D); + List list1 = worldObj.getEntitiesWithinAABB(Entity.class, axisalignedbb); + if (!worldObj.isRemote && list1 != null && !list1.isEmpty()){ Iterator iterator = list1.iterator(); - - while (iterator.hasNext()) - { - Entity entity = (Entity) iterator.next(); - if (entity != null && this.posX <= entity.posX + 0.5F && this.posX >= entity.posX - 0.5F && this.posZ <= entity.posZ + 0.5F && this.posZ >= entity.posZ - 0.5F) entity.attackEntityFrom(DamageSource.anvil, 100F); + while (iterator.hasNext()){ + Entity entity = (Entity)iterator.next(); + if (entity != null && posX <= entity.posX + 0.5F && posX >= entity.posX - 0.5F && posZ <= entity.posZ + 0.5F && posZ >= entity.posZ - 0.5F) entity.attackEntityFrom(DamageSourceList.shadows, 100F); if (entity instanceof EntityThrowable) ((EntityThrowable)entity).setDead(); } } } + /** + * @return + */ + @Override public int getFXLayer() { return 2; } - } -- cgit v1.2.3