This miner is pretty much done :)
This commit is contained in:
parent
1c674f4317
commit
d01d444753
4 changed files with 29 additions and 11 deletions
|
@ -15,7 +15,7 @@ import net.minecraft.item.ItemStack;
|
|||
|
||||
public interface IAdvancedBoundingBlock extends IBoundingBlock, ISidedInventory, IEnergySink, IStrictEnergyAcceptor, IPowerReceptor, IEnergyTile, IElectrical, IElectricalStorage, IConnector, IStrictEnergyStorage, IEnergyHandler
|
||||
{
|
||||
public int[] getBoundSlots(Object3D location, int slotID);
|
||||
public int[] getBoundSlots(Object3D location, int side);
|
||||
|
||||
public boolean canBoundInsert(Object3D location, int i, ItemStack itemstack);
|
||||
|
||||
|
|
|
@ -422,6 +422,10 @@ public class Mekanism
|
|||
CraftingManager.getInstance().getRecipeList().add(new MekanismRecipe(new ItemStack(BasicBlock, 1, 6), new Object[] {
|
||||
"SSS", "SCS", "SSS", Character.valueOf('S'), Block.cobblestone, Character.valueOf('C'), "circuitBasic"
|
||||
}));
|
||||
CraftingManager.getInstance().getRecipeList().add(new MekanismRecipe(new ItemStack(MachineBlock, 1, 4), new Object[] {
|
||||
"ACA", "SES", "TIT", Character.valueOf('A'), AtomicCore, Character.valueOf('C'), "circuitBasic", Character.valueOf('S'), new ItemStack(MachineBlock, 1, 15), Character.valueOf('E'), new ItemStack(MachineBlock, 1, 13),
|
||||
Character.valueOf('I'), new ItemStack(BasicBlock, 1, 8), Character.valueOf('T'), TeleportationCore
|
||||
}));
|
||||
|
||||
//Factory Recipes
|
||||
CraftingManager.getInstance().getRecipeList().add(new MekanismRecipe(MekanismUtils.getFactory(FactoryTier.BASIC, RecipeType.SMELTING), new Object[] {
|
||||
|
|
|
@ -25,6 +25,7 @@ import mekanism.common.miner.MinerFilter;
|
|||
import mekanism.common.miner.ThreadMinerSearch;
|
||||
import mekanism.common.miner.ThreadMinerSearch.State;
|
||||
import mekanism.common.network.PacketTileEntity;
|
||||
import mekanism.common.transporter.InvStack;
|
||||
import mekanism.common.util.ChargeUtils;
|
||||
import mekanism.common.util.InventoryUtils;
|
||||
import mekanism.common.util.MekanismUtils;
|
||||
|
@ -237,9 +238,15 @@ public class TileEntityDigitalMiner extends TileEntityElectricBlock implements I
|
|||
}
|
||||
}
|
||||
|
||||
if(doPull)
|
||||
if(doPull && getPullInv() instanceof IInventory)
|
||||
{
|
||||
//TODO
|
||||
InvStack stack = InventoryUtils.takeDefinedItem((IInventory)getPullInv(), 1, replaceStack.copy(), 1, 1);
|
||||
|
||||
if(stack != null)
|
||||
{
|
||||
stack.use();
|
||||
return MekanismUtils.size(replaceStack, 1);
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
|
@ -323,16 +330,16 @@ public class TileEntityDigitalMiner extends TileEntityElectricBlock implements I
|
|||
return false;
|
||||
}
|
||||
|
||||
public IInventory getPullInv()
|
||||
public TileEntity getPullInv()
|
||||
{
|
||||
return null;
|
||||
return new Object3D(xCoord, yCoord+2, zCoord).getTileEntity(worldObj);
|
||||
}
|
||||
|
||||
public TileEntity getEjectInv()
|
||||
{
|
||||
ForgeDirection side = ForgeDirection.getOrientation(facing).getOpposite();
|
||||
|
||||
return (TileEntity)new Object3D(xCoord+(side.offsetX*2), yCoord+1, zCoord+(side.offsetZ*2), worldObj.provider.dimensionId).getTileEntity(worldObj);
|
||||
return new Object3D(xCoord+(side.offsetX*2), yCoord+1, zCoord+(side.offsetZ*2), worldObj.provider.dimensionId).getTileEntity(worldObj);
|
||||
}
|
||||
|
||||
public void add(List<ItemStack> stacks)
|
||||
|
@ -925,14 +932,14 @@ public class TileEntityDigitalMiner extends TileEntityElectricBlock implements I
|
|||
}
|
||||
|
||||
@Override
|
||||
public int[] getBoundSlots(Object3D location, int slotID)
|
||||
public int[] getBoundSlots(Object3D location, int side)
|
||||
{
|
||||
ForgeDirection side = ForgeDirection.getOrientation(facing).getOpposite();
|
||||
ForgeDirection dir = ForgeDirection.getOrientation(facing).getOpposite();
|
||||
|
||||
Object3D eject = new Object3D(xCoord+side.offsetX, yCoord+1, zCoord+side.offsetZ, worldObj.provider.dimensionId);
|
||||
Object3D eject = new Object3D(xCoord+dir.offsetX, yCoord+1, zCoord+dir.offsetZ, worldObj.provider.dimensionId);
|
||||
Object3D pull = new Object3D(xCoord, yCoord+1, zCoord);
|
||||
|
||||
if(location.equals(eject) || location.equals(pull))
|
||||
if((location.equals(eject) && side == dir.ordinal()) || (location.equals(pull) && side == 1))
|
||||
{
|
||||
int[] ret = new int[27];
|
||||
|
||||
|
|
|
@ -244,7 +244,14 @@ public class FXElectricBolt extends EntityFX
|
|||
{
|
||||
lastActiveSegment.put(lastSplitCalc, lastActiveSeg);
|
||||
lastSplitCalc = segment.splitID;
|
||||
lastActiveSeg = lastActiveSegment.get(parentIDMap.get(segment.splitID)).intValue();
|
||||
|
||||
if(lastActiveSegment.get(parentIDMap.get(segment.splitID)) != null)
|
||||
{
|
||||
lastActiveSeg = lastActiveSegment.get(parentIDMap.get(segment.splitID)).intValue();
|
||||
}
|
||||
else {
|
||||
lastActiveSeg = 0;
|
||||
}
|
||||
}
|
||||
|
||||
lastActiveSeg = segment.id;
|
||||
|
|
Loading…
Reference in a new issue