2013-05-14 11:34:26 -04:00
|
|
|
package mekanism.client;
|
|
|
|
|
|
|
|
import java.util.HashSet;
|
|
|
|
import java.util.Random;
|
|
|
|
import java.util.Set;
|
|
|
|
|
2013-12-20 16:09:09 -05:00
|
|
|
import mekanism.api.Coord4D;
|
2013-05-14 11:34:26 -04:00
|
|
|
import mekanism.common.Mekanism;
|
2013-08-26 18:49:32 -04:00
|
|
|
import mekanism.common.tileentity.TileEntityDynamicTank;
|
2013-05-14 11:34:26 -04:00
|
|
|
import net.minecraft.tileentity.TileEntity;
|
|
|
|
import net.minecraft.world.World;
|
|
|
|
import net.minecraftforge.common.ForgeDirection;
|
2013-10-14 23:36:07 -04:00
|
|
|
import cpw.mods.fml.relauncher.Side;
|
|
|
|
import cpw.mods.fml.relauncher.SideOnly;
|
2013-05-14 11:34:26 -04:00
|
|
|
|
2013-05-29 11:35:30 -04:00
|
|
|
@SideOnly(Side.CLIENT)
|
2013-05-14 11:34:26 -04:00
|
|
|
public class ThreadTankSparkle extends Thread
|
|
|
|
{
|
|
|
|
public TileEntityDynamicTank pointer;
|
|
|
|
|
|
|
|
public Random random = new Random();
|
|
|
|
|
|
|
|
public Set<TileEntity> iteratedNodes = new HashSet<TileEntity>();
|
|
|
|
|
|
|
|
public ThreadTankSparkle(TileEntityDynamicTank tileEntity)
|
|
|
|
{
|
|
|
|
pointer = tileEntity;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void run()
|
|
|
|
{
|
2013-05-19 18:43:01 -04:00
|
|
|
try {
|
|
|
|
if(Mekanism.dynamicTankEasterEgg)
|
|
|
|
{
|
2013-12-20 16:09:09 -05:00
|
|
|
MekanismClient.audioHandler.quickPlay("cj/CJ_" + (random.nextInt(3)+1) + ".ogg", pointer.worldObj, Coord4D.get(pointer));
|
2013-05-19 18:43:01 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
loop(pointer);
|
|
|
|
} catch(Exception e) {}
|
2013-05-14 11:34:26 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
public void loop(TileEntityDynamicTank tileEntity)
|
|
|
|
{
|
|
|
|
World world = pointer.worldObj;
|
|
|
|
|
|
|
|
for(int i = 0; i < 6; i++)
|
|
|
|
{
|
2013-12-20 16:09:09 -05:00
|
|
|
if(Coord4D.get(tileEntity).sideVisible(ForgeDirection.DOWN, world))
|
2013-05-14 11:34:26 -04:00
|
|
|
{
|
|
|
|
world.spawnParticle("reddust", tileEntity.xCoord + random.nextDouble(), tileEntity.yCoord + -.01, tileEntity.zCoord + random.nextDouble(), 0, 0, 0);
|
|
|
|
}
|
|
|
|
|
2013-12-20 16:09:09 -05:00
|
|
|
if(Coord4D.get(tileEntity).sideVisible(ForgeDirection.UP, world))
|
2013-05-14 11:34:26 -04:00
|
|
|
{
|
|
|
|
world.spawnParticle("reddust", tileEntity.xCoord + random.nextDouble(), tileEntity.yCoord + 1.01, tileEntity.zCoord + random.nextDouble(), 0, 0, 0);
|
|
|
|
}
|
|
|
|
|
2013-12-20 16:09:09 -05:00
|
|
|
if(Coord4D.get(tileEntity).sideVisible(ForgeDirection.NORTH, world))
|
2013-05-14 11:34:26 -04:00
|
|
|
{
|
|
|
|
world.spawnParticle("reddust", tileEntity.xCoord + random.nextDouble(), tileEntity.yCoord + random.nextDouble(), tileEntity.zCoord + -.01, 0, 0, 0);
|
|
|
|
}
|
|
|
|
|
2013-12-20 16:09:09 -05:00
|
|
|
if(Coord4D.get(tileEntity).sideVisible(ForgeDirection.SOUTH, world))
|
2013-05-14 11:34:26 -04:00
|
|
|
{
|
|
|
|
world.spawnParticle("reddust", tileEntity.xCoord + random.nextDouble(), tileEntity.yCoord + random.nextDouble(), tileEntity.zCoord + 1.01, 0, 0, 0);
|
|
|
|
}
|
|
|
|
|
2013-12-20 16:09:09 -05:00
|
|
|
if(Coord4D.get(tileEntity).sideVisible(ForgeDirection.WEST, world))
|
2013-05-14 11:34:26 -04:00
|
|
|
{
|
|
|
|
world.spawnParticle("reddust", tileEntity.xCoord + -.01, tileEntity.yCoord + random.nextDouble(), tileEntity.zCoord + random.nextDouble(), 0, 0, 0);
|
|
|
|
}
|
|
|
|
|
2013-12-20 16:09:09 -05:00
|
|
|
if(Coord4D.get(tileEntity).sideVisible(ForgeDirection.EAST, world))
|
2013-05-14 11:34:26 -04:00
|
|
|
{
|
|
|
|
world.spawnParticle("reddust", tileEntity.xCoord + 1.01, tileEntity.yCoord + random.nextDouble(), tileEntity.zCoord + random.nextDouble(), 0, 0, 0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
iteratedNodes.add(tileEntity);
|
|
|
|
|
|
|
|
for(ForgeDirection side : ForgeDirection.VALID_DIRECTIONS)
|
|
|
|
{
|
2013-12-20 16:09:09 -05:00
|
|
|
TileEntity tile = Coord4D.get(tileEntity).getFromSide(side).getTileEntity(pointer.worldObj);
|
2013-05-14 11:34:26 -04:00
|
|
|
|
|
|
|
if(tile instanceof TileEntityDynamicTank && !iteratedNodes.contains(tile))
|
|
|
|
{
|
|
|
|
loop((TileEntityDynamicTank)tile);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|