add bad rendering creative controller
This commit is contained in:
@@ -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)
|
||||||
{
|
{
|
||||||
|
35
src/main/java/storagecraft/block/EnumControllerType.java
Executable file
35
src/main/java/storagecraft/block/EnumControllerType.java
Executable 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;
|
||||||
|
}
|
||||||
|
}
|
@@ -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()));
|
||||||
|
11
src/main/java/storagecraft/item/ItemBlockController.java
Executable file
11
src/main/java/storagecraft/item/ItemBlockController.java
Executable file
@@ -0,0 +1,11 @@
|
|||||||
|
package storagecraft.item;
|
||||||
|
|
||||||
|
import net.minecraft.block.Block;
|
||||||
|
|
||||||
|
public class ItemBlockController extends ItemBlockBase
|
||||||
|
{
|
||||||
|
public ItemBlockController(Block block)
|
||||||
|
{
|
||||||
|
super(block);
|
||||||
|
}
|
||||||
|
}
|
@@ -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"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -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",
|
||||||
|
@@ -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
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
switch (getType()){
|
||||||
|
case NORMAL:
|
||||||
energy.extractEnergy(energyUsage, false);
|
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();
|
||||||
|
@@ -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
|
||||||
|
@@ -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
|
||||||
|
@@ -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
|
||||||
|
Reference in New Issue
Block a user