summaryrefslogtreecommitdiff
path: root/java/darkknight/jewelrycraft/effects/EffectFeather.java
diff options
context:
space:
mode:
authorOnyxDarkKnight <sor1n.iliutza16@gmail.com>2015-03-23 14:25:27 +0000
committerOnyxDarkKnight <sor1n.iliutza16@gmail.com>2015-03-23 14:25:27 +0000
commite86949a1ad3269ec66c9de65e2c92f5e66251411 (patch)
treeabe7a3b14d7a5f7bb27a916a991f8911de94c1d2 /java/darkknight/jewelrycraft/effects/EffectFeather.java
parent12cb40ba14e76b999a381b1f122bfce73223fd38 (diff)
More stuff. I don't even know by this point....
Diffstat (limited to 'java/darkknight/jewelrycraft/effects/EffectFeather.java')
-rw-r--r--java/darkknight/jewelrycraft/effects/EffectFeather.java77
1 files changed, 48 insertions, 29 deletions
diff --git a/java/darkknight/jewelrycraft/effects/EffectFeather.java b/java/darkknight/jewelrycraft/effects/EffectFeather.java
index b331044..2acaf76 100644
--- a/java/darkknight/jewelrycraft/effects/EffectFeather.java
+++ b/java/darkknight/jewelrycraft/effects/EffectFeather.java
@@ -1,16 +1,25 @@
package darkknight.jewelrycraft.effects;
+import java.util.Iterator;
+import java.util.List;
import net.minecraft.entity.Entity;
import net.minecraft.entity.player.EntityPlayer;
+import net.minecraft.entity.projectile.EntityArrow;
import net.minecraft.init.Items;
import net.minecraft.item.Item;
import net.minecraft.item.ItemStack;
+import net.minecraft.nbt.NBTTagCompound;
+import net.minecraft.util.AxisAlignedBB;
+import net.minecraft.util.ChatComponentText;
import net.minecraft.util.DamageSource;
+import net.minecraft.util.EnumChatFormatting;
import darkknight.jewelrycraft.damage.DamageSourceList;
import darkknight.jewelrycraft.item.ItemBracelet;
import darkknight.jewelrycraft.item.ItemEarrings;
import darkknight.jewelrycraft.item.ItemNecklace;
+import darkknight.jewelrycraft.item.ItemRing;
import darkknight.jewelrycraft.util.JewelryNBT;
+import darkknight.jewelrycraft.util.PlayerUtils;
public class EffectFeather extends ModifierEffects
{
@@ -23,47 +32,57 @@ public class EffectFeather extends ModifierEffects
public void action(ItemStack item, EntityPlayer player, Item jewelry)
{
int pos = JewelryNBT.doesModifierExist(item, modifier);
- // Positive necklace
- if (jewelry instanceof ItemNecklace && pos != -1 && !player.onGround){
- player.motionY = -10D;
- System.out.println(player.motionY);
+ NBTTagCompound playerInfo = PlayerUtils.getModPlayerPersistTag(player, "Jewelrycraft");
+ // Positive earrings
+ if (jewelry instanceof ItemEarrings && pos != -1){
+ AxisAlignedBB axisalignedbb = player.boundingBox.expand(1.0D, 1.0D, 1.0D);
+ List list = player.worldObj.getEntitiesWithinAABB(EntityArrow.class, axisalignedbb);
+ if (!player.worldObj.isRemote && list != null && !list.isEmpty()){
+ Iterator iterator = list.iterator();
+ while (iterator.hasNext()){
+ EntityArrow arrow = (EntityArrow)iterator.next();
+ if (rand.nextInt(3) == 0 && (arrow.shootingEntity == null || !(arrow.shootingEntity.equals(player)) || arrow.canBePickedUp == 0)) arrow.setDead();
+ }
+ }
}
- }
-
- @Override
- public boolean onEntityAttackedCacellable(ItemStack item, EntityPlayer player, Entity target, Item jewelry, float amount)
- {
- int pos = JewelryNBT.doesModifierExist(item, modifier);
- // if (jewelry instanceof ItemNecklace && pos != -1) player.fallDistance *= 0.5F;
- if (jewelry instanceof ItemBracelet && pos != -1) return true;
- return false;
- }
-
- @Override
- public boolean onPlayerAttackedCacellable(ItemStack item, EntityPlayer player, DamageSource source, Item jewelry, float amount)
- {
- int pos = JewelryNBT.doesModifierExist(item, modifier);
// Positive bracelet
- if (jewelry instanceof ItemBracelet && pos != -1) return true;
- return true;
+ if (jewelry instanceof ItemBracelet && pos != -1){
+ if (player.motionY < 0) player.motionY *= 0.6D;
+ player.setAIMoveSpeed(player.getAIMoveSpeed() / 2);
+ player.fallDistance = 0F;
+ }
}
@Override
public void onEntityAttacked(ItemStack item, EntityPlayer player, Entity target, Item jewelry, float amount)
- {}
-
- @Override
- public void onPlayerAttacked(ItemStack item, EntityPlayer player, DamageSource source, Item jewelry, float amount)
{
int pos = JewelryNBT.doesModifierExist(item, modifier);
- // Negative necklace
- if (jewelry instanceof ItemNecklace && pos != -1 && source != DamageSourceList.weak) player.attackEntityFrom(DamageSourceList.weak, amount * 2F);
+ NBTTagCompound playerInfo = PlayerUtils.getModPlayerPersistTag(player, "Jewelrycraft");
+ NBTTagCompound enemyData = target.getEntityData();
+ if (jewelry instanceof ItemRing && pos != -1 && enemyData.getInteger("reAttacked") == 0){
+ enemyData.setInteger("reAttacked", enemyData.getInteger("reAttacked") + 1);
+ target.attackEntityFrom(DamageSource.causePlayerDamage(player), amount / 2F);
+ if (rand.nextInt(2) == 0){
+ enemyData.setInteger("stunTime", 50);
+ enemyData.setBoolean("stunned", true);
+ }
+ playerInfo.setBoolean("weakDamage", true);
+ }
+ if (enemyData.getInteger("reAttacked") == 1) enemyData.setInteger("reAttacked", 0);
}
@Override
- public boolean onPlayerFall(ItemStack item, EntityPlayer player, Item jewelry)
+ public void onPlayerAttacked(ItemStack item, EntityPlayer player, DamageSource source, Item jewelry, float amount)
{
int pos = JewelryNBT.doesModifierExist(item, modifier);
- return false;
+ NBTTagCompound playerInfo = PlayerUtils.getModPlayerPersistTag(player, "Jewelrycraft");
+ if (jewelry instanceof ItemNecklace && pos != -1 && rand.nextInt(4) == 0 && source != DamageSourceList.weak && source != DamageSource.inFire && source != DamageSource.onFire && source != DamageSource.lava){
+ player.addChatComponentMessage(new ChatComponentText(EnumChatFormatting.GRAY + "The necklace protected you from taking damage!"));
+ playerInfo.setBoolean("negateDamage", true);
+ }
+ // Negative necklace
+ if (jewelry instanceof ItemNecklace && pos != -1 && (source == DamageSource.inFire || source == DamageSource.onFire || source == DamageSource.lava) && source != DamageSourceList.weak) player.attackEntityFrom(DamageSourceList.weak, amount * 3F);
+ // Negative earrings
+ if (jewelry instanceof ItemEarrings && pos != -1 && source.damageType.equals("arrow") && source != DamageSourceList.weak) player.attackEntityFrom(DamageSourceList.weak, amount * 2F);
}
}