A bit more added to the projectile paradigm
This commit is contained in:
parent
e583fe429d
commit
5c6a5d0c0b
|
@ -2,6 +2,7 @@ package WayofTime.alchemicalWizardry.common.spell.complex;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
|
import java.util.LinkedList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
|
@ -13,7 +14,9 @@ import net.minecraft.entity.monster.EntityPigZombie;
|
||||||
import net.minecraft.entity.monster.EntitySkeleton;
|
import net.minecraft.entity.monster.EntitySkeleton;
|
||||||
import net.minecraft.entity.monster.EntityZombie;
|
import net.minecraft.entity.monster.EntityZombie;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.nbt.NBTTagCompound;
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
|
import net.minecraft.nbt.NBTTagList;
|
||||||
import net.minecraft.util.AxisAlignedBB;
|
import net.minecraft.util.AxisAlignedBB;
|
||||||
import net.minecraft.util.DamageSource;
|
import net.minecraft.util.DamageSource;
|
||||||
import net.minecraft.util.EnumMovingObjectType;
|
import net.minecraft.util.EnumMovingObjectType;
|
||||||
|
@ -40,9 +43,11 @@ public class EntitySpellProjectile extends Entity implements IProjectile
|
||||||
|
|
||||||
//Custom variables
|
//Custom variables
|
||||||
private int maxRicochet = 0;
|
private int maxRicochet = 0;
|
||||||
|
private float damage = 1;
|
||||||
public List<IProjectileImpactEffect> impactList = new ArrayList();
|
public List<IProjectileImpactEffect> impactList = new ArrayList();
|
||||||
private boolean penetration = false;
|
private boolean penetration = false;
|
||||||
public List<IProjectileUpdateEffect> updateEffectList = new ArrayList();
|
public List<IProjectileUpdateEffect> updateEffectList = new ArrayList();
|
||||||
|
public List<String> effectList = new LinkedList();
|
||||||
|
|
||||||
public EntitySpellProjectile(World par1World)
|
public EntitySpellProjectile(World par1World)
|
||||||
{
|
{
|
||||||
|
@ -254,26 +259,52 @@ public class EntitySpellProjectile extends Entity implements IProjectile
|
||||||
* (abstract) Protected helper method to write subclass entity data to NBT.
|
* (abstract) Protected helper method to write subclass entity data to NBT.
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void writeEntityToNBT(NBTTagCompound par1NBTTagCompound) {
|
public void writeEntityToNBT(NBTTagCompound par1NBTTagCompound)
|
||||||
|
{
|
||||||
par1NBTTagCompound.setShort("xTile", (short)xTile);
|
par1NBTTagCompound.setShort("xTile", (short)xTile);
|
||||||
par1NBTTagCompound.setShort("yTile", (short)yTile);
|
par1NBTTagCompound.setShort("yTile", (short)yTile);
|
||||||
par1NBTTagCompound.setShort("zTile", (short)zTile);
|
par1NBTTagCompound.setShort("zTile", (short)zTile);
|
||||||
par1NBTTagCompound.setByte("inTile", (byte)inTile);
|
par1NBTTagCompound.setByte("inTile", (byte)inTile);
|
||||||
par1NBTTagCompound.setByte("inData", (byte)inData);
|
par1NBTTagCompound.setByte("inData", (byte)inData);
|
||||||
par1NBTTagCompound.setByte("inGround", (byte)(inGround ? 1 : 0));
|
par1NBTTagCompound.setByte("inGround", (byte)(inGround ? 1 : 0));
|
||||||
|
|
||||||
|
NBTTagList tagList = par1NBTTagCompound.getTagList("Effects");
|
||||||
|
this.effectList = new LinkedList();
|
||||||
|
for (int i = 0; i < tagList.tagCount(); i++)
|
||||||
|
{
|
||||||
|
NBTTagCompound tag = (NBTTagCompound) tagList.tagAt(i);
|
||||||
|
|
||||||
|
this.effectList.add(tag.getString("Class"));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* (abstract) Protected helper method to read subclass entity data from NBT.
|
* (abstract) Protected helper method to read subclass entity data from NBT.
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void readEntityFromNBT(NBTTagCompound par1NBTTagCompound) {
|
public void readEntityFromNBT(NBTTagCompound par1NBTTagCompound)
|
||||||
|
{
|
||||||
xTile = par1NBTTagCompound.getShort("xTile");
|
xTile = par1NBTTagCompound.getShort("xTile");
|
||||||
yTile = par1NBTTagCompound.getShort("yTile");
|
yTile = par1NBTTagCompound.getShort("yTile");
|
||||||
zTile = par1NBTTagCompound.getShort("zTile");
|
zTile = par1NBTTagCompound.getShort("zTile");
|
||||||
inTile = par1NBTTagCompound.getByte("inTile") & 255;
|
inTile = par1NBTTagCompound.getByte("inTile") & 255;
|
||||||
inData = par1NBTTagCompound.getByte("inData") & 255;
|
inData = par1NBTTagCompound.getByte("inData") & 255;
|
||||||
inGround = par1NBTTagCompound.getByte("inGround") == 1;
|
inGround = par1NBTTagCompound.getByte("inGround") == 1;
|
||||||
|
|
||||||
|
NBTTagList effectList = new NBTTagList();
|
||||||
|
|
||||||
|
for (String str : this.effectList)
|
||||||
|
{
|
||||||
|
if (str != null)
|
||||||
|
{
|
||||||
|
NBTTagCompound tag = new NBTTagCompound();
|
||||||
|
|
||||||
|
tag.setString("Class", str);
|
||||||
|
effectList.appendTag(tag);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
par1NBTTagCompound.setTag("Effects", effectList);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -464,6 +495,11 @@ public class EntitySpellProjectile extends Entity implements IProjectile
|
||||||
this.impactList = list;
|
this.impactList = list;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setUpdateEffectList(List<IProjectileUpdateEffect> list)
|
||||||
|
{
|
||||||
|
this.updateEffectList = list;
|
||||||
|
}
|
||||||
|
|
||||||
private void performEntityImpactEffects(Entity mop)
|
private void performEntityImpactEffects(Entity mop)
|
||||||
{
|
{
|
||||||
if(impactList!=null)
|
if(impactList!=null)
|
||||||
|
@ -501,4 +537,19 @@ public class EntitySpellProjectile extends Entity implements IProjectile
|
||||||
{
|
{
|
||||||
this.penetration = penetration;
|
this.penetration = penetration;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public float getDamage()
|
||||||
|
{
|
||||||
|
return this.damage;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDamage(float damage)
|
||||||
|
{
|
||||||
|
this.damage = damage;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setEffectList(List<String> stringList)
|
||||||
|
{
|
||||||
|
this.effectList = stringList;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package WayofTime.alchemicalWizardry.common.spell.complex;
|
package WayofTime.alchemicalWizardry.common.spell.complex;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.LinkedList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
|
@ -11,12 +12,15 @@ import WayofTime.alchemicalWizardry.common.spell.complex.effect.SpellEffect;
|
||||||
public abstract class SpellParadigm
|
public abstract class SpellParadigm
|
||||||
{
|
{
|
||||||
protected List<SpellEffect> bufferedEffectList = new ArrayList();
|
protected List<SpellEffect> bufferedEffectList = new ArrayList();
|
||||||
|
protected List<String> effectList = new LinkedList();
|
||||||
|
|
||||||
public void addBufferedEffect(SpellEffect effect)
|
public void addBufferedEffect(SpellEffect effect)
|
||||||
{
|
{
|
||||||
if(effect!=null)
|
if(effect!=null)
|
||||||
{
|
{
|
||||||
this.bufferedEffectList.add(effect);
|
this.bufferedEffectList.add(effect);
|
||||||
|
|
||||||
|
effectList.add(effect.getClass().getName());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -26,23 +30,31 @@ public abstract class SpellParadigm
|
||||||
if(effect!=null)
|
if(effect!=null)
|
||||||
{
|
{
|
||||||
effect.modifyEffect(modifier);
|
effect.modifyEffect(modifier);
|
||||||
|
|
||||||
|
effectList.add(modifier.getClass().getName());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void applyEnhancement(SpellEnhancement enh)
|
public void applyEnhancement(SpellEnhancement enh)
|
||||||
{
|
{
|
||||||
if(bufferedEffectList.isEmpty())
|
if(enh!=null)
|
||||||
{
|
{
|
||||||
this.enhanceParadigm(enh);
|
if(bufferedEffectList.isEmpty())
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
SpellEffect effect = this.getBufferedEffect();
|
|
||||||
if(effect!=null)
|
|
||||||
{
|
{
|
||||||
effect.enhanceEffect(enh);
|
this.enhanceParadigm(enh);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
SpellEffect effect = this.getBufferedEffect();
|
||||||
|
if(effect!=null)
|
||||||
|
{
|
||||||
|
effect.enhanceEffect(enh);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
effectList.add(enh.getClass().getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public abstract void enhanceParadigm(SpellEnhancement enh);
|
public abstract void enhanceParadigm(SpellEnhancement enh);
|
||||||
|
|
|
@ -1,12 +1,14 @@
|
||||||
package WayofTime.alchemicalWizardry.common.spell.complex;
|
package WayofTime.alchemicalWizardry.common.spell.complex;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.LinkedList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.util.DamageSource;
|
import net.minecraft.util.DamageSource;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
import WayofTime.alchemicalWizardry.common.spell.complex.effect.SpellEffect;
|
||||||
|
|
||||||
public class SpellParadigmProjectile extends SpellParadigm
|
public class SpellParadigmProjectile extends SpellParadigm
|
||||||
{
|
{
|
||||||
|
@ -14,6 +16,9 @@ public class SpellParadigmProjectile extends SpellParadigm
|
||||||
public float damage = 1;
|
public float damage = 1;
|
||||||
public int cost = 0;
|
public int cost = 0;
|
||||||
public List<IProjectileImpactEffect> impactList = new ArrayList();
|
public List<IProjectileImpactEffect> impactList = new ArrayList();
|
||||||
|
public List<IProjectileUpdateEffect> updateEffectList = new ArrayList();
|
||||||
|
public boolean penetration = false;
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void enhanceParadigm(SpellEnhancement enh)
|
public void enhanceParadigm(SpellEnhancement enh)
|
||||||
|
@ -25,7 +30,62 @@ public class SpellParadigmProjectile extends SpellParadigm
|
||||||
@Override
|
@Override
|
||||||
public void castSpell(World world, EntityPlayer entityPlayer, ItemStack itemStack)
|
public void castSpell(World world, EntityPlayer entityPlayer, ItemStack itemStack)
|
||||||
{
|
{
|
||||||
// TODO Auto-generated method stub
|
EntitySpellProjectile proj = new EntitySpellProjectile(world, entityPlayer);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static SpellParadigmProjectile getParadigmForStringArray(List<String> stringList)
|
||||||
|
{
|
||||||
|
SpellParadigmProjectile parad = new SpellParadigmProjectile();
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
for(String str : stringList)
|
||||||
|
{
|
||||||
|
Class clazz = Class.forName(str);
|
||||||
|
if(clazz!=null)
|
||||||
|
{
|
||||||
|
Object obj = clazz.newInstance();
|
||||||
|
|
||||||
|
if(obj instanceof SpellEffect)
|
||||||
|
{
|
||||||
|
parad.addBufferedEffect((SpellEffect)obj);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if(obj instanceof SpellModifier)
|
||||||
|
{
|
||||||
|
parad.modifyBufferedEffect((SpellModifier)obj);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if(obj instanceof SpellEnhancement)
|
||||||
|
{
|
||||||
|
parad.applyEnhancement((SpellEnhancement)obj);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch (InstantiationException e) {
|
||||||
|
|
||||||
|
e.printStackTrace();
|
||||||
|
} catch (IllegalAccessException e) {
|
||||||
|
|
||||||
|
e.printStackTrace();
|
||||||
|
} catch (ClassNotFoundException e) {
|
||||||
|
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
return parad;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void prepareProjectile(EntitySpellProjectile proj)
|
||||||
|
{
|
||||||
|
proj.setDamage(damage);
|
||||||
|
proj.setImpactList(impactList);
|
||||||
|
proj.setUpdateEffectList(updateEffectList);
|
||||||
|
proj.setPenetration(penetration);
|
||||||
|
proj.setEffectList(effectList);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue