Fixed grinder to separate client and server statics

This commit is contained in:
Calclavia 2014-01-05 19:35:56 +08:00
parent 23223da214
commit 9cce3f302e
2 changed files with 104 additions and 41 deletions

View file

@ -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

View file

@ -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;
} }
} }