summaryrefslogtreecommitdiff
path: root/java/darkknight/jewelrycraft/particles/EntityShadowsFX.java
diff options
context:
space:
mode:
Diffstat (limited to 'java/darkknight/jewelrycraft/particles/EntityShadowsFX.java')
-rw-r--r--java/darkknight/jewelrycraft/particles/EntityShadowsFX.java75
1 files changed, 46 insertions, 29 deletions
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;
}
-
}