From e583fe429d2e49aa42f5a3a36e7399712e98b74d Mon Sep 17 00:00:00 2001 From: WayofTime Date: Fri, 17 Jan 2014 19:59:31 -0500 Subject: [PATCH] Added fun spell framework --- .../AlchemicalWizardry.java | 4 +- .../{ => thaumcraft}/ItemSanguineArmour.java | 2 +- .../spell/complex/EntitySpellProjectile.java | 504 ++++++++++++++++++ .../complex/IProjectileImpactEffect.java | 10 + .../complex/IProjectileUpdateEffect.java | 8 + ...SpellEffect.java => SpellEnhancement.java} | 3 +- .../common/spell/complex/SpellModifier.java | 14 + .../common/spell/complex/SpellParadigm.java | 72 ++- .../complex/SpellParadigmProjectile.java | 31 ++ .../spell/complex/SpellParadigmSelf.java | 21 + .../spell/complex/effect/SpellEffect.java | 46 ++ 11 files changed, 710 insertions(+), 5 deletions(-) rename BM_src/WayofTime/alchemicalWizardry/common/items/{ => thaumcraft}/ItemSanguineArmour.java (97%) create mode 100644 BM_src/WayofTime/alchemicalWizardry/common/spell/complex/EntitySpellProjectile.java create mode 100644 BM_src/WayofTime/alchemicalWizardry/common/spell/complex/IProjectileImpactEffect.java create mode 100644 BM_src/WayofTime/alchemicalWizardry/common/spell/complex/IProjectileUpdateEffect.java rename BM_src/WayofTime/alchemicalWizardry/common/spell/complex/{SpellEffect.java => SpellEnhancement.java} (65%) create mode 100644 BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellParadigmProjectile.java create mode 100644 BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellParadigmSelf.java create mode 100644 BM_src/WayofTime/alchemicalWizardry/common/spell/complex/effect/SpellEffect.java diff --git a/BM_src/WayofTime/alchemicalWizardry/AlchemicalWizardry.java b/BM_src/WayofTime/alchemicalWizardry/AlchemicalWizardry.java index bb4711f1..b27bfbb1 100644 --- a/BM_src/WayofTime/alchemicalWizardry/AlchemicalWizardry.java +++ b/BM_src/WayofTime/alchemicalWizardry/AlchemicalWizardry.java @@ -55,9 +55,9 @@ import WayofTime.alchemicalWizardry.common.entity.mob.EntityWaterElemental; import WayofTime.alchemicalWizardry.common.entity.mob.EntityWingedFireDemon; import WayofTime.alchemicalWizardry.common.items.ItemBloodRuneBlock; import WayofTime.alchemicalWizardry.common.items.ItemRitualDiviner; -import WayofTime.alchemicalWizardry.common.items.ItemSanguineArmour; import WayofTime.alchemicalWizardry.common.items.LifeBucket; import WayofTime.alchemicalWizardry.common.items.sigil.SigilOfHolding; +import WayofTime.alchemicalWizardry.common.items.thaumcraft.ItemSanguineArmour; import WayofTime.alchemicalWizardry.common.rituals.Rituals; import WayofTime.alchemicalWizardry.common.spell.simple.HomSpellRegistry; import WayofTime.alchemicalWizardry.common.spell.simple.SpellEarthBender; @@ -306,7 +306,7 @@ public class AlchemicalWizardry public void preInit(FMLPreInitializationEvent event) { MinecraftForge.EVENT_BUS.register(new LifeBucketHandler()); - BloodMagicConfiguration.init(new File(event.getModConfigurationDirectory(), "bloodMagic.cfg")); + BloodMagicConfiguration.init(new File(event.getModConfigurationDirectory(), "AWWayofTime.cfg")); //Custom config stuff goes here diff --git a/BM_src/WayofTime/alchemicalWizardry/common/items/ItemSanguineArmour.java b/BM_src/WayofTime/alchemicalWizardry/common/items/thaumcraft/ItemSanguineArmour.java similarity index 97% rename from BM_src/WayofTime/alchemicalWizardry/common/items/ItemSanguineArmour.java rename to BM_src/WayofTime/alchemicalWizardry/common/items/thaumcraft/ItemSanguineArmour.java index d8c77bbb..5c0821c3 100644 --- a/BM_src/WayofTime/alchemicalWizardry/common/items/ItemSanguineArmour.java +++ b/BM_src/WayofTime/alchemicalWizardry/common/items/thaumcraft/ItemSanguineArmour.java @@ -1,4 +1,4 @@ -package WayofTime.alchemicalWizardry.common.items; +package WayofTime.alchemicalWizardry.common.items.thaumcraft; import WayofTime.alchemicalWizardry.AlchemicalWizardry; import WayofTime.alchemicalWizardry.ModItems; diff --git a/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/EntitySpellProjectile.java b/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/EntitySpellProjectile.java new file mode 100644 index 00000000..39283517 --- /dev/null +++ b/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/EntitySpellProjectile.java @@ -0,0 +1,504 @@ +package WayofTime.alchemicalWizardry.common.spell.complex; + +import java.util.ArrayList; +import java.util.Iterator; +import java.util.List; + +import net.minecraft.block.Block; +import net.minecraft.entity.Entity; +import net.minecraft.entity.IProjectile; +import net.minecraft.entity.boss.EntityWither; +import net.minecraft.entity.monster.EntityGhast; +import net.minecraft.entity.monster.EntityPigZombie; +import net.minecraft.entity.monster.EntitySkeleton; +import net.minecraft.entity.monster.EntityZombie; +import net.minecraft.entity.player.EntityPlayer; +import net.minecraft.nbt.NBTTagCompound; +import net.minecraft.util.AxisAlignedBB; +import net.minecraft.util.DamageSource; +import net.minecraft.util.EnumMovingObjectType; +import net.minecraft.util.MathHelper; +import net.minecraft.util.MovingObjectPosition; +import net.minecraft.util.Vec3; +import net.minecraft.world.World; +import cpw.mods.fml.relauncher.Side; +import cpw.mods.fml.relauncher.SideOnly; + +public class EntitySpellProjectile 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; + /** The owner of this arrow. */ + public EntityPlayer shootingEntity; + private int ticksInAir = 0; + private int ricochetCounter = 0; + private boolean scheduledForDeath = false; + + //Custom variables + private int maxRicochet = 0; + public List impactList = new ArrayList(); + private boolean penetration = false; + public List updateEffectList = new ArrayList(); + + public EntitySpellProjectile(World par1World) + { + super(par1World); + this.setSize(0.5F, 0.5F); + } + + public EntitySpellProjectile(World par1World, double par2, double par4, double par6) + { + super(par1World); + this.setSize(0.5F, 0.5F); + this.setPosition(par2, par4, par6); + yOffset = 0.0F; + } + + public EntitySpellProjectile(World par1World, EntityPlayer par2EntityPlayer) + { + super(par1World); + shootingEntity = par2EntityPlayer; + float par3 = 0.8F; + this.setSize(0.1F, 0.1F); + this.setLocationAndAngles(par2EntityPlayer.posX, par2EntityPlayer.posY + par2EntityPlayer.getEyeHeight(), par2EntityPlayer.posZ, par2EntityPlayer.rotationYaw, par2EntityPlayer.rotationPitch); + posX -= MathHelper.cos(rotationYaw / 180.0F * (float)Math.PI) * 0.16F; + posY -= 0.2D; + 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, par3 * 1.5F, 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 var1, double var3, double var5, float var7, float var8) { + float var9 = MathHelper.sqrt_double(var1 * var1 + var3 * var3 + var5 * var5); + var1 /= var9; + var3 /= var9; + var5 /= var9; + var1 += rand.nextGaussian() * 0.007499999832361937D * var8; + var3 += rand.nextGaussian() * 0.007499999832361937D * var8; + var5 += rand.nextGaussian() * 0.007499999832361937D * var8; + var1 *= var7; + var3 *= var7; + var5 *= var7; + motionX = var1; + motionY = var3; + motionZ = var5; + float var10 = MathHelper.sqrt_double(var1 * var1 + var5 * var5); + prevRotationYaw = rotationYaw = (float)(Math.atan2(var1, var5) * 180.0D / Math.PI); + prevRotationPitch = rotationPitch = (float)(Math.atan2(var3, var10) * 180.0D / Math.PI); + } + + @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 par1, double par3, double par5, float par7, float par8, int par9) { + this.setPosition(par1, par3, par5); + this.setRotation(par7, par8); + } + + @Override + @SideOnly(Side.CLIENT) + /** + * Sets the velocity to the args. Args: x, y, z + */ + public void setVelocity(double par1, double par3, double par5) { + motionX = par1; + motionY = par3; + motionZ = par5; + if (prevRotationPitch == 0.0F && prevRotationYaw == 0.0F) { + float var7 = MathHelper.sqrt_double(par1 * par1 + par5 * par5); + prevRotationYaw = rotationYaw = (float)(Math.atan2(par1, par5) * 180.0D / Math.PI); + prevRotationPitch = rotationPitch = (float)(Math.atan2(par3, var7) * 180.0D / Math.PI); + prevRotationPitch = rotationPitch; + prevRotationYaw = rotationYaw; + this.setLocationAndAngles(posX, posY, posZ, rotationYaw, rotationPitch); + } + } + + /** + * Called to update the entity's position/logic. + */ + @Override + public void onUpdate() + { + super.onUpdate(); + this.performUpdateEffects(); + if (ticksInAir > 600) { + this.setDead(); + } + if (shootingEntity == null) { + List players = worldObj.getEntitiesWithinAABB(EntityPlayer.class, AxisAlignedBB.getBoundingBox(posX - 1, posY - 1, posZ - 1, posX + 1, posY + 1, posZ + 1)); + Iterator i = players.iterator(); + double closestDistance = Double.MAX_VALUE; + EntityPlayer closestPlayer = null; + while (i.hasNext()) { + EntityPlayer e = (EntityPlayer)i.next(); + double distance = e.getDistanceToEntity(this); + if (distance < closestDistance) { + closestPlayer = e; + } + } + if (closestPlayer != null) { + shootingEntity = closestPlayer; + } + } + if (prevRotationPitch == 0.0F && prevRotationYaw == 0.0F) { + float var1 = MathHelper.sqrt_double(motionX * motionX + motionZ * motionZ); + prevRotationYaw = rotationYaw = (float)(Math.atan2(motionX, motionZ) * 180.0D / Math.PI); + prevRotationPitch = rotationPitch = (float)(Math.atan2(motionY, var1) * 180.0D / Math.PI); + } + int var16 = worldObj.getBlockId(xTile, yTile, zTile); + if (var16 > 0) { + Block.blocksList[var16].setBlockBoundsBasedOnState(worldObj, xTile, yTile, zTile); + AxisAlignedBB var2 = Block.blocksList[var16].getCollisionBoundingBoxFromPool(worldObj, xTile, yTile, zTile); + if (var2 != null && var2.isVecInside(worldObj.getWorldVec3Pool().getVecFromPool(posX, posY, posZ))) { + inGround = true; + } + } + if (inGround) { + int var18 = worldObj.getBlockId(xTile, yTile, zTile); + int var19 = worldObj.getBlockMetadata(xTile, yTile, zTile); + if (var18 == inTile && var19 == inData) { + // this.groundImpact(); + // this.setDead(); + } + } else { + ++ticksInAir; + if (ticksInAir > 1 && ticksInAir < 3) { + worldObj.spawnParticle("flame", posX + smallGauss(0.1D), posY + smallGauss(0.1D), posZ + smallGauss(0.1D), 0D, 0D, 0D); + for (int particles = 0; particles < 3; particles++) { + this.doFiringParticles(); + } + } else { + this.doFlightParticles(); + } + Vec3 var17 = worldObj.getWorldVec3Pool().getVecFromPool(posX, posY, posZ); + Vec3 var3 = worldObj.getWorldVec3Pool().getVecFromPool(posX + motionX, posY + motionY, posZ + motionZ); + MovingObjectPosition var4 = worldObj.rayTraceBlocks_do_do(var17, var3, false, true); + var17 = worldObj.getWorldVec3Pool().getVecFromPool(posX, posY, posZ); + var3 = worldObj.getWorldVec3Pool().getVecFromPool(posX + motionX, posY + motionY, posZ + motionZ); + if (var4 != null) { + var3 = worldObj.getWorldVec3Pool().getVecFromPool(var4.hitVec.xCoord, var4.hitVec.yCoord, var4.hitVec.zCoord); + } + Entity var5 = null; + List var6 = worldObj.getEntitiesWithinAABBExcludingEntity(this, boundingBox.addCoord(motionX, motionY, motionZ).expand(1.0D, 1.0D, 1.0D)); + double var7 = 0.0D; + Iterator var9 = var6.iterator(); + float var11; + while (var9.hasNext()) { + Entity var10 = (Entity)var9.next(); + if (var10.canBeCollidedWith() && (var10 != shootingEntity || ticksInAir >= 5)) { + var11 = 0.3F; + AxisAlignedBB var12 = var10.boundingBox.expand(var11, var11, var11); + MovingObjectPosition var13 = var12.calculateIntercept(var17, var3); + if (var13 != null) { + double var14 = var17.distanceTo(var13.hitVec); + if (var14 < var7 || var7 == 0.0D) { + var5 = var10; + var7 = var14; + } + } + } + } + if (var5 != null) { + var4 = new MovingObjectPosition(var5); + } + if (var4 != null) { + this.onImpact(var4); + if (scheduledForDeath) { + this.setDead(); + } + } + posX += motionX; + posY += motionY; + posZ += motionZ; + MathHelper.sqrt_double(motionX * motionX + motionZ * motionZ); + this.setPosition(posX, posY, posZ); + this.doBlockCollisions(); + } + } + + private void doFlightParticles() { + if (ticksInAir % 3 == 0) { + double gauss = gaussian(1.0F); + worldObj.spawnParticle("mobSpell", posX, posY, posZ, gauss, gauss, 0.0F); + } + } + + private void doFiringParticles() { + worldObj.spawnParticle("mobSpellAmbient", posX + smallGauss(0.1D), posY + smallGauss(0.1D), posZ + smallGauss(0.1D), 0.5D, 0.5D, 0.5D); + worldObj.spawnParticle("flame", posX, posY, posZ, gaussian(motionX), gaussian(motionY), gaussian(motionZ)); + } + + /** + * (abstract) Protected helper method to write subclass entity data to NBT. + */ + @Override + public void writeEntityToNBT(NBTTagCompound par1NBTTagCompound) { + par1NBTTagCompound.setShort("xTile", (short)xTile); + par1NBTTagCompound.setShort("yTile", (short)yTile); + par1NBTTagCompound.setShort("zTile", (short)zTile); + par1NBTTagCompound.setByte("inTile", (byte)inTile); + par1NBTTagCompound.setByte("inData", (byte)inData); + par1NBTTagCompound.setByte("inGround", (byte)(inGround ? 1 : 0)); + } + + /** + * (abstract) Protected helper method to read subclass entity data from NBT. + */ + @Override + public void readEntityFromNBT(NBTTagCompound par1NBTTagCompound) { + xTile = par1NBTTagCompound.getShort("xTile"); + yTile = par1NBTTagCompound.getShort("yTile"); + zTile = par1NBTTagCompound.getShort("zTile"); + inTile = par1NBTTagCompound.getByte("inTile") & 255; + inData = par1NBTTagCompound.getByte("inData") & 255; + inGround = par1NBTTagCompound.getByte("inGround") == 1; + } + + /** + * 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; + } + + /** + * Sets the amount of knockback the arrow applies when it hits a mob. + */ + public void setKnockbackStrength(int par1) { + } + + /** + * If returns false, the item will not inflict any damage against entities. + */ + @Override + public boolean canAttackWithItem() { + return false; + } + + /** + * Whether the arrow has a stream of critical hit particles flying behind + * it. + */ + public void setIsCritical(boolean par1) { + byte var2 = dataWatcher.getWatchableObjectByte(16); + if (par1) { + dataWatcher.updateObject(16, Byte.valueOf((byte)(var2 | 1))); + } else { + dataWatcher.updateObject(16, Byte.valueOf((byte)(var2 & -2))); + } + } + + /** + * Whether the arrow has a stream of critical hit particles flying behind + * it. + */ + public boolean getIsCritical() { + byte var1 = dataWatcher.getWatchableObjectByte(16); + return (var1 & 1) != 0; + } + + private void onImpact(MovingObjectPosition mop) + { + if (mop.typeOfHit == EnumMovingObjectType.ENTITY && mop.entityHit != null) + { + if (mop.entityHit == shootingEntity) return; + this.onImpact(mop.entityHit); + this.performEntityImpactEffects(mop.entityHit); + } + else if (mop.typeOfHit == EnumMovingObjectType.TILE) + { + if(!this.penetration) + { + this.groundImpact(mop.sideHit); + this.performTileImpactEffects(mop); + } + } + } + + private void onImpact(Entity mop) //TODO + { + if (mop == shootingEntity && ticksInAir > 3) + { + shootingEntity.attackEntityFrom(DamageSource.causePlayerDamage(shootingEntity), 1); + this.setDead(); + } else if (this.isUndead(mop)) { + doDamage(16 + d12(), mop); + } else { + doDamage(8 + d6(), mop); + } + spawnHitParticles("exorcism", 8); + this.setDead(); + } + + private int d12() { + return rand.nextInt(12) + 1; + } + + private int d6() { + return rand.nextInt(6) + 1; + } + + private void spawnHitParticles(String string, int i) { + for (int particles = 0; particles < i; particles++) { + worldObj.spawnParticle("mobSpellAmbient", posX + smallGauss(0.1D), posY + smallGauss(0.1D), posZ + smallGauss(0.1D), posGauss(1.0F), posGauss(1.0F), 0.0F); + } + } + + private void doDamage(int i, Entity mop) { + mop.attackEntityFrom(this.getDamageSource(), i); + } + + private boolean isUndead(Entity mop) { + return mop instanceof EntitySkeleton || mop instanceof EntityGhast || mop instanceof EntityWither || mop instanceof EntityZombie || mop instanceof EntityPigZombie; + } + + private DamageSource getDamageSource() { + return DamageSource.causePlayerDamage(shootingEntity); + } + + private void groundImpact(int sideHit) { + this.ricochet(sideHit); + } + + private double smallGauss(double d) { + return (worldObj.rand.nextFloat() - 0.5D) * d; + } + + private double posGauss(double d) { + return rand.nextFloat() * 0.5D * d; + } + + private double gaussian(double d) { + return d + d * ((rand.nextFloat() - 0.5D) / 4); + } + + private void ricochet(int sideHit) { + switch (sideHit) { + case 0: + case 1: + // topHit, bottomHit, reflect Y + motionY = motionY * -1; + break; + case 2: + case 3: + // westHit, eastHit, reflect Z + motionZ = motionZ * -1; + break; + case 4: + case 5: + // southHit, northHit, reflect X + motionX = motionX * -1; + break; + } + ricochetCounter++; + if (ricochetCounter > this.getRicochetMax()) { + scheduledForDeath = true; + for (int particles = 0; particles < 4; particles++) { + switch (sideHit) { + case 0: + worldObj.spawnParticle("smoke", posX, posY, posZ, gaussian(0.1D), -gaussian(0.1D), gaussian(0.1D)); + break; + case 1: + worldObj.spawnParticle("smoke", posX, posY, posZ, gaussian(0.1D), gaussian(0.1D), gaussian(0.1D)); + break; + case 2: + worldObj.spawnParticle("smoke", posX, posY, posZ, gaussian(0.1D), gaussian(0.1D), -gaussian(0.1D)); + break; + case 3: + worldObj.spawnParticle("smoke", posX, posY, posZ, gaussian(0.1D), gaussian(0.1D), gaussian(0.1D)); + break; + case 4: + worldObj.spawnParticle("smoke", posX, posY, posZ, -gaussian(0.1D), gaussian(0.1D), gaussian(0.1D)); + break; + case 5: + worldObj.spawnParticle("smoke", posX, posY, posZ, gaussian(0.1D), gaussian(0.1D), gaussian(0.1D)); + break; + } + } + } + } + + //Custom stuff + public int getRicochetMax() + { + return this.maxRicochet; + } + + public void setRicochetMax(int ricochet) + { + this.maxRicochet = ricochet; + } + + public void setImpactList(List list) + { + this.impactList = list; + } + + private void performEntityImpactEffects(Entity mop) + { + if(impactList!=null) + { + for(IProjectileImpactEffect impactEffect : impactList) + { + impactEffect.onEntityImpact(mop); + } + } + } + + private void performTileImpactEffects(MovingObjectPosition mop) + { + if(impactList!=null) + { + for(IProjectileImpactEffect impactEffect : impactList) + { + impactEffect.onTileImpact(mop); + } + } + } + + private void performUpdateEffects() + { + if(updateEffectList!=null) + { + for(IProjectileUpdateEffect updateEffect : updateEffectList) + { + updateEffect.onUpdateEffect(this); + } + } + } + + public void setPenetration(boolean penetration) + { + this.penetration = penetration; + } +} diff --git a/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/IProjectileImpactEffect.java b/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/IProjectileImpactEffect.java new file mode 100644 index 00000000..6fd0ff30 --- /dev/null +++ b/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/IProjectileImpactEffect.java @@ -0,0 +1,10 @@ +package WayofTime.alchemicalWizardry.common.spell.complex; + +import net.minecraft.entity.Entity; +import net.minecraft.util.MovingObjectPosition; + +public interface IProjectileImpactEffect +{ + public void onEntityImpact(Entity mop); + public void onTileImpact(MovingObjectPosition mop); +} diff --git a/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/IProjectileUpdateEffect.java b/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/IProjectileUpdateEffect.java new file mode 100644 index 00000000..bd8b7939 --- /dev/null +++ b/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/IProjectileUpdateEffect.java @@ -0,0 +1,8 @@ +package WayofTime.alchemicalWizardry.common.spell.complex; + +import net.minecraft.entity.Entity; + +public interface IProjectileUpdateEffect +{ + public void onUpdateEffect(Entity projectile); +} diff --git a/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellEffect.java b/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellEnhancement.java similarity index 65% rename from BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellEffect.java rename to BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellEnhancement.java index c139ccd4..58a1c6b6 100644 --- a/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellEffect.java +++ b/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellEnhancement.java @@ -1,5 +1,6 @@ package WayofTime.alchemicalWizardry.common.spell.complex; -public class SpellEffect { +public class SpellEnhancement +{ } diff --git a/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellModifier.java b/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellModifier.java index c600df80..e25d6643 100644 --- a/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellModifier.java +++ b/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellModifier.java @@ -4,4 +4,18 @@ public class SpellModifier { public static final int DEFAULT = 0; public static final int OFFENSIVE = 1; + public static final int DEFENSIVE = 2; + public static final int ENVIRONMENTAL = 3; + + private int modifier; + + public SpellModifier(int modifier) + { + this.modifier = modifier; + } + + public int getModifier() + { + return this.modifier; + } } diff --git a/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellParadigm.java b/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellParadigm.java index 4ef1a046..67b7700e 100644 --- a/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellParadigm.java +++ b/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellParadigm.java @@ -1,5 +1,75 @@ package WayofTime.alchemicalWizardry.common.spell.complex; -public class SpellParadigm { +import java.util.ArrayList; +import java.util.List; +import net.minecraft.entity.player.EntityPlayer; +import net.minecraft.item.ItemStack; +import net.minecraft.world.World; +import WayofTime.alchemicalWizardry.common.spell.complex.effect.SpellEffect; + +public abstract class SpellParadigm +{ + protected List bufferedEffectList = new ArrayList(); + + public void addBufferedEffect(SpellEffect effect) + { + if(effect!=null) + { + this.bufferedEffectList.add(effect); + } + } + + public void modifyBufferedEffect(SpellModifier modifier) + { + SpellEffect effect = this.getBufferedEffect(); + if(effect!=null) + { + effect.modifyEffect(modifier); + } + } + + public void applyEnhancement(SpellEnhancement enh) + { + if(bufferedEffectList.isEmpty()) + { + this.enhanceParadigm(enh); + } + else + { + SpellEffect effect = this.getBufferedEffect(); + if(effect!=null) + { + effect.enhanceEffect(enh); + } + } + } + + public abstract void enhanceParadigm(SpellEnhancement enh); + public abstract void castSpell(World world, EntityPlayer entityPlayer, ItemStack itemStack); + + public void applySpellEffect(SpellEffect effect) + { + effect.modifyParadigm(this); + } + + public void applyAllSpellEffects() + { + for(SpellEffect effect : bufferedEffectList) + { + this.applySpellEffect(effect); + } + } + + public SpellEffect getBufferedEffect() + { + if(bufferedEffectList.isEmpty()) + { + return null; + } + else + { + return bufferedEffectList.get(bufferedEffectList.size()-1); + } + } } diff --git a/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellParadigmProjectile.java b/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellParadigmProjectile.java new file mode 100644 index 00000000..45e995e1 --- /dev/null +++ b/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellParadigmProjectile.java @@ -0,0 +1,31 @@ +package WayofTime.alchemicalWizardry.common.spell.complex; + +import java.util.ArrayList; +import java.util.List; + +import net.minecraft.entity.player.EntityPlayer; +import net.minecraft.item.ItemStack; +import net.minecraft.util.DamageSource; +import net.minecraft.world.World; + +public class SpellParadigmProjectile extends SpellParadigm +{ + public DamageSource damageSource = DamageSource.generic; + public float damage = 1; + public int cost = 0; + public List impactList = new ArrayList(); + + @Override + public void enhanceParadigm(SpellEnhancement enh) + { + // TODO Auto-generated method stub + + } + + @Override + public void castSpell(World world, EntityPlayer entityPlayer, ItemStack itemStack) + { + // TODO Auto-generated method stub + + } +} diff --git a/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellParadigmSelf.java b/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellParadigmSelf.java new file mode 100644 index 00000000..41a72da8 --- /dev/null +++ b/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/SpellParadigmSelf.java @@ -0,0 +1,21 @@ +package WayofTime.alchemicalWizardry.common.spell.complex; + +import net.minecraft.entity.player.EntityPlayer; +import net.minecraft.item.ItemStack; +import net.minecraft.world.World; + +public class SpellParadigmSelf extends SpellParadigm +{ + @Override + public void enhanceParadigm(SpellEnhancement enh) + { + + } + + @Override + public void castSpell(World world, EntityPlayer entityPlayer, ItemStack itemStack) + { + // TODO Auto-generated method stub + + } +} diff --git a/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/effect/SpellEffect.java b/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/effect/SpellEffect.java new file mode 100644 index 00000000..95098863 --- /dev/null +++ b/BM_src/WayofTime/alchemicalWizardry/common/spell/complex/effect/SpellEffect.java @@ -0,0 +1,46 @@ +package WayofTime.alchemicalWizardry.common.spell.complex.effect; + +import WayofTime.alchemicalWizardry.common.spell.complex.SpellEnhancement; +import WayofTime.alchemicalWizardry.common.spell.complex.SpellModifier; +import WayofTime.alchemicalWizardry.common.spell.complex.SpellParadigm; +import WayofTime.alchemicalWizardry.common.spell.complex.SpellParadigmProjectile; + +public abstract class SpellEffect +{ + public int modifierState = SpellModifier.DEFAULT; + + public void enhanceEffect(SpellEnhancement enh) + { + + } + + public void modifyEffect(SpellModifier mod) + { + if(mod!=null) + modifierState = mod.getModifier(); + } + + public void modifyParadigm(SpellParadigm parad) + { + if(parad instanceof SpellParadigmProjectile) + { + this.modifyProjectileParadigm((SpellParadigmProjectile)parad); + } + } + + public void modifyProjectileParadigm(SpellParadigmProjectile parad) + { + switch(modifierState) + { + case SpellModifier.DEFAULT: this.defaultModificationProjectile(parad); break; + case SpellModifier.OFFENSIVE: this.offensiveModificationProjectile(parad); break; + case SpellModifier.DEFENSIVE: this.defensiveModificationProjectile(parad); break; + case SpellModifier.ENVIRONMENTAL: this.environmentalModificationProjectile(parad); break; + } + } + + public abstract void defaultModificationProjectile(SpellParadigmProjectile parad); + public abstract void offensiveModificationProjectile(SpellParadigmProjectile parad); + public abstract void defensiveModificationProjectile(SpellParadigmProjectile parad); + public abstract void environmentalModificationProjectile(SpellParadigmProjectile parad); +}