add bad rendering creative controller

This commit is contained in:
Raoul Van den Berge
2015-12-29 12:56:28 +01:00
parent 2237784d5f
commit a8e754772a
10 changed files with 129 additions and 12 deletions

View File

@@ -1,10 +1,14 @@
package storagecraft.block; package storagecraft.block;
import net.minecraft.block.properties.IProperty; import net.minecraft.block.properties.IProperty;
import net.minecraft.block.properties.PropertyEnum;
import net.minecraft.block.properties.PropertyInteger; import net.minecraft.block.properties.PropertyInteger;
import net.minecraft.block.state.BlockState; import net.minecraft.block.state.BlockState;
import net.minecraft.block.state.IBlockState; import net.minecraft.block.state.IBlockState;
import net.minecraft.creativetab.CreativeTabs;
import net.minecraft.entity.player.EntityPlayer; import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.item.Item;
import net.minecraft.item.ItemStack;
import net.minecraft.tileentity.TileEntity; import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.BlockPos; import net.minecraft.util.BlockPos;
import net.minecraft.util.EnumFacing; import net.minecraft.util.EnumFacing;
@@ -14,8 +18,11 @@ import storagecraft.StorageCraft;
import storagecraft.StorageCraftGUI; import storagecraft.StorageCraftGUI;
import storagecraft.tile.TileController; import storagecraft.tile.TileController;
import java.util.List;
public class BlockController extends BlockBase public class BlockController extends BlockBase
{ {
public static final PropertyEnum TYPE = PropertyEnum.create("type", EnumControllerType.class);
public static final PropertyInteger ENERGY = PropertyInteger.create("energy", 0, 8); public static final PropertyInteger ENERGY = PropertyInteger.create("energy", 0, 8);
public BlockController() public BlockController()
@@ -23,16 +30,38 @@ public class BlockController extends BlockBase
super("controller"); super("controller");
} }
@Override
public void getSubBlocks(Item item, CreativeTabs tab, List subItems)
{
for (int i = 0; i <= 1; i++)
{
subItems.add(new ItemStack(item, 1, i));
}
}
@Override @Override
protected BlockState createBlockState() protected BlockState createBlockState()
{ {
return new BlockState(this, new IProperty[] return new BlockState(this, new IProperty[]
{ {
DIRECTION, DIRECTION,
TYPE,
ENERGY ENERGY
}); });
} }
@Override
public IBlockState getStateFromMeta(int meta)
{
return getDefaultState().withProperty(TYPE, meta == 0 ? EnumControllerType.NORMAL : EnumControllerType.CREATIVE);
}
@Override
public int getMetaFromState(IBlockState state)
{
return state.getValue(TYPE) == EnumControllerType.NORMAL ? 0 : 1;
}
@Override @Override
public IBlockState getActualState(IBlockState state, IBlockAccess world, BlockPos pos) public IBlockState getActualState(IBlockState state, IBlockAccess world, BlockPos pos)
{ {

View File

@@ -0,0 +1,35 @@
package storagecraft.block;
import net.minecraft.util.IStringSerializable;
public enum EnumControllerType implements IStringSerializable
{
NORMAL(0, "normal"),
CREATIVE(1, "creative");
private int id;
private String name;
EnumControllerType(int id, String name)
{
this.id = id;
this.name = name;
}
@Override
public String getName()
{
return name;
}
public int getId()
{
return id;
}
@Override
public String toString()
{
return name;
}
}

View File

@@ -46,7 +46,7 @@ public class GuiController extends GuiBase
@Override @Override
public void drawForeground(int mouseX, int mouseY) public void drawForeground(int mouseX, int mouseY)
{ {
drawString(7, 7, t("gui.storagecraft:controller")); drawString(7, 7, t("gui.storagecraft:controller." + controller.getType().getId()));
drawString(7, 87, t("container.inventory")); drawString(7, 87, t("container.inventory"));
drawString(31, 20, t("misc.storagecraft:energy_usage", controller.getEnergyUsage())); drawString(31, 20, t("misc.storagecraft:energy_usage", controller.getEnergyUsage()));

View File

@@ -0,0 +1,11 @@
package storagecraft.item;
import net.minecraft.block.Block;
public class ItemBlockController extends ItemBlockBase
{
public ItemBlockController(Block block)
{
super(block);
}
}

View File

@@ -11,6 +11,8 @@ import net.minecraftforge.fml.common.event.FMLInitializationEvent;
import net.minecraftforge.fml.common.event.FMLPreInitializationEvent; import net.minecraftforge.fml.common.event.FMLPreInitializationEvent;
import storagecraft.StorageCraftBlocks; import storagecraft.StorageCraftBlocks;
import storagecraft.StorageCraftItems; import storagecraft.StorageCraftItems;
import storagecraft.block.BlockController;
import storagecraft.block.EnumControllerType;
import storagecraft.block.EnumGridType; import storagecraft.block.EnumGridType;
import storagecraft.item.ItemCore; import storagecraft.item.ItemCore;
import storagecraft.item.ItemProcessor; import storagecraft.item.ItemProcessor;
@@ -106,6 +108,7 @@ public class ClientProxy extends CommonProxy
mesher.register(Item.getItemFromBlock(StorageCraftBlocks.IMPORTER), 0, new ModelResourceLocation("storagecraft:importer", "inventory")); mesher.register(Item.getItemFromBlock(StorageCraftBlocks.IMPORTER), 0, new ModelResourceLocation("storagecraft:importer", "inventory"));
mesher.register(Item.getItemFromBlock(StorageCraftBlocks.EXTERNAL_STORAGE), 0, new ModelResourceLocation("storagecraft:external_storage", "inventory")); mesher.register(Item.getItemFromBlock(StorageCraftBlocks.EXTERNAL_STORAGE), 0, new ModelResourceLocation("storagecraft:external_storage", "inventory"));
mesher.register(Item.getItemFromBlock(StorageCraftBlocks.DRIVE), 0, new ModelResourceLocation("storagecraft:drive", "inventory")); mesher.register(Item.getItemFromBlock(StorageCraftBlocks.DRIVE), 0, new ModelResourceLocation("storagecraft:drive", "inventory"));
mesher.register(Item.getItemFromBlock(StorageCraftBlocks.CONTROLLER), 0, new ModelResourceLocation("storagecraft:controller", "inventory")); mesher.register(Item.getItemFromBlock(StorageCraftBlocks.CONTROLLER), EnumControllerType.NORMAL.getId(), new ModelResourceLocation("storagecraft:controller", "inventory"));
mesher.register(Item.getItemFromBlock(StorageCraftBlocks.CONTROLLER), EnumControllerType.CREATIVE.getId(), new ModelResourceLocation("storagecraft:controller", "inventory"));
} }
} }

