made progress at resurecting Quarry, for #1561

This commit is contained in:
SpaceToad 2014-04-05 17:31:59 +02:00
parent 757bea50dc
commit ac055f0b4f
23 changed files with 144 additions and 221 deletions

View file

@ -42,7 +42,6 @@ import buildcraft.factory.FactoryProxy;
import buildcraft.factory.FactoryProxyClient; import buildcraft.factory.FactoryProxyClient;
import buildcraft.factory.GuiHandler; import buildcraft.factory.GuiHandler;
import buildcraft.factory.PumpDimensionList; import buildcraft.factory.PumpDimensionList;
import buildcraft.factory.SchematicFrame;
import buildcraft.factory.SchematicRefinery; import buildcraft.factory.SchematicRefinery;
import buildcraft.factory.SchematicTank; import buildcraft.factory.SchematicTank;
import buildcraft.factory.TileAutoWorkbench; import buildcraft.factory.TileAutoWorkbench;
@ -145,7 +144,6 @@ public class BuildCraftFactory extends BuildCraftMod {
FactoryProxy.proxy.initializeTileEntities(); FactoryProxy.proxy.initializeTileEntities();
SchematicRegistry.registerSchematicBlock(frameBlock, SchematicFrame.class);
SchematicRegistry.registerSchematicBlock(refineryBlock, SchematicRefinery.class); SchematicRegistry.registerSchematicBlock(refineryBlock, SchematicRefinery.class);
SchematicRegistry.registerSchematicBlock(tankBlock, SchematicTank.class); SchematicRegistry.registerSchematicBlock(tankBlock, SchematicTank.class);

View file

@ -8,8 +8,10 @@
*/ */
package buildcraft.api.filler; package buildcraft.api.filler;
import net.minecraft.block.Block;
import net.minecraft.util.IIcon; import net.minecraft.util.IIcon;
import buildcraft.core.Box; import buildcraft.core.Box;
import buildcraft.core.blueprints.Blueprint;
import buildcraft.core.blueprints.Template; import buildcraft.core.blueprints.Template;
import cpw.mods.fml.relauncher.Side; import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly; import cpw.mods.fml.relauncher.SideOnly;
@ -23,5 +25,7 @@ public interface IFillerPattern {
public String getDisplayName(); public String getDisplayName();
public Template getBlueprint (Box box); public Template getTemplate (Box box);
public Blueprint getBlueprint (Box box, Block block);
} }

View file

@ -178,11 +178,8 @@ public class BuildingItem implements IBuilder {
Block block = context.world().getBlock((int) destination.x, (int)destination.y, (int)destination.z); Block block = context.world().getBlock((int) destination.x, (int)destination.y, (int)destination.z);
int meta = context.world().getBlockMetadata((int) destination.x, (int)destination.y, (int)destination.z); int meta = context.world().getBlockMetadata((int) destination.x, (int)destination.y, (int)destination.z);
context.world().playAuxSFXAtEntity( context.world().playAuxSFXAtEntity(null, 2001,
null, (int) destination.x, (int) destination.y,
2001,
(int) destination.x,
(int) destination.y,
(int) destination.z, (int) destination.z,
Block.getIdFromBlock(block) + (meta << 12)); Block.getIdFromBlock(block) + (meta << 12));

View file

@ -12,8 +12,10 @@ import java.util.ArrayList;
import java.util.LinkedList; import java.util.LinkedList;
import net.minecraft.inventory.IInventory; import net.minecraft.inventory.IInventory;
import net.minecraft.nbt.NBTTagCompound;
import buildcraft.api.core.SafeTimeTracker; import buildcraft.api.core.SafeTimeTracker;
import buildcraft.api.mj.MjBattery; import buildcraft.api.mj.MjBattery;
import buildcraft.core.IBoxProvider;
import buildcraft.core.LaserData; import buildcraft.core.LaserData;
import buildcraft.core.TileBuildCraft; import buildcraft.core.TileBuildCraft;
import buildcraft.core.network.NetworkData; import buildcraft.core.network.NetworkData;
@ -21,7 +23,7 @@ import buildcraft.core.network.RPC;
import buildcraft.core.network.RPCHandler; import buildcraft.core.network.RPCHandler;
import buildcraft.core.network.RPCSide; import buildcraft.core.network.RPCSide;
public abstract class TileAbstractBuilder extends TileBuildCraft implements IInventory { public abstract class TileAbstractBuilder extends TileBuildCraft implements IInventory, IBoxProvider {
public static double BREAK_ENERGY = 10; public static double BREAK_ENERGY = 10;
public static double BUILD_ENERGY = 20; public static double BUILD_ENERGY = 20;
@ -83,5 +85,17 @@ public abstract class TileAbstractBuilder extends TileBuildCraft implements IInv
mjStored -= quantity; mjStored -= quantity;
} }
@Override
public void readFromNBT(NBTTagCompound nbttagcompound) {
super.readFromNBT(nbttagcompound);
mjStored = nbttagcompound.getDouble("mjStored");
}
@Override
public void writeToNBT(NBTTagCompound nbttagcompound) {
super.writeToNBT(nbttagcompound);
nbttagcompound.setDouble("mjStored", mjStored);
}
} }

