Fixed grinder to separate client and server statics
This commit is contained in:
parent
23223da214
commit
9cce3f302e
2 changed files with 104 additions and 41 deletions
|
@ -26,33 +26,41 @@ public class BlockGrinderWheel extends BlockRotatableBase implements ITileEntity
|
||||||
@Override
|
@Override
|
||||||
public void onEntityCollidedWithBlock(World world, int x, int y, int z, Entity entity)
|
public void onEntityCollidedWithBlock(World world, int x, int y, int z, Entity entity)
|
||||||
{
|
{
|
||||||
if (entity instanceof EntityItem)
|
TileGrinderWheel tile = (TileGrinderWheel) world.getBlockTileEntity(x, y, z);
|
||||||
{
|
|
||||||
TileGrinderWheel tile = (TileGrinderWheel) world.getBlockTileEntity(x, y, z);
|
|
||||||
|
|
||||||
if (tile.canGrind(((EntityItem) entity).getEntityItem()))
|
if (tile.canWork())
|
||||||
|
{
|
||||||
|
if (entity instanceof EntityItem)
|
||||||
{
|
{
|
||||||
if (!tile.grinderTimer.containsKey((EntityItem) entity))
|
if (tile.canGrind(((EntityItem) entity).getEntityItem()))
|
||||||
{
|
{
|
||||||
tile.grinderTimer.put((EntityItem) entity, 10 * 20);
|
if (tile.grindingItem == null)
|
||||||
|
{
|
||||||
|
tile.grindingItem = (EntityItem) entity;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!tile.getTimer().containsKey((EntityItem) entity))
|
||||||
|
{
|
||||||
|
tile.getTimer().put((EntityItem) entity, TileGrinderWheel.DEFAULT_TIME);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
entity.setPosition(entity.posX, entity.posY - 1.2, entity.posZ);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
entity.setPosition(entity.posX, entity.posY - 1.2, entity.posZ);
|
entity.attackEntityFrom(DamageSource.cactus, 2);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
entity.attackEntityFrom(DamageSource.cactus, 2);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Move entity based on the direction of the block.
|
// Move entity based on the direction of the block.
|
||||||
ForgeDirection dir = this.getDirection(world, x, y, z);
|
ForgeDirection dir = this.getDirection(world, x, y, z);
|
||||||
entity.motionX += dir.offsetX * 0.1;
|
entity.motionX += dir.offsetX * 0.1;
|
||||||
entity.motionZ += dir.offsetZ * 0.1;
|
entity.motionZ += dir.offsetZ * 0.1;
|
||||||
|
entity.motionY += 0.3;
|
||||||
entity.motionY += Math.random() * 0.3;
|
entity.isAirBorne = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -1,18 +1,18 @@
|
||||||
package resonantinduction.machine.grinder;
|
package resonantinduction.machine.grinder;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Iterator;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map.Entry;
|
|
||||||
|
|
||||||
import net.minecraft.entity.item.EntityItem;
|
import net.minecraft.entity.item.EntityItem;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
|
import resonantinduction.ResonantInduction;
|
||||||
import resonantinduction.api.MachineRecipes;
|
import resonantinduction.api.MachineRecipes;
|
||||||
import resonantinduction.api.MachineRecipes.RecipeType;
|
import resonantinduction.api.MachineRecipes.RecipeType;
|
||||||
import resonantinduction.api.RecipeUtils.ItemStackResource;
|
import resonantinduction.api.RecipeUtils.ItemStackResource;
|
||||||
import resonantinduction.api.RecipeUtils.Resource;
|
import resonantinduction.api.RecipeUtils.Resource;
|
||||||
import universalelectricity.api.energy.EnergyStorageHandler;
|
import universalelectricity.api.energy.EnergyStorageHandler;
|
||||||
import calclavia.lib.prefab.tile.TileElectrical;
|
import calclavia.lib.prefab.tile.TileElectrical;
|
||||||
|
import cpw.mods.fml.common.FMLCommonHandler;
|
||||||
|
import cpw.mods.fml.relauncher.Side;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Calclavia
|
* @author Calclavia
|
||||||
|
@ -20,8 +20,10 @@ import calclavia.lib.prefab.tile.TileElectrical;
|
||||||
*/
|
*/
|
||||||
public class TileGrinderWheel extends TileElectrical
|
public class TileGrinderWheel extends TileElectrical
|
||||||
{
|
{
|
||||||
|
public static final int DEFAULT_TIME = 20 * 20;
|
||||||
/** A map of ItemStacks and their remaining grind-time left. */
|
/** A map of ItemStacks and their remaining grind-time left. */
|
||||||
public static final HashMap<EntityItem, Integer> grinderTimer = new HashMap<EntityItem, Integer>();
|
private static final HashMap<EntityItem, Integer> clientGrinderTimer = new HashMap<EntityItem, Integer>();
|
||||||
|
private static final HashMap<EntityItem, Integer> serverGrinderTimer = new HashMap<EntityItem, Integer>();
|
||||||
|
|
||||||
public EntityItem grindingItem = null;
|
public EntityItem grindingItem = null;
|
||||||
|
|
||||||
|
@ -33,30 +35,71 @@ public class TileGrinderWheel extends TileElectrical
|
||||||
@Override
|
@Override
|
||||||
public void updateEntity()
|
public void updateEntity()
|
||||||
{
|
{
|
||||||
|
super.updateEntity();
|
||||||
// TODO: Add electricity support.
|
// TODO: Add electricity support.
|
||||||
doWork();
|
doWork();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Can this machine work this tick?
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public boolean canWork()
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
public void doWork()
|
public void doWork()
|
||||||
{
|
{
|
||||||
if (grindingItem != null && grinderTimer.containsKey(grindingItem))
|
boolean didWork = false;
|
||||||
{
|
|
||||||
int timeLeft = grinderTimer.get(grindingItem) - 1;
|
|
||||||
grinderTimer.put(grindingItem, timeLeft);
|
|
||||||
|
|
||||||
if (timeLeft <= 0)
|
if (grindingItem != null)
|
||||||
|
{
|
||||||
|
if (getTimer().containsKey(grindingItem) && !grindingItem.isDead)
|
||||||
{
|
{
|
||||||
if (this.doGrind(grindingItem))
|
int timeLeft = getTimer().get(grindingItem) - 1;
|
||||||
|
getTimer().put(grindingItem, timeLeft);
|
||||||
|
|
||||||
|
if (timeLeft <= 0)
|
||||||
{
|
{
|
||||||
grindingItem.setDead();
|
if (this.doGrind(grindingItem))
|
||||||
grinderTimer.remove(grindingItem);
|
{
|
||||||
grindingItem = null;
|
if (--grindingItem.getEntityItem().stackSize <= 0)
|
||||||
|
{
|
||||||
|
grindingItem.setDead();
|
||||||
|
getTimer().remove(grindingItem);
|
||||||
|
grindingItem = null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
grindingItem.setEntityItemStack(grindingItem.getEntityItem());
|
||||||
|
// Reset timer
|
||||||
|
getTimer().put(grindingItem, DEFAULT_TIME);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
grindingItem.delayBeforeCanPickup = 20;
|
||||||
|
this.worldObj.spawnParticle("crit", grindingItem.posX, grindingItem.posY, grindingItem.posZ, (Math.random() - 0.5f) * 3, (Math.random() - 0.5f) * 3, (Math.random() - 0.5f) * 3);
|
||||||
|
}
|
||||||
|
|
||||||
|
didWork = true;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
grindingItem.delayBeforeCanPickup = 20;
|
getTimer().remove(grindingItem);
|
||||||
this.worldObj.spawnParticle("crit", grindingItem.posX, grindingItem.posY, grindingItem.posZ, (Math.random() - 0.5f) * 3, (Math.random() - 0.5f) * 3, (Math.random() - 0.5f) * 3);
|
grindingItem = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (didWork)
|
||||||
|
{
|
||||||
|
// TODO: Consume energy.
|
||||||
|
if (this.ticks % 20 == 0)
|
||||||
|
{
|
||||||
|
this.worldObj.playSoundEffect(this.xCoord + 0.5, this.yCoord + 0.5, this.zCoord + 0.5, ResonantInduction.PREFIX + "grinder", 0.5f, 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -68,15 +111,15 @@ public class TileGrinderWheel extends TileElectrical
|
||||||
|
|
||||||
private boolean doGrind(EntityItem entity)
|
private boolean doGrind(EntityItem entity)
|
||||||
{
|
{
|
||||||
if (!this.worldObj.isRemote)
|
ItemStack itemStack = entity.getEntityItem();
|
||||||
|
|
||||||
|
Resource[] results = MachineRecipes.INSTANCE.getRecipe(RecipeType.GRINDER, itemStack);
|
||||||
|
|
||||||
|
for (Resource resource : results)
|
||||||
{
|
{
|
||||||
ItemStack itemStack = entity.getEntityItem();
|
if (resource instanceof ItemStackResource)
|
||||||
|
|
||||||
Resource[] results = MachineRecipes.INSTANCE.getRecipe(RecipeType.GRINDER, itemStack);
|
|
||||||
|
|
||||||
for (Resource resource : results)
|
|
||||||
{
|
{
|
||||||
if (resource instanceof ItemStackResource)
|
if (!this.worldObj.isRemote)
|
||||||
{
|
{
|
||||||
EntityItem entityItem = new EntityItem(this.worldObj, entity.posX, entity.posY, entity.posZ, ((ItemStackResource) resource).itemStack.copy());
|
EntityItem entityItem = new EntityItem(this.worldObj, entity.posX, entity.posY, entity.posZ, ((ItemStackResource) resource).itemStack.copy());
|
||||||
entityItem.delayBeforeCanPickup = 20;
|
entityItem.delayBeforeCanPickup = 20;
|
||||||
|
@ -85,9 +128,21 @@ public class TileGrinderWheel extends TileElectrical
|
||||||
entityItem.motionZ = 0;
|
entityItem.motionZ = 0;
|
||||||
this.worldObj.spawnEntityInWorld(entityItem);
|
this.worldObj.spawnEntityInWorld(entityItem);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static HashMap<EntityItem, Integer> getTimer()
|
||||||
|
{
|
||||||
|
if (FMLCommonHandler.instance().getEffectiveSide() == Side.SERVER)
|
||||||
|
{
|
||||||
|
return serverGrinderTimer;
|
||||||
|
}
|
||||||
|
|
||||||
|
return clientGrinderTimer;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue