Recipe Stuff

This commit is contained in:
DarkGuardsman 2013-11-02 08:10:51 -04:00
parent 8fa92f8697
commit da96375b8c
9 changed files with 104 additions and 21 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.2 KiB

View file

Before

Width:  |  Height:  |  Size: 271 B

After

Width:  |  Height:  |  Size: 271 B

View file

@ -0,0 +1,41 @@
package dark.core.client;
import net.minecraft.entity.Entity;
import net.minecraft.util.Vec3;
import net.minecraft.world.World;
import universalelectricity.core.vector.Vector3;
public class Effects
{
public static void drawParticleStreamTo(World world, Vector3 start, Vector3 end)
{
}
public static void drawParticleStreamTo(Entity shooter, World world, double x, double y, double z)
{
Vec3 direction = shooter.getLookVec().normalize();
double scale = 1.0;
double xoffset = 1.3f;
double yoffset = -.2;
double zoffset = 0.3f;
Vec3 horzdir = direction.normalize();
horzdir.yCoord = 0;
horzdir = horzdir.normalize();
double cx = shooter.posX + direction.xCoord * xoffset - direction.yCoord * horzdir.xCoord * yoffset - horzdir.zCoord * zoffset;
double cy = shooter.posY + shooter.getEyeHeight() + direction.yCoord * xoffset + (1 - Math.abs(direction.yCoord)) * yoffset;
double cz = shooter.posZ + direction.zCoord * xoffset - direction.yCoord * horzdir.zCoord * yoffset + horzdir.xCoord * zoffset;
double dx = x - cx;
double dy = y - cy;
double dz = z - cz;
double ratio = Math.sqrt(dx * dx + dy * dy + dz * dz);
while (Math.abs(cx - x) > Math.abs(dx / ratio))
{
world.spawnParticle("townaura", cx, cy, cz, 0.0D, 0.0D, 0.0D);
cx += dx * 0.1 / ratio;
cy += dy * 0.1 / ratio;
cz += dz * 0.1 / ratio;
}
}
}

View file

@ -44,7 +44,7 @@ public class CoreRecipeLoader extends RecipeLoader
public static ItemStack unfinishedTank; public static ItemStack unfinishedTank;
public static Item itemGlowingSand; public static Item itemGlowingSand;
public static Item itemDiggingTool; public static Item itemDiggingTool;
public static boolean debugOreItems = true; public static boolean debugOreItems = false;
@Override @Override
public void loadRecipes() public void loadRecipes()
@ -94,12 +94,21 @@ public class CoreRecipeLoader extends RecipeLoader
// seal // seal
GameRegistry.addRecipe(this.setStackSize(leatherSeal, 16), new Object[] { "LL", "LL", 'L', Item.leather }); GameRegistry.addRecipe(this.setStackSize(leatherSeal, 16), new Object[] { "LL", "LL", 'L', Item.leather });
// slime steal // slime steal
new RecipeGrid(this.setStackSize(slimeSeal, 4)).setRowOne(null, leatherSeal, null).setRowTwo(leatherSeal, Item.slimeBall, leatherSeal).setRowThree(null, leatherSeal, null).RegisterRecipe(); GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(itemParts, 4, Parts.GasSeal.ordinal()), " # ", "#S#", " # ", '#', "leatherSeal", 'S', Item.slimeBall));
// part valve // part valve
GameRegistry.addRecipe(new ShapedOreRecipe(valvePart, new Object[] { "PLP", 'P', "ironPipe", 'L', Block.lever })); GameRegistry.addRecipe(new ShapedOreRecipe(valvePart, new Object[] { "PLP", 'P', "ironPipe", 'L', Block.lever }));
//Basic Circuit
GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(itemParts, 1, Parts.CircuitBasic.ordinal()), "!#!", "#@#", "!#!", '@', "plateCopper", '#', Block.glass, '!', "copperWire"));
//Advanced Circuit
GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(itemParts, 1, Parts.CircuitAdvanced.ordinal()), "!#!", "#@#", "!#!", '@', "plateCopper", '#', Item.redstone, '!', "copperWire"));
//Elite Circuit
GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(itemParts, 1, Parts.CircuitElite.ordinal()), "!#!", "#@#", "!#!", '@', "plateGold", '#', Item.redstone, '!', "copperWire"));
// unfinished tank // unfinished tank
new RecipeGrid(unfinishedTank).setRowOne(null, Item.ingotIron, null).setRowTwo(Item.ingotIron, null, Item.ingotIron).setRowThree(null, Item.ingotIron, null).RegisterRecipe(); GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(itemParts, 1, Parts.Tank.ordinal()), " # ", "# #", " # ", '#', bronze));
new RecipeGrid(unfinishedTank).setRowOne(null, bronze, null).setRowTwo(bronze, null, bronze).setRowThree(null, bronze, null).RegisterRecipe(); GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(itemParts, 1, Parts.Tank.ordinal()), " # ", "# #", " # ", '#', steel));
//Motor
GameRegistry.addRecipe(new ShapedOreRecipe(new ItemStack(itemParts, 1, Parts.Motor.ordinal()), new Object[] { "@!@", "!#!", "@!@", '!', "ingotSteel", '#', Item.ingotIron, '@', "copperWire" }));
} }
if (itemMetals instanceof ItemOreDirv) if (itemMetals instanceof ItemOreDirv)