View file

@ -26,7 +26,6 @@ import buildcraft.api.gates.IAction;
import buildcraft.core.BlockIndex; import buildcraft.core.BlockIndex;
import buildcraft.core.Box; import buildcraft.core.Box;
import buildcraft.core.Box.Kind; import buildcraft.core.Box.Kind;
import buildcraft.core.IBoxProvider;
import buildcraft.core.IMachine; import buildcraft.core.IMachine;
import buildcraft.core.LaserData; import buildcraft.core.LaserData;
import buildcraft.core.blueprints.Blueprint; import buildcraft.core.blueprints.Blueprint;
@ -41,7 +40,7 @@ import buildcraft.core.network.RPCHandler;
import buildcraft.core.network.RPCSide; import buildcraft.core.network.RPCSide;
import buildcraft.core.utils.Utils; import buildcraft.core.utils.Utils;
public class TileBuilder extends TileAbstractBuilder implements IMachine, IBoxProvider { public class TileBuilder extends TileAbstractBuilder implements IMachine {
private static int POWER_ACTIVATION = 50; private static int POWER_ACTIVATION = 50;

View file

@ -26,7 +26,6 @@ import buildcraft.builders.filler.pattern.PatternFill;
import buildcraft.builders.triggers.ActionFiller; import buildcraft.builders.triggers.ActionFiller;
import buildcraft.core.Box; import buildcraft.core.Box;
import buildcraft.core.Box.Kind; import buildcraft.core.Box.Kind;
import buildcraft.core.IBoxProvider;
import buildcraft.core.IMachine; import buildcraft.core.IMachine;
import buildcraft.core.blueprints.BptBuilderTemplate; import buildcraft.core.blueprints.BptBuilderTemplate;
import buildcraft.core.blueprints.BptContext; import buildcraft.core.blueprints.BptContext;
@ -40,7 +39,7 @@ import buildcraft.core.triggers.ActionMachineControl;
import buildcraft.core.triggers.ActionMachineControl.Mode; import buildcraft.core.triggers.ActionMachineControl.Mode;
import buildcraft.core.utils.Utils; import buildcraft.core.utils.Utils;
public class TileFiller extends TileAbstractBuilder implements IMachine, IActionReceptor, IBoxProvider { public class TileFiller extends TileAbstractBuilder implements IMachine, IActionReceptor {
public IFillerPattern currentPattern = PatternFill.INSTANCE; public IFillerPattern currentPattern = PatternFill.INSTANCE;
@ -105,7 +104,7 @@ public class TileFiller extends TileAbstractBuilder implements IMachine, IAction
if (currentPattern != null && currentTemplate == null) { if (currentPattern != null && currentTemplate == null) {
currentTemplate = new BptBuilderTemplate( currentTemplate = new BptBuilderTemplate(
currentPattern.getBlueprint(box), getWorld(), box.xMin, currentPattern.getTemplate(box), getWorld(), box.xMin,
box.yMin, box.zMin); box.yMin, box.zMin);
context = currentTemplate.getContext(); context = currentTemplate.getContext();
} }

View file

@ -11,10 +11,14 @@ package buildcraft.builders.filler.pattern;
import java.util.Map; import java.util.Map;
import java.util.TreeMap; import java.util.TreeMap;
import net.minecraft.block.Block;
import net.minecraft.client.renderer.texture.IIconRegister; import net.minecraft.client.renderer.texture.IIconRegister;
import net.minecraft.util.IIcon; import net.minecraft.util.IIcon;
import buildcraft.api.blueprints.SchematicMask; import buildcraft.api.blueprints.SchematicMask;
import buildcraft.api.blueprints.SchematicRegistry;
import buildcraft.api.filler.IFillerPattern; import buildcraft.api.filler.IFillerPattern;
import buildcraft.core.Box;
import buildcraft.core.blueprints.Blueprint;
import buildcraft.core.blueprints.Template; import buildcraft.core.blueprints.Template;
import buildcraft.core.utils.StringUtils; import buildcraft.core.utils.StringUtils;
@ -97,4 +101,25 @@ public abstract class FillerPattern implements IFillerPattern {
} }
} }
} }
@Override
public Blueprint getBlueprint (Box box, Block block) {
Blueprint result = new Blueprint (box.sizeX(), box.sizeY(), box.sizeZ());
Template tmpl = getTemplate(box);
for (int x = 0; x < box.sizeX(); ++x) {
for (int y = 0; y < box.sizeY(); ++y) {
for (int z = 0; z < box.sizeZ(); ++z) {
if (tmpl.contents[x][y][z] != null) {
result.contents[x][y][z] = SchematicRegistry
.newSchematicBlock(block);
}
}
}
}
return result;
}
} }

View file

