BloodMagic/1.7.10/main/java/WayofTime/alchemicalWizardry/common/rituals/RitualEffectEvaporation.java

247 lines
11 KiB
Java
Raw Normal View History

2014-07-31 23:45:40 +00:00
package WayofTime.alchemicalWizardry.common.rituals;
import WayofTime.alchemicalWizardry.ModBlocks;
import WayofTime.alchemicalWizardry.api.rituals.IMasterRitualStone;
import WayofTime.alchemicalWizardry.api.rituals.RitualComponent;
import WayofTime.alchemicalWizardry.api.rituals.RitualEffect;
import WayofTime.alchemicalWizardry.api.soulNetwork.SoulNetworkHandler;
2014-07-31 23:45:40 +00:00
import WayofTime.alchemicalWizardry.common.spell.complex.effect.SpellHelper;
2014-10-13 20:33:20 +00:00
import net.minecraft.block.Block;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.init.Blocks;
import net.minecraft.potion.Potion;
import net.minecraft.potion.PotionEffect;
import net.minecraft.world.World;
import java.util.ArrayList;
import java.util.List;
2014-07-31 23:45:40 +00:00
public class RitualEffectEvaporation extends RitualEffect
{
@Override
public void performEffect(IMasterRitualStone ritualStone)
{
String owner = ritualStone.getOwner();
int currentEssence = SoulNetworkHandler.getCurrentEssence(owner);
2014-07-31 23:45:40 +00:00
World world = ritualStone.getWorld();
int x = ritualStone.getXCoord();
int y = ritualStone.getYCoord();
int z = ritualStone.getZCoord();
2014-10-13 20:33:20 +00:00
2014-07-31 23:45:40 +00:00
if (currentEssence < 0)
{
EntityPlayer entityOwner = SpellHelper.getPlayerForUsername(owner);
if (entityOwner == null)
{
return;
}
entityOwner.addPotionEffect(new PotionEffect(Potion.confusion.id, 80));
} else
{
2014-10-13 20:33:20 +00:00
Block block1 = world.getBlock(x, y - 1, z);
int range = this.getRadiusForModifierBlock(block1);
boolean[][][] boolList = new boolean[range * 2 + 1][range * 2 + 1][range * 2 + 1];
2014-07-31 23:45:40 +00:00
for (int i = 0; i < 2 * range + 1; i++)
{
for (int j = 0; j < 2 * range + 1; j++)
{
2014-10-13 20:33:20 +00:00
for (int k = 0; k < 2 * range + 1; k++)
{
2014-07-31 23:45:40 +00:00
boolList[i][j][k] = false;
2014-10-13 20:33:20 +00:00
}
2014-07-31 23:45:40 +00:00
}
}
2014-10-13 20:33:20 +00:00
2014-07-31 23:45:40 +00:00
boolList[range][range][range] = true;
boolean isReady = false;
while (!isReady)
{
isReady = true;
for (int i = 0; i < 2 * range + 1; i++)
{
for (int j = 0; j < 2 * range + 1; j++)
{
2014-10-13 20:33:20 +00:00
for (int k = 0; k < 2 * range + 1; k++)
{
2014-07-31 23:45:40 +00:00
if (boolList[i][j][k])
{
if (i - 1 >= 0 && !boolList[i - 1][j][k])
{
Block block = world.getBlock(x - range + i - 1, y - range + j, z - range + k);
2014-10-13 20:33:20 +00:00
if (world.isAirBlock(x - range + i - 1, y - range + j, z - range + k) || block == ModBlocks.blockSpectralContainer)
2014-07-31 23:45:40 +00:00
{
boolList[i - 1][j][k] = true;
isReady = false;
}
}
if (j - 1 >= 0 && !boolList[i][j - 1][k])
{
Block block = world.getBlock(x - range + i, y - range + j - 1, z - range + k);
2014-10-13 20:33:20 +00:00
if (world.isAirBlock(x - range + i, y - range + j - 1, z - range + k) || block == ModBlocks.blockSpectralContainer)
2014-07-31 23:45:40 +00:00
{
boolList[i][j - 1][k] = true;
isReady = false;
}
}
2014-10-13 20:33:20 +00:00
if (k - 1 >= 0 && !boolList[i][j][k - 1])
2014-07-31 23:45:40 +00:00
{
2014-10-13 20:33:20 +00:00
Block block = world.getBlock(x - range + i, y - range + j, z - range + k - 1);
if (world.isAirBlock(x - range + i, y - range + j, z - range + k - 1) || block == ModBlocks.blockSpectralContainer)
2014-07-31 23:45:40 +00:00
{
boolList[i][j][k - 1] = true;
isReady = false;
}
}
if (i + 1 <= 2 * range && !boolList[i + 1][j][k])
{
Block block = world.getBlock(x - range + i + 1, y - range + j, z - range + k);
2014-10-13 20:33:20 +00:00
if (world.isAirBlock(x - range + i + 1, y - range + j, z - range + k) || block == ModBlocks.blockSpectralContainer)
2014-07-31 23:45:40 +00:00
{
boolList[i + 1][j][k] = true;
isReady = false;
}
}
if (j + 1 <= 2 * range && !boolList[i][j + 1][k])
{
Block block = world.getBlock(x - range + i, y - range + j + 1, z - range + k);
2014-10-13 20:33:20 +00:00
if (world.isAirBlock(x - range + i, y - range + j + 1, z - range + k) || block == ModBlocks.blockSpectralContainer)
2014-07-31 23:45:40 +00:00
{
boolList[i][j + 1][k] = true;
isReady = false;
}
}
2014-10-13 20:33:20 +00:00
if (k + 1 <= 2 * range && !boolList[i][j][k + 1])
2014-07-31 23:45:40 +00:00
{
2014-10-13 20:33:20 +00:00
Block block = world.getBlock(x - range + i, y - range + j, z - range + k + 1);
if (world.isAirBlock(x - range + i, y - range + j, z - range + k + 1) || block == ModBlocks.blockSpectralContainer)
2014-07-31 23:45:40 +00:00
{
2014-10-13 20:33:20 +00:00
boolList[i][j][k + 1] = true;
2014-07-31 23:45:40 +00:00
isReady = false;
}
}
}
2014-10-13 20:33:20 +00:00
}
2014-07-31 23:45:40 +00:00
}
}
}
2014-10-13 20:33:20 +00:00
2014-07-31 23:45:40 +00:00
for (int i = 0; i < 2 * range + 1; i++)
{
for (int j = 0; j < 2 * range + 1; j++)
{
2014-10-13 20:33:20 +00:00
for (int k = 0; k < 2 * range + 1; k++)
{
if (!boolList[i][j][k])
{
continue;
}
Block block = world.getBlock(x + i - range, y + j - range, z + k - range);
if (block == ModBlocks.blockSpectralContainer)
{
world.setBlockToAir(x + i - range, y + j - range, z + k - range);
}
}
2014-07-31 23:45:40 +00:00
}
}
2014-10-13 20:33:20 +00:00
SoulNetworkHandler.syphonFromNetwork(owner, this.getCostPerRefresh());
2014-10-13 20:33:20 +00:00
ritualStone.setActive(false);
2014-07-31 23:45:40 +00:00
}
}
@Override
public int getCostPerRefresh()
{
return 0;
}
@Override
2014-10-13 20:33:20 +00:00
public List<RitualComponent> getRitualComponentList()
{
ArrayList<RitualComponent> ellipsoidRitual = new ArrayList();
ellipsoidRitual.add(new RitualComponent(-1, 0, -1, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(-1, 0, 1, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(1, 0, -1, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(1, 0, 1, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(4, 0, 0, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(5, 0, 0, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(5, 0, -1, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(5, 0, -2, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(-4, 0, 0, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(-5, 0, 0, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(-5, 0, 1, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(-5, 0, 2, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(0, 0, 4, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(0, 0, 5, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(1, 0, 5, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(2, 0, 5, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(0, 0, -4, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(0, 0, -5, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(-1, 0, -5, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(-2, 0, -5, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(3, 0, 1, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(3, 0, 2, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(3, 0, 3, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(2, 0, 3, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(-3, 0, -1, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(-3, 0, -2, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(-3, 0, -3, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(-2, 0, -3, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(1, 0, -3, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(2, 0, -3, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(3, 0, -3, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(3, 0, -2, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(-1, 0, 3, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(-2, 0, 3, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(-3, 0, 3, RitualComponent.DUSK));
ellipsoidRitual.add(new RitualComponent(-3, 0, 2, RitualComponent.DUSK));
2014-07-31 23:45:40 +00:00
return ellipsoidRitual;
2014-10-13 20:33:20 +00:00
}
2014-07-31 23:45:40 +00:00
public int getRadiusForModifierBlock(Block block)
2014-10-13 20:33:20 +00:00
{
if (block == null)
{
return 10;
}
if (block == Blocks.diamond_block)
{
return 30;
}
if (block == Blocks.gold_block)
{
return 20;
}
if (block == Blocks.iron_block)
{
return 15;
}
return 10;
}
2014-07-31 23:45:40 +00:00
}