View File

@@ -12,11 +12,13 @@ import net.minecraftforge.fml.relauncher.Side;
import storagecraft.StorageCraft; import storagecraft.StorageCraft;
import storagecraft.StorageCraftBlocks; import storagecraft.StorageCraftBlocks;
import storagecraft.StorageCraftItems; import storagecraft.StorageCraftItems;
import storagecraft.block.EnumGridType;
import storagecraft.gui.GuiHandler; import storagecraft.gui.GuiHandler;
import storagecraft.item.*; import storagecraft.item.*;
import storagecraft.network.*; import storagecraft.network.*;
import storagecraft.tile.*; import storagecraft.tile.*;
import storagecraft.tile.solderer.*; import storagecraft.tile.solderer.*;
import storagecraft.block.EnumControllerType;
public class CommonProxy public class CommonProxy
{ {
@@ -48,7 +50,7 @@ public class CommonProxy
GameRegistry.registerTileEntity(TileDestructor.class, "destructor"); GameRegistry.registerTileEntity(TileDestructor.class, "destructor");
GameRegistry.registerTileEntity(TileConstructor.class, "constructor"); GameRegistry.registerTileEntity(TileConstructor.class, "constructor");
GameRegistry.registerBlock(StorageCraftBlocks.CONTROLLER, "controller"); GameRegistry.registerBlock(StorageCraftBlocks.CONTROLLER, ItemBlockController.class, "controller");
GameRegistry.registerBlock(StorageCraftBlocks.CABLE, ItemBlockCable.class, "cable"); GameRegistry.registerBlock(StorageCraftBlocks.CABLE, ItemBlockCable.class, "cable");
GameRegistry.registerBlock(StorageCraftBlocks.GRID, ItemBlockGrid.class, "grid"); GameRegistry.registerBlock(StorageCraftBlocks.GRID, ItemBlockGrid.class, "grid");
GameRegistry.registerBlock(StorageCraftBlocks.DRIVE, "drive"); GameRegistry.registerBlock(StorageCraftBlocks.DRIVE, "drive");
@@ -115,7 +117,7 @@ public class CommonProxy
); );
// Controller // Controller
GameRegistry.addRecipe(new ItemStack(StorageCraftBlocks.CONTROLLER), GameRegistry.addRecipe(new ItemStack(StorageCraftBlocks.CONTROLLER, 1, EnumControllerType.NORMAL.getId()),
"EDE", "EDE",
"SRS", "SRS",
"ESE", "ESE",
@@ -154,7 +156,7 @@ public class CommonProxy
); );
// Grid // Grid
GameRegistry.addRecipe(new ItemStack(StorageCraftBlocks.GRID, 1, 0), GameRegistry.addRecipe(new ItemStack(StorageCraftBlocks.GRID, 1, EnumGridType.NORMAL.getId()),
"ECE", "ECE",
"PMP", "PMP",
"EDE", "EDE",

View File

@@ -9,6 +9,8 @@ import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.BlockPos; import net.minecraft.util.BlockPos;
import net.minecraft.util.EnumFacing; import net.minecraft.util.EnumFacing;
import storagecraft.StorageCraftBlocks; import storagecraft.StorageCraftBlocks;
import storagecraft.block.BlockController;
import storagecraft.block.EnumControllerType;
import storagecraft.storage.IStorage; import storagecraft.storage.IStorage;
import storagecraft.storage.IStorageProvider; import storagecraft.storage.IStorageProvider;
import storagecraft.storage.StorageItem; import storagecraft.storage.StorageItem;
@@ -28,7 +30,7 @@ public class TileController extends TileBase implements IEnergyReceiver, INetwor
private List<BlockPos> visitedCables = new ArrayList<BlockPos>(); private List<BlockPos> visitedCables = new ArrayList<BlockPos>();
private EnergyStorage energy = new EnergyStorage(1000); private EnergyStorage energy = new EnergyStorage(32000);
private int energyUsage; private int energyUsage;
private boolean destroyed = false; private boolean destroyed = false;
@@ -113,7 +115,14 @@ public class TileController extends TileBase implements IEnergyReceiver, INetwor
} }
} }
energy.extractEnergy(energyUsage, false); switch (getType()){
case NORMAL:
energy.extractEnergy(energyUsage, false);
break;
case CREATIVE:
energy.setEnergyStored(energy.getMaxEnergyStored());
break;
}
if (lastEnergy != energy.getEnergyStored()) { if (lastEnergy != energy.getEnergyStored()) {
worldObj.markBlockForUpdate(pos); worldObj.markBlockForUpdate(pos);
@@ -122,6 +131,10 @@ public class TileController extends TileBase implements IEnergyReceiver, INetwor
} }
} }
public EnumControllerType getType() {
return (EnumControllerType) worldObj.getBlockState(pos).getValue(BlockController.TYPE);
}
public void onDestroyed() public void onDestroyed()
{ {
disconnectAll(); disconnectAll();

View File

@@ -4,6 +4,7 @@ import net.minecraft.init.Blocks;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import storagecraft.StorageCraftBlocks; import storagecraft.StorageCraftBlocks;
import storagecraft.StorageCraftItems; import storagecraft.StorageCraftItems;
import storagecraft.block.EnumGridType;
import storagecraft.item.ItemProcessor; import storagecraft.item.ItemProcessor;
public class SoldererRecipeCraftingGrid implements ISoldererRecipe public class SoldererRecipeCraftingGrid implements ISoldererRecipe
@@ -30,7 +31,7 @@ public class SoldererRecipeCraftingGrid implements ISoldererRecipe
@Override @Override
public ItemStack getResult() public ItemStack getResult()
{ {
return new ItemStack(StorageCraftBlocks.GRID, 1, 1); return new ItemStack(StorageCraftBlocks.GRID, 1, EnumGridType.CRAFTING.getId());
} }
@Override @Override

View File

@@ -11,10 +11,20 @@
"variants": { "variants": {
"inventory": [ "inventory": [
{ {
"y": 0 "y": 0,
"textures": {
"side": "storagecraft:blocks/side",
"top": "storagecraft:blocks/side",
"front": "storagecraft:blocks/controller_0"
}
}, },
{ {
"y": 0 "y": 0,
"textures": {
"front": "storagecraft:blocks/controller_creative_front",
"top": "storagecraft:blocks/controller_creative_side",
"side": "storagecraft:blocks/controller_creative_side"
}
} }
], ],
"energy": { "energy": {
@@ -64,6 +74,17 @@
} }
} }
}, },
"type": {
"normal": {
},
"creative": {
"textures": {
"front": "storagecraft:blocks/controller_creative_front",
"top": "storagecraft:blocks/controller_creative_side",
"side": "storagecraft:blocks/controller_creative_side"
}
}
},
"direction": { "direction": {
"north": { "north": {
"y": 0 "y": 0

View File

@@ -1,6 +1,7 @@
itemGroup.storagecraft=StorageCraft itemGroup.storagecraft=StorageCraft
gui.storagecraft:controller=Controller gui.storagecraft:controller.0=Controller
gui.storagecraft:controller.1=Creative Controller
gui.storagecraft:grid=Grid gui.storagecraft:grid=Grid
gui.storagecraft:drive=Drive gui.storagecraft:drive=Drive
gui.storagecraft:external_storage=External Storage gui.storagecraft:external_storage=External Storage
@@ -56,7 +57,8 @@ sidebutton.storagecraft:detector.mode.0=Under the amount
sidebutton.storagecraft:detector.mode.1=On the amount sidebutton.storagecraft:detector.mode.1=On the amount
sidebutton.storagecraft:detector.mode.2=Above the amount sidebutton.storagecraft:detector.mode.2=Above the amount
block.storagecraft:controller.name=Controller block.storagecraft:controller.0.name=Controller
block.storagecraft:controller.1.name=Creative Controller
block.storagecraft:cable.0.name=Cable block.storagecraft:cable.0.name=Cable
block.storagecraft:cable.1.name=Sensitive Cable block.storagecraft:cable.1.name=Sensitive Cable
block.storagecraft:grid.0.name=Grid block.storagecraft:grid.0.name=Grid