View file

@ -53,6 +53,7 @@ import dark.core.common.items.ItemOreDirv;
import dark.core.common.items.ItemParts; import dark.core.common.items.ItemParts;
import dark.core.common.items.ItemReadoutTools; import dark.core.common.items.ItemReadoutTools;
import dark.core.common.items.ItemWrench; import dark.core.common.items.ItemWrench;
import dark.core.common.items.ItemParts.Parts;
import dark.core.common.machines.BlockBasicMachine; import dark.core.common.machines.BlockBasicMachine;
import dark.core.common.machines.BlockSolarPanel; import dark.core.common.machines.BlockSolarPanel;
import dark.core.common.transmit.BlockWire; import dark.core.common.transmit.BlockWire;
@ -142,7 +143,14 @@ public class DarkMain extends ModPrefab
} }
} }
} }
if (CoreRecipeLoader.itemMetals instanceof ItemOreDirv) if (CoreRecipeLoader.itemParts instanceof ItemParts)
{
for (Parts part : Parts.values())
{
OreDictionary.registerOre(part.name, new ItemStack(CoreRecipeLoader.itemParts, 1, part.ordinal()));
}
}
if (CoreRecipeLoader.itemMetals != null)
{ {
//Ore material recipe loop //Ore material recipe loop
for (EnumMaterial mat : EnumMaterial.values()) for (EnumMaterial mat : EnumMaterial.values())

View file

@ -83,11 +83,16 @@ public class ItemParts extends ItemBasic implements IExtraItemInfo
public static enum Parts public static enum Parts
{ {
Seal("LeatherSeal"), Seal("leatherSeal"),
GasSeal("GasSeal"), GasSeal("gasSeal"),
Tank("UnfinishedTank"), Tank("unfinishedTank"),
Valve("ValvePart"), Valve("valvePart"),
MiningIcon("miningIcon", false); MiningIcon("miningIcon", false),
CircuitBasic("circuitBasic"),
CircuitAdvanced("circuitAdvanced"),
CircuitElite("circuitElite"),
Motor("motor"),
IC("IC_Chip");
public String name; public String name;
public Icon icon; public Icon icon;

View file

@ -65,7 +65,7 @@ public abstract class ModPrefab
* has been made */ * has been made */
public static int getNextItemId() public static int getNextItemId()
{ {
int id = BLOCK_ID_PRE; int id = ITEM_ID_PREFIX;
while (id > 255 && id < (Item.itemsList.length - 1)) while (id > 255 && id < (Item.itemsList.length - 1))
{ {
@ -76,7 +76,7 @@ public abstract class ModPrefab
} }
id++; id++;
} }
BLOCK_ID_PRE = id + 1; ITEM_ID_PREFIX = id + 1;
return id; return id;
} }

View file

@ -28,7 +28,7 @@ import dark.core.registration.ModObjectRegistry.BlockBuildData;
/** Basic TileEntity Container class designed to be used by generic machines. It is suggested that /** Basic TileEntity Container class designed to be used by generic machines. It is suggested that
* each mod using this create there own basic block extending this to reduce need to use build data * each mod using this create there own basic block extending this to reduce need to use build data
* per block. * per block.
* *
* @author Darkguardsman */ * @author Darkguardsman */
public abstract class BlockMachine extends BlockTile implements IExtraBlockInfo public abstract class BlockMachine extends BlockTile implements IExtraBlockInfo
{ {
@ -104,6 +104,24 @@ public abstract class BlockMachine extends BlockTile implements IExtraBlockInfo
} }
} }
@Override
public void onNeighborTileChange(World world, int x, int y, int z, int tileX, int tileY, int tileZ)
{
super.onNeighborTileChange(world, x, y, z, tileX, tileY, tileZ);
TileEntity tileEntity = world.getBlockTileEntity(x, y, z);
if (tileEntity instanceof INetworkPart)
{
((INetworkPart) tileEntity).refresh();
}
}
public void breakBlock(World world, int x, int y, int z, int par5, int par6)
{
super.breakBlock(world, x, y, z, par5, par6);
world.notifyBlockChange(x, y, z, world.getBlockId(x, y, z));
}
@Override @Override
public TileEntity createTileEntity(World world, int metadata) public TileEntity createTileEntity(World world, int metadata)
{ {

View file

@ -32,13 +32,13 @@ public abstract class NetworkTileEntities
/** Creates a new instance of this network to be used to merge or split networks while still /** Creates a new instance of this network to be used to merge or split networks while still
* maintaining each class that extends the base network class * maintaining each class that extends the base network class
* *
* @return - new network instance using the current networks properties */ * @return - new network instance using the current networks properties */
public abstract NetworkTileEntities newInstance(); public abstract NetworkTileEntities newInstance();
/** Adds a TileEntity to the network. extends this to catch non-network parts and add them to /** Adds a TileEntity to the network. extends this to catch non-network parts and add them to
* other tile lists * other tile lists
* *
* @param tileEntity - tileEntity instance * @param tileEntity - tileEntity instance
* @param member - add to network member list * @param member - add to network member list
* @return */ * @return */
@ -127,7 +127,7 @@ public abstract class NetworkTileEntities
/** Combines two networks together into one. Calls to preMerge and doMerge instead of doing the /** Combines two networks together into one. Calls to preMerge and doMerge instead of doing the
* merge process itself * merge process itself
* *
* @param network * @param network
* @param mergePoint */ * @param mergePoint */
public void merge(NetworkTileEntities network, INetworkPart mergePoint) public void merge(NetworkTileEntities network, INetworkPart mergePoint)
@ -143,17 +143,17 @@ public abstract class NetworkTileEntities
/** Processing that needs too be done before the network merges. Use this to do final network /** Processing that needs too be done before the network merges. Use this to do final network
* merge calculations and to cause network merge failure * merge calculations and to cause network merge failure
* *
* @param network the network that is to merge with this one * @param network the network that is to merge with this one
* @param part the part at which started the network merge. Use this to cause damage if two * @param part the part at which started the network merge. Use this to cause damage if two
* networks merge with real world style failures * networks merge with real world style failures
* *
* @return false if the merge needs to be canceled. * @return false if the merge needs to be canceled.
* *
* Cases in which the network should fail to merge are were the two networks merge with error. * Cases in which the network should fail to merge are were the two networks merge with error.
* Or, in the case of pipes the two networks merge and the merge point was destroyed by * Or, in the case of pipes the two networks merge and the merge point was destroyed by
* combination of liquids. * combination of liquids.
* *
* Ex Lava and water */ * Ex Lava and water */
public boolean preMergeProcessing(NetworkTileEntities network, INetworkPart part) public boolean preMergeProcessing(NetworkTileEntities network, INetworkPart part)
{ {
@ -235,6 +235,8 @@ public abstract class NetworkTileEntities
} }
} }
} }
this.cleanUpMembers();
} }
} }
@ -245,7 +247,7 @@ public abstract class NetworkTileEntities
} }
/** invalidates/remove a tile from the networks that surround and connect to it /** invalidates/remove a tile from the networks that surround and connect to it
* *
* @param tileEntity - tile */ * @param tileEntity - tile */
public static void invalidate(TileEntity tileEntity) public static void invalidate(TileEntity tileEntity)
{ {