mirror of
https://github.com/Ellpeck/ActuallyAdditions.git
synced 2024-11-26 08:48:34 +01:00
Chest To Storage Crate Upgrade & Textures to be made
This commit is contained in:
parent
a0b7a1cc3e
commit
3f02d5cd0e
3 changed files with 107 additions and 0 deletions
|
@ -4,3 +4,8 @@ This file is a reminder to Glenthor for what textures he should make or change.
|
||||||
If you want to give making some of these textures a go, go ahead and make a pull request when you're done.
|
If you want to give making some of these textures a go, go ahead and make a pull request when you're done.
|
||||||
--------------------------------------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
-Chest To Storage Crate Upgrade (right click on chest to turn into storage crate) "itemChestToCrateUpgrade"
|
||||||
|
|
||||||
|
-Crafty Crate (Storage Crate with Crafting inside of it) "blockCraftyCrate"
|
||||||
|
|
||||||
|
-Storage Crate To Crafty Crate Upgrade "itemCrateToCraftyUpgrade"
|
||||||
|
|
|
@ -125,9 +125,14 @@ public class InitItems{
|
||||||
public static Item itemMagnetRing;
|
public static Item itemMagnetRing;
|
||||||
public static Item itemWaterRemovalRing;
|
public static Item itemWaterRemovalRing;
|
||||||
|
|
||||||
|
public static Item itemChestToCrateUpgrade;
|
||||||
|
|
||||||
public static void init(){
|
public static void init(){
|
||||||
ModUtil.LOGGER.info("Initializing Items...");
|
ModUtil.LOGGER.info("Initializing Items...");
|
||||||
|
|
||||||
|
itemChestToCrateUpgrade = new ItemChestToCrateUpgrade();
|
||||||
|
ItemUtil.register(itemChestToCrateUpgrade);
|
||||||
|
|
||||||
itemLexicon = new ItemBooklet();
|
itemLexicon = new ItemBooklet();
|
||||||
ItemUtil.register(itemLexicon);
|
ItemUtil.register(itemLexicon);
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,97 @@
|
||||||
|
/*
|
||||||
|
* This file ("ItemChestToCrateUpgrade.java") is part of the Actually Additions Mod for Minecraft.
|
||||||
|
* It is created and owned by Ellpeck and distributed
|
||||||
|
* under the Actually Additions License to be found at
|
||||||
|
* http://github.com/Ellpeck/ActuallyAdditions/blob/master/README.md
|
||||||
|
* View the source code at https://github.com/Ellpeck/ActuallyAdditions
|
||||||
|
*
|
||||||
|
* © 2015 Ellpeck
|
||||||
|
*/
|
||||||
|
|
||||||
|
package ellpeck.actuallyadditions.items;
|
||||||
|
|
||||||
|
import cpw.mods.fml.relauncher.Side;
|
||||||
|
import cpw.mods.fml.relauncher.SideOnly;
|
||||||
|
import ellpeck.actuallyadditions.blocks.InitBlocks;
|
||||||
|
import ellpeck.actuallyadditions.tile.TileEntityGiantChest;
|
||||||
|
import ellpeck.actuallyadditions.util.IActAddItemOrBlock;
|
||||||
|
import ellpeck.actuallyadditions.util.ModUtil;
|
||||||
|
import net.minecraft.block.BlockChest;
|
||||||
|
import net.minecraft.client.renderer.texture.IIconRegister;
|
||||||
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
|
import net.minecraft.item.EnumRarity;
|
||||||
|
import net.minecraft.item.Item;
|
||||||
|
import net.minecraft.item.ItemStack;
|
||||||
|
import net.minecraft.tileentity.TileEntity;
|
||||||
|
import net.minecraft.tileentity.TileEntityChest;
|
||||||
|
import net.minecraft.util.IIcon;
|
||||||
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
|
public class ItemChestToCrateUpgrade extends Item implements IActAddItemOrBlock{
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onItemUse(ItemStack heldStack, EntityPlayer player, World world, int x, int y, int z, int par7, float par8, float par9, float par10){
|
||||||
|
if(player.isSneaking()){
|
||||||
|
TileEntity tileHit = world.getTileEntity(x, y, z);
|
||||||
|
if(world.getBlock(x, y, z) instanceof BlockChest && tileHit instanceof TileEntityChest){
|
||||||
|
if(!world.isRemote){
|
||||||
|
TileEntityChest chest = (TileEntityChest)tileHit;
|
||||||
|
|
||||||
|
//Copy Slots
|
||||||
|
ItemStack[] stacks = new ItemStack[chest.getSizeInventory()];
|
||||||
|
for(int i = 0; i < stacks.length; i++){
|
||||||
|
ItemStack aStack = chest.getStackInSlot(i);
|
||||||
|
if(aStack != null){
|
||||||
|
stacks[i] = aStack.copy();
|
||||||
|
chest.setInventorySlotContents(i, null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//Set New Block
|
||||||
|
world.setBlock(x, y, z, InitBlocks.blockGiantChest, 0, 2);
|
||||||
|
|
||||||
|
//Copy Items into new Chest
|
||||||
|
TileEntity newTileHit = world.getTileEntity(x, y, z);
|
||||||
|
if(newTileHit instanceof TileEntityGiantChest){
|
||||||
|
TileEntityGiantChest newChest = (TileEntityGiantChest)newTileHit;
|
||||||
|
for(int i = 0; i < stacks.length; i++){
|
||||||
|
if(stacks[i] != null){
|
||||||
|
if(newChest.getSizeInventory() > i){
|
||||||
|
newChest.setInventorySlotContents(i, stacks[i].copy());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!player.capabilities.isCreativeMode){
|
||||||
|
heldStack.stackSize--;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return super.onItemUse(heldStack, player, world, x, y, z, par7, par8, par9, par10);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public EnumRarity getRarity(ItemStack stack){
|
||||||
|
return EnumRarity.rare;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@SideOnly(Side.CLIENT)
|
||||||
|
public void registerIcons(IIconRegister iconReg){
|
||||||
|
this.itemIcon = iconReg.registerIcon(ModUtil.MOD_ID_LOWER+":"+this.getName());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public IIcon getIcon(ItemStack stack, int pass){
|
||||||
|
return this.itemIcon;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getName(){
|
||||||
|
return "itemChestToCrateUpgrade";
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue