From 70c1354a4a96698758a88c032866288f79de6f5a Mon Sep 17 00:00:00 2001 From: Benjamin Culkin Date: Sat, 24 Aug 2024 08:16:37 -0400 Subject: Initial commit --- .../java/jp/plusplus/fbs/magic/MagicFireBolt.java | 59 ++++++++++++++++++++++ 1 file changed, 59 insertions(+) create mode 100644 src/main/java/jp/plusplus/fbs/magic/MagicFireBolt.java (limited to 'src/main/java/jp/plusplus/fbs/magic/MagicFireBolt.java') diff --git a/src/main/java/jp/plusplus/fbs/magic/MagicFireBolt.java b/src/main/java/jp/plusplus/fbs/magic/MagicFireBolt.java new file mode 100644 index 0000000..f18c438 --- /dev/null +++ b/src/main/java/jp/plusplus/fbs/magic/MagicFireBolt.java @@ -0,0 +1,59 @@ +package jp.plusplus.fbs.magic; + +import jp.plusplus.fbs.api.IMagicEnchant; +import jp.plusplus.fbs.api.MagicBase; +import jp.plusplus.fbs.entity.EntityMagicFireBolt; +import net.minecraft.entity.Entity; +import net.minecraft.entity.EntityLivingBase; + +/** + * Createdby pluslus_Fon 2015/06/14. + */ +public class MagicFireBolt extends MagicBase implements IMagicEnchant { + @Override + public boolean checkSuccess() { + if(isSpelled) return true; + + float prob=0.4f+0.03f*property.getMagicLevel(); + return rand.nextFloat()<=prob; + } + + @Override + public void success() { + int d=getLvDiff(); + float dm=isSpelled?1.5f:0.5f; + if(d>0) dm+=0.5f*(d/5); + + Entity e=new EntityMagicFireBolt(world, player, 1.0F, 1.0F, dm); + world.spawnEntityInWorld(e); + } + + @Override + public void failure() { + sanity(2, 4); + } + + @Override + public void enchant(EntityLivingBase entity, boolean success) { + if(success) entity.setFire(10); + } + + @Override + public float damageScale(EntityLivingBase entity) { + return 1.2f; + } + + @Override + public float damageValue(EntityLivingBase entity) { + return 0.f; + } + + @Override + public ParticleColor setParticleColor(){ + ParticleColor col=new ParticleColor(); + float v=0.5f+0.5f*rand.nextFloat(); + col.blue-=v; + col.green-=v; + return col; + } +} -- cgit v1.2.3