@ -19,7 +19,7 @@ public class PatternBox extends FillerPattern {
} }
@Override @Override
public Template getBlueprint(Box box) { public Template getTemplate(Box box) {
Template result = new Template (box.sizeX(), box.sizeY(), box.sizeZ()); Template result = new Template (box.sizeX(), box.sizeY(), box.sizeZ());
int xMin = 0; int xMin = 0;

View file

@ -18,7 +18,7 @@ public class PatternClear extends FillerPattern {
} }
@Override @Override
public Template getBlueprint (Box box) { public Template getTemplate (Box box) {
int xMin = (int) box.pMin().x; int xMin = (int) box.pMin().x;
int yMin = (int) box.pMin().y; int yMin = (int) box.pMin().y;
int zMin = (int) box.pMin().z; int zMin = (int) box.pMin().z;

View file

@ -19,7 +19,7 @@ public class PatternCylinder extends FillerPattern {
@Override @Override
public Template getBlueprint(Box box) { public Template getTemplate(Box box) {
Template result = new Template (box.sizeX(), box.sizeY(), box.sizeZ()); Template result = new Template (box.sizeX(), box.sizeY(), box.sizeZ());
int xMin = 0; int xMin = 0;

View file

@ -20,7 +20,7 @@ public class PatternFill extends FillerPattern {
} }
@Override @Override
public Template getBlueprint (Box box) { public Template getTemplate (Box box) {
Template bpt = new Template(box.sizeX(), box.sizeY(), box.sizeZ()); Template bpt = new Template(box.sizeX(), box.sizeY(), box.sizeZ());
fill (0, 0, 0, box.sizeX() - 1, box.sizeY() - 1, box.sizeZ() - 1, bpt); fill (0, 0, 0, box.sizeX() - 1, box.sizeY() - 1, box.sizeZ() - 1, bpt);

View file

@ -19,7 +19,7 @@ public class PatternFlatten extends FillerPattern {
} }
@Override @Override
public Template getBlueprint (Box box) { public Template getTemplate (Box box) {
int xMin = (int) box.pMin().x; int xMin = (int) box.pMin().x;
int yMin = 1; int yMin = 1;
int zMin = (int) box.pMin().z; int zMin = (int) box.pMin().z;

View file

@ -20,7 +20,7 @@ public class PatternFrame extends FillerPattern {
} }
@Override @Override
public Template getBlueprint(Box box) { public Template getTemplate(Box box) {
Template template = new Template (box.sizeX(), box.sizeY(), box.sizeZ()); Template template = new Template (box.sizeX(), box.sizeY(), box.sizeZ());
int xMin = 0; int xMin = 0;

View file

@ -18,7 +18,7 @@ public class PatternHorizon extends FillerPattern {
} }
@Override @Override
public Template getBlueprint(Box box) { public Template getTemplate(Box box) {
/* /*
int xMin = 0; int xMin = 0;
int yMin = 0; int yMin = 0;

View file

@ -22,7 +22,7 @@ public class PatternPyramid extends FillerPattern {
boolean param1 = true; boolean param1 = true;
@Override @Override
public Template getBlueprint (Box box) { public Template getTemplate (Box box) {
int xMin = (int) box.pMin().x; int xMin = (int) box.pMin().x;
int yMin = (int) box.pMin().y; int yMin = (int) box.pMin().y;
int zMin = (int) box.pMin().z; int zMin = (int) box.pMin().z;

View file

@ -25,7 +25,7 @@ public class PatternStairs extends FillerPattern {
int param4 = 0; int param4 = 0;
@Override @Override
public Template getBlueprint(Box box) { public Template getTemplate(Box box) {
int xMin = 0; int xMin = 0;
int yMin = 0; int yMin = 0;
int zMin = 0; int zMin = 0;

View file

@ -46,16 +46,20 @@ public class RenderBoxProvider extends TileEntitySpecialRenderer {
if (tileentity instanceof IBoxesProvider) { if (tileentity instanceof IBoxesProvider) {
for (Box b : ((IBoxesProvider) tileentity).getBoxes()) { for (Box b : ((IBoxesProvider) tileentity).getBoxes()) {
RenderBox.doRender( if (b.isVisible) {
RenderBox.doRender(
TileEntityRendererDispatcher.instance.field_147553_e, TileEntityRendererDispatcher.instance.field_147553_e,
getTexture(b.kind), b); getTexture(b.kind), b);
}
} }
} else if (tileentity instanceof IBoxProvider) { } else if (tileentity instanceof IBoxProvider) {
Box b = ((IBoxProvider) tileentity).getBox(); Box b = ((IBoxProvider) tileentity).getBox();
RenderBox.doRender( if (b.isVisible) {
RenderBox.doRender(
TileEntityRendererDispatcher.instance.field_147553_e, TileEntityRendererDispatcher.instance.field_147553_e,
getTexture(b.kind), b); getTexture(b.kind), b);
}
} }
GL11.glPopMatrix(); GL11.glPopMatrix();

View file

@ -183,7 +183,9 @@ public class BptBuilderBlueprint extends BptBuilderBase {
} }
} }
} else { } else {
if (checkRequirements(builder, (SchematicBlock) slot.schematic)) { if (BlockUtil.isSoftBlock(world, slot.x, slot.y, slot.z)
&& checkRequirements(builder,
(SchematicBlock) slot.schematic)) {
useRequirements(builder, slot); useRequirements(builder, slot);
iterator.remove(); iterator.remove();

View file

@ -8,13 +8,6 @@
*/ */
package buildcraft.factory; package buildcraft.factory;
import buildcraft.BuildCraftCore;
import buildcraft.core.CoreConstants;
import buildcraft.core.IFramePipeConnection;
import buildcraft.core.utils.Utils;
import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly;
import java.util.List; import java.util.List;
import java.util.Random; import java.util.Random;
@ -30,24 +23,18 @@ import net.minecraft.util.MovingObjectPosition;
import net.minecraft.util.Vec3; import net.minecraft.util.Vec3;
import net.minecraft.world.IBlockAccess; import net.minecraft.world.IBlockAccess;
import net.minecraft.world.World; import net.minecraft.world.World;
import buildcraft.BuildCraftCore;
import buildcraft.core.CoreConstants;
import buildcraft.core.IFramePipeConnection;
import buildcraft.core.utils.Utils;
import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly;
public class BlockFrame extends Block implements IFramePipeConnection { public class BlockFrame extends Block implements IFramePipeConnection {
public BlockFrame() { public BlockFrame() {
super(Material.glass); super(Material.glass);
setHardness(0.5F); setHardness(0.5F);
setTickRandomly(true);
}
@Override
public void updateTick(World world, int i, int j, int k, Random random) {
if (world.isRemote)
return;
int meta = world.getBlockMetadata(i, j, k);
if (meta == 1 && random.nextInt(10) > 5) {
world.setBlockToAir(i, j, k);
}
} }
@Override @Override
@ -101,6 +88,7 @@ public class BlockFrame extends Block implements IFramePipeConnection {
return AxisAlignedBB.getBoundingBox((double) i + xMin, (double) j + yMin, (double) k + zMin, (double) i + xMax, (double) j + yMax, (double) k + zMax); return AxisAlignedBB.getBoundingBox((double) i + xMin, (double) j + yMin, (double) k + zMin, (double) i + xMax, (double) j + yMax, (double) k + zMax);
} }
@Override
@SuppressWarnings({ "all" }) @SuppressWarnings({ "all" })
// @Override (client only) // @Override (client only)
public AxisAlignedBB getSelectedBoundingBoxFromPool(World world, int i, int j, int k) { public AxisAlignedBB getSelectedBoundingBoxFromPool(World world, int i, int j, int k) {

View file

@ -19,6 +19,7 @@ import net.minecraft.item.Item;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import net.minecraft.tileentity.TileEntity; import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.IIcon; import net.minecraft.util.IIcon;
import net.minecraft.world.IBlockAccess;
import net.minecraft.world.World; import net.minecraft.world.World;
import net.minecraftforge.common.util.ForgeDirection; import net.minecraftforge.common.util.ForgeDirection;
import buildcraft.BuildCraftFactory; import buildcraft.BuildCraftFactory;
@ -208,4 +209,19 @@ public class BlockQuarry extends BlockBuildCraft {
textureTop = par1IconRegister.registerIcon("buildcraft:quarry_top"); textureTop = par1IconRegister.registerIcon("buildcraft:quarry_top");
textureFront = par1IconRegister.registerIcon("buildcraft:quarry_front"); textureFront = par1IconRegister.registerIcon("buildcraft:quarry_front");
} }
@Override
public boolean renderAsNormalBlock() {
return false;
}
@Override
public boolean isSideSolid(IBlockAccess world, int x, int y, int z, ForgeDirection side) {
return false;
}
@Override
public int getLightValue(IBlockAccess world, int x, int y, int z) {
return 1;
}
} }

View file

@ -8,7 +8,12 @@
*/ */
package buildcraft.factory; package buildcraft.factory;
import java.lang.reflect.Method;
import net.minecraft.util.IIcon;
import net.minecraft.world.World;
import buildcraft.BuildCraftFactory; import buildcraft.BuildCraftFactory;
import buildcraft.builders.RenderBuilder;
import buildcraft.core.EntityBlock; import buildcraft.core.EntityBlock;
import buildcraft.core.render.RenderVoid; import buildcraft.core.render.RenderVoid;
import buildcraft.core.render.RenderingEntityBlocks; import buildcraft.core.render.RenderingEntityBlocks;
@ -20,9 +25,6 @@ import buildcraft.factory.render.RenderRefinery;
import buildcraft.factory.render.RenderTank; import buildcraft.factory.render.RenderTank;
import cpw.mods.fml.client.registry.ClientRegistry; import cpw.mods.fml.client.registry.ClientRegistry;
import cpw.mods.fml.client.registry.RenderingRegistry; import cpw.mods.fml.client.registry.RenderingRegistry;
import java.lang.reflect.Method;
import net.minecraft.util.IIcon;
import net.minecraft.world.World;
public class FactoryProxyClient extends FactoryProxy { public class FactoryProxyClient extends FactoryProxy {
@ -48,6 +50,7 @@ public class FactoryProxyClient extends FactoryProxy {
RenderingEntityBlocks.blockByEntityRenders.put(new EntityRenderIndex(BuildCraftFactory.hopperBlock, 0), new RenderHopper()); RenderingEntityBlocks.blockByEntityRenders.put(new EntityRenderIndex(BuildCraftFactory.hopperBlock, 0), new RenderHopper());
} }
ClientRegistry.bindTileEntitySpecialRenderer(TileQuarry.class, new RenderBuilder());
} }
@Override @Override

View file

@ -1,24 +0,0 @@
/**
* Copyright (c) 2011-2014, SpaceToad and the BuildCraft Team
* http://www.mod-buildcraft.com
*
* BuildCraft is distributed under the terms of the Minecraft Mod Public
* License 1.0, or MMPL. Please check the contents of the license located in
* http://www.mod-buildcraft.com/MMPL-1.0.txt
*/
package buildcraft.factory;
import java.util.LinkedList;
import net.minecraft.item.ItemStack;
import buildcraft.api.blueprints.SchematicBlock;
import buildcraft.api.blueprints.IBuilderContext;
public class SchematicFrame extends SchematicBlock {
@Override
public void addRequirements(IBuilderContext context, LinkedList<ItemStack> requirements) {
}
}

View file

@ -8,7 +8,6 @@
*/ */
package buildcraft.factory; package buildcraft.factory;
import java.util.ArrayList;
import java.util.LinkedList; import java.util.LinkedList;
import java.util.List; import java.util.List;
import java.util.Set; import java.util.Set;
@ -27,33 +26,28 @@ import net.minecraftforge.common.ForgeChunkManager.Type;
import net.minecraftforge.common.util.ForgeDirection; import net.minecraftforge.common.util.ForgeDirection;
import buildcraft.BuildCraftCore; import buildcraft.BuildCraftCore;
import buildcraft.BuildCraftFactory; import buildcraft.BuildCraftFactory;
import buildcraft.api.blueprints.SchematicRegistry;
import buildcraft.api.core.IAreaProvider; import buildcraft.api.core.IAreaProvider;
import buildcraft.api.filler.FillerManager;
import buildcraft.api.gates.IAction; import buildcraft.api.gates.IAction;
import buildcraft.api.power.IPowerReceptor;
import buildcraft.api.power.PowerHandler;
import buildcraft.api.power.PowerHandler.PowerReceiver;
import buildcraft.builders.BuildingItem;
import buildcraft.builders.TileAbstractBuilder; import buildcraft.builders.TileAbstractBuilder;
import buildcraft.core.Box; import buildcraft.core.Box;
import buildcraft.core.Box.Kind;
import buildcraft.core.CoreConstants; import buildcraft.core.CoreConstants;
import buildcraft.core.DefaultAreaProvider; import buildcraft.core.DefaultAreaProvider;
import buildcraft.core.IMachine; import buildcraft.core.IMachine;
import buildcraft.core.LaserData;
import buildcraft.core.blueprints.Blueprint; import buildcraft.core.blueprints.Blueprint;
import buildcraft.core.blueprints.BptBuilderBase;
import buildcraft.core.blueprints.BptBuilderBlueprint; import buildcraft.core.blueprints.BptBuilderBlueprint;
import buildcraft.core.blueprints.BuildingSlot;
import buildcraft.core.network.NetworkData; import buildcraft.core.network.NetworkData;
import buildcraft.core.network.PacketUpdate; import buildcraft.core.network.PacketUpdate;
import buildcraft.core.proxy.CoreProxy; import buildcraft.core.proxy.CoreProxy;
import buildcraft.core.robots.EntityRobotBuilder;
import buildcraft.core.utils.BlockUtil; import buildcraft.core.utils.BlockUtil;
import buildcraft.core.utils.Utils; import buildcraft.core.utils.Utils;
import com.google.common.collect.Lists; import com.google.common.collect.Lists;
import com.google.common.collect.Sets; import com.google.common.collect.Sets;
public class TileQuarry extends TileAbstractBuilder implements IMachine, IPowerReceptor { public class TileQuarry extends TileAbstractBuilder implements IMachine {
public @NetworkData public @NetworkData
Box box = new Box(); Box box = new Box();
@ -65,30 +59,17 @@ public class TileQuarry extends TileAbstractBuilder implements IMachine, IPowerR
double headPosX, headPosY, headPosZ; double headPosX, headPosY, headPosZ;
public @NetworkData public @NetworkData
double speed = 0.03; double speed = 0.03;
public @NetworkData
boolean builderDone = false; private BptBuilderBase builder;
public EntityRobotBuilder builder;
private BptBuilderBlueprint blueprintBuilder;
public EntityMechanicalArm arm; public EntityMechanicalArm arm;
public PowerHandler powerHandler;
boolean isDigging = false; boolean isDigging = false;
public static final int MAX_ENERGY = 15000;
private static final PowerHandler.PerditionCalculator PERDITION = new PowerHandler.PerditionCalculator(2 * BuildCraftFactory.miningMultiplier);
public TileQuarry() { public TileQuarry () {
powerHandler = new PowerHandler(this, PowerHandler.Type.MACHINE); box.kind = Kind.STRIPES;
initPowerProvider();
}
private void initPowerProvider() {
float mj = 25 * BuildCraftFactory.miningMultiplier;
powerHandler.configure(50 * BuildCraftFactory.miningMultiplier, 100 * BuildCraftFactory.miningMultiplier, mj, MAX_ENERGY * BuildCraftFactory.miningMultiplier);
powerHandler.setPerdition(PERDITION);
} }
public void createUtilsIfNeeded() { public void createUtilsIfNeeded() {
if (blueprintBuilder == null) { if (builder == null) {
if (!box.isInitialized()) { if (!box.isInitialized()) {
setBoundaries(loadDefaultBoundaries); setBoundaries(loadDefaultBoundaries);
} }
@ -96,7 +77,7 @@ public class TileQuarry extends TileAbstractBuilder implements IMachine, IPowerR
initializeBlueprintBuilder(); initializeBlueprintBuilder();
} }
if (builderDone) { if (builder != null && builder.isDone(this)) {
box.isVisible = false; box.isVisible = false;
if (arm == null) { if (arm == null) {
@ -126,9 +107,8 @@ public class TileQuarry extends TileAbstractBuilder implements IMachine, IPowerR
public EntityPlayer placedBy; public EntityPlayer placedBy;
private void createArm() { private void createArm() {
worldObj.spawnEntityInWorld(new EntityMechanicalArm(worldObj, box.xMin + CoreConstants.PIPE_MAX_POS, yCoord + builder.blueprint.sizeY - 1
worldObj.spawnEntityInWorld(new EntityMechanicalArm(worldObj, box.xMin + CoreConstants.PIPE_MAX_POS, yCoord + blueprintBuilder.blueprint.sizeY - 1 + CoreConstants.PIPE_MIN_POS, box.zMin + CoreConstants.PIPE_MAX_POS, builder.blueprint.sizeX - 2 + CoreConstants.PIPE_MIN_POS * 2, builder.blueprint.sizeZ
+ CoreConstants.PIPE_MIN_POS, box.zMin + CoreConstants.PIPE_MAX_POS, blueprintBuilder.blueprint.sizeX - 2 + CoreConstants.PIPE_MIN_POS * 2, blueprintBuilder.blueprint.sizeZ
- 2 + CoreConstants.PIPE_MIN_POS * 2, this)); - 2 + CoreConstants.PIPE_MIN_POS * 2, this));
} }
@ -141,25 +121,26 @@ public class TileQuarry extends TileAbstractBuilder implements IMachine, IPowerR
public void updateEntity() { public void updateEntity() {
super.updateEntity(); super.updateEntity();
if (!isAlive && !worldObj.isRemote) { if (worldObj.isRemote) {
return; return;
} }
if (isAlive && worldObj.isRemote) { if (!isAlive) {
return; return;
} }
if (inProcess) { if (inProcess) {
double energyToUse = 2 + powerHandler.getEnergyStored() / 500; double energyToUse = 2 + mjStored / 500;
double energy = powerHandler.useEnergy(energyToUse, energyToUse, true); if (mjStored > energyToUse) {
mjStored -= energyToUse;
if (energy > 0) { moveHead(0.1 + energyToUse / 200F);
moveHead(0.1 + energy / 200F);
} }
} }
if (!worldObj.isRemote && inProcess) { if (!worldObj.isRemote && inProcess) {
// TODO: Don't send an update at each tick!!!! At most once every
// 20 ~ 25 ticks
sendNetworkUpdate(); sendNetworkUpdate();
} }
@ -169,66 +150,22 @@ public class TileQuarry extends TileAbstractBuilder implements IMachine, IPowerR
createUtilsIfNeeded(); createUtilsIfNeeded();
if (blueprintBuilder != null) { if (builder != null) {
//builderDone = !blueprintIterator.hasNext(); if (!builder.isDone(this)) {
//if (!builderDone) { builder.buildNextSlot(worldObj, this, xCoord, yCoord, zCoord);
// buildFrame(); } else {
// return; dig();
//} else if (builder != null && builder.done()) { }
// killBuilder();
//}
} }
if (builder == null) {
dig();
}
}
private void killBuilder() {
builder.setDead();
builder = null;
}
@Override
public void doWork(PowerHandler workProvider) {
}
protected void buildFrame() {
BuildingSlot schematic = blueprintBuilder.getNextBlock(getWorld(), this);
if (schematic == null) {
return;
}
float mj = 25 * BuildCraftFactory.miningMultiplier;
powerHandler.configure(50 * BuildCraftFactory.miningMultiplier, 100 * BuildCraftFactory.miningMultiplier, mj, MAX_ENERGY * BuildCraftFactory.miningMultiplier);
if (powerHandler.useEnergy(mj, mj, true) != mj) {
return;
}
//if (builder == null) {
// builder = new EntityRobotBuilder(worldObj, box);
// worldObj.spawnEntityInWorld(builder);
//}
//if (builder.readyToBuild()) {
// while (blueprintIterator.hasNext()) {
// if (builder.scheduleContruction(blueprintIterator.next())) {
// powerHandler.useEnergy(0, 25, true);
// break;
// }
// }
//}
} }
protected void dig() { protected void dig() {
powerHandler.configure(100 * BuildCraftFactory.miningMultiplier, 500 * BuildCraftFactory.miningMultiplier, BuildCraftFactory.MINING_MJ_COST_PER_BLOCK, MAX_ENERGY * BuildCraftFactory.miningMultiplier);
float mj = BuildCraftFactory.MINING_MJ_COST_PER_BLOCK * BuildCraftFactory.miningMultiplier; float mj = BuildCraftFactory.MINING_MJ_COST_PER_BLOCK * BuildCraftFactory.miningMultiplier;
if (powerHandler.useEnergy(mj, mj, true) != mj) { if (mjStored < mj) {
return; return;
} else {
mjStored -= mj;
} }
if (!findTarget(true)) { if (!findTarget(true)) {
@ -300,18 +237,18 @@ public class TileQuarry extends TileAbstractBuilder implements IMachine, IPowerR
private void createColumnVisitList() { private void createColumnVisitList() {
visitList.clear(); visitList.clear();
Integer[][] columnHeights = new Integer[blueprintBuilder.blueprint.sizeX - 2][blueprintBuilder.blueprint.sizeZ - 2]; Integer[][] columnHeights = new Integer[builder.blueprint.sizeX - 2][builder.blueprint.sizeZ - 2];
boolean[][] blockedColumns = new boolean[blueprintBuilder.blueprint.sizeX - 2][blueprintBuilder.blueprint.sizeZ - 2]; boolean[][] blockedColumns = new boolean[builder.blueprint.sizeX - 2][builder.blueprint.sizeZ - 2];
for (int searchY = yCoord + 3; searchY >= 0; --searchY) { for (int searchY = yCoord + 3; searchY >= 0; --searchY) {
int startX, endX, incX; int startX, endX, incX;
if (searchY % 2 == 0) { if (searchY % 2 == 0) {
startX = 0; startX = 0;
endX = blueprintBuilder.blueprint.sizeX - 2; endX = builder.blueprint.sizeX - 2;
incX = 1; incX = 1;
} else { } else {
startX = blueprintBuilder.blueprint.sizeX - 3; startX = builder.blueprint.sizeX - 3;
endX = -1; endX = -1;
incX = -1; incX = -1;
} }
@ -321,10 +258,10 @@ public class TileQuarry extends TileAbstractBuilder implements IMachine, IPowerR
if (searchX % 2 == searchY % 2) { if (searchX % 2 == searchY % 2) {
startZ = 0; startZ = 0;
endZ = blueprintBuilder.blueprint.sizeZ - 2; endZ = builder.blueprint.sizeZ - 2;
incZ = 1; incZ = 1;
} else { } else {
startZ = blueprintBuilder.blueprint.sizeZ - 3; startZ = builder.blueprint.sizeZ - 3;
endZ = -1; endZ = -1;
incZ = -1; incZ = -1;
} }
@ -356,7 +293,7 @@ public class TileQuarry extends TileAbstractBuilder implements IMachine, IPowerR
// Stop at two planes - generally any obstructions will have been found and will force a recompute prior to this // Stop at two planes - generally any obstructions will have been found and will force a recompute prior to this
if (visitList.size() > blueprintBuilder.blueprint.sizeZ * blueprintBuilder.blueprint.sizeX * 2) { if (visitList.size() > builder.blueprint.sizeZ * builder.blueprint.sizeX * 2) {
return; return;
} }
} }
@ -369,8 +306,7 @@ public class TileQuarry extends TileAbstractBuilder implements IMachine, IPowerR
public void readFromNBT(NBTTagCompound nbttagcompound) { public void readFromNBT(NBTTagCompound nbttagcompound) {
super.readFromNBT(nbttagcompound); super.readFromNBT(nbttagcompound);
powerHandler.readFromNBT(nbttagcompound);
initPowerProvider();
if (nbttagcompound.hasKey("box")) { if (nbttagcompound.hasKey("box")) {
box.initialize(nbttagcompound.getCompoundTag("box")); box.initialize(nbttagcompound.getCompoundTag("box"));
@ -407,8 +343,6 @@ public class TileQuarry extends TileAbstractBuilder implements IMachine, IPowerR
public void writeToNBT(NBTTagCompound nbttagcompound) { public void writeToNBT(NBTTagCompound nbttagcompound) {
super.writeToNBT(nbttagcompound); super.writeToNBT(nbttagcompound);
powerHandler.writeToNBT(nbttagcompound);
nbttagcompound.setInteger("targetX", targetX); nbttagcompound.setInteger("targetX", targetX);
nbttagcompound.setInteger("targetY", targetY); nbttagcompound.setInteger("targetY", targetY);
nbttagcompound.setInteger("targetZ", targetZ); nbttagcompound.setInteger("targetZ", targetZ);
@ -534,10 +468,6 @@ public class TileQuarry extends TileAbstractBuilder implements IMachine, IPowerR
arm.setDead(); arm.setDead();
} }
if (builder != null) {
builder.setDead();
}
arm = null; arm = null;
} }
@ -639,28 +569,10 @@ public class TileQuarry extends TileAbstractBuilder implements IMachine, IPowerR
} }
private void initializeBlueprintBuilder() { private void initializeBlueprintBuilder() {
Blueprint blueprint = new Blueprint (box.sizeX(), box.sizeY(), box.sizeZ()); Blueprint bpt = FillerManager.registry.getPattern("buildcraft:frame")
.getBlueprint(box, BuildCraftFactory.frameBlock);
for (int it = 0; it < 2; it++) { builder = new BptBuilderBlueprint(bpt, worldObj, box.xMin, yCoord, box.zMin);
for (int i = 0; i < blueprint.sizeX; ++i) {
blueprint.contents [i][it * (box.sizeY() - 1)][0] = SchematicRegistry.newSchematicBlock(BuildCraftFactory.frameBlock);
blueprint.contents [i][it * (box.sizeY() - 1)][blueprint.sizeZ - 1] = SchematicRegistry.newSchematicBlock(BuildCraftFactory.frameBlock);
}
for (int k = 0; k < blueprint.sizeZ; ++k) {
blueprint.contents [0][it * (box.sizeY() - 1)][k] = SchematicRegistry.newSchematicBlock(BuildCraftFactory.frameBlock);
blueprint.contents [blueprint.sizeX - 1][it * (box.sizeY() - 1)][k] = SchematicRegistry.newSchematicBlock(BuildCraftFactory.frameBlock);
}
}
for (int h = 1; h < box.sizeY(); ++h) {
blueprint.contents [0][h][0] = SchematicRegistry.newSchematicBlock(BuildCraftFactory.frameBlock);
blueprint.contents [0][h][blueprint.sizeZ - 1] = SchematicRegistry.newSchematicBlock(BuildCraftFactory.frameBlock);
blueprint.contents [blueprint.sizeX - 1][h][0] = SchematicRegistry.newSchematicBlock(BuildCraftFactory.frameBlock);
blueprint.contents [blueprint.sizeX - 1][h][blueprint.sizeZ - 1] = SchematicRegistry.newSchematicBlock(BuildCraftFactory.frameBlock);
}
blueprintBuilder = new BptBuilderBlueprint(blueprint, worldObj, box.xMin, yCoord, box.zMin); //ForgeDirection.NORTH
} }
@Override @Override
@ -693,16 +605,10 @@ public class TileQuarry extends TileAbstractBuilder implements IMachine, IPowerR
} }
public void reinitalize() { public void reinitalize() {
builderDone = false;
initializeBlueprintBuilder(); initializeBlueprintBuilder();
isDigging = true; isDigging = true;
} }
@Override
public PowerReceiver getPowerReceiver(ForgeDirection side) {
return powerHandler.getPowerReceiver();
}
@Override @Override
public boolean manageFluids() { public boolean manageFluids() {
return false; return false;
@ -715,17 +621,17 @@ public class TileQuarry extends TileAbstractBuilder implements IMachine, IPowerR
@Override @Override
public int getSizeInventory() { public int getSizeInventory() {
return 0; return 1;
} }
@Override @Override
public ItemStack getStackInSlot(int i) { public ItemStack getStackInSlot(int i) {
return null; return new ItemStack(BuildCraftFactory.frameBlock);
} }
@Override @Override
public ItemStack decrStackSize(int i, int j) { public ItemStack decrStackSize(int i, int j) {
return null; return new ItemStack(BuildCraftFactory.frameBlock, j);
} }
@Override @Override
@ -882,20 +788,12 @@ public class TileQuarry extends TileAbstractBuilder implements IMachine, IPowerR
} }
@Override @Override
public void addBuildingItem(BuildingItem item) { public AxisAlignedBB getRenderBoundingBox() {
// TODO Auto-generated method stub return new Box (this).extendToEncompass(box).expand(50).getBoundingBox();
} }
@Override @Override
public ArrayList<BuildingItem> getBuilders() { public Box getBox() {
// TODO Auto-generated method stub return box;
return null;
}
@Override
public LinkedList<LaserData> getPathLaser() {
// TODO Auto-generated method stub
return null;
} }
} }