2015-08-29 14:33:25 +02:00
|
|
|
/*
|
2016-05-16 22:52:27 +02:00
|
|
|
* This file ("ItemMisc.java") is part of the Actually Additions mod for Minecraft.
|
2015-08-29 14:33:25 +02:00
|
|
|
* It is created and owned by Ellpeck and distributed
|
|
|
|
* under the Actually Additions License to be found at
|
2016-05-16 22:52:27 +02:00
|
|
|
* http://ellpeck.de/actaddlicense
|
2015-08-29 14:33:25 +02:00
|
|
|
* View the source code at https://github.com/Ellpeck/ActuallyAdditions
|
|
|
|
*
|
2017-01-01 16:23:26 +01:00
|
|
|
* © 2015-2017 Ellpeck
|
2015-08-29 14:33:25 +02:00
|
|
|
*/
|
|
|
|
|
2016-01-05 04:47:35 +01:00
|
|
|
package de.ellpeck.actuallyadditions.mod.items;
|
2014-11-10 16:47:04 +01:00
|
|
|
|
2016-01-10 01:17:17 +01:00
|
|
|
import de.ellpeck.actuallyadditions.mod.ActuallyAdditions;
|
2016-09-11 14:51:52 +02:00
|
|
|
import de.ellpeck.actuallyadditions.mod.fluids.InitFluids;
|
2016-01-05 04:47:35 +01:00
|
|
|
import de.ellpeck.actuallyadditions.mod.items.base.ItemBase;
|
|
|
|
import de.ellpeck.actuallyadditions.mod.items.metalists.TheMiscItems;
|
|
|
|
import de.ellpeck.actuallyadditions.mod.util.StringUtil;
|
2016-09-11 14:51:52 +02:00
|
|
|
import net.minecraft.block.Block;
|
|
|
|
import net.minecraft.block.state.IBlockState;
|
2014-11-10 16:47:04 +01:00
|
|
|
import net.minecraft.creativetab.CreativeTabs;
|
2016-09-11 14:51:52 +02:00
|
|
|
import net.minecraft.entity.item.EntityItem;
|
2015-03-07 02:23:31 +01:00
|
|
|
import net.minecraft.item.EnumRarity;
|
2014-11-10 16:47:04 +01:00
|
|
|
import net.minecraft.item.Item;
|
|
|
|
import net.minecraft.item.ItemStack;
|
2016-11-19 21:11:17 +01:00
|
|
|
import net.minecraft.util.NonNullList;
|
2016-06-01 00:37:28 +02:00
|
|
|
import net.minecraft.util.ResourceLocation;
|
2016-09-11 14:51:52 +02:00
|
|
|
import net.minecraft.util.math.BlockPos;
|
|
|
|
import net.minecraftforge.fluids.Fluid;
|
|
|
|
import net.minecraftforge.fluids.IFluidBlock;
|
2016-01-07 18:20:59 +01:00
|
|
|
import net.minecraftforge.fml.relauncher.Side;
|
|
|
|
import net.minecraftforge.fml.relauncher.SideOnly;
|
2014-11-10 16:47:04 +01:00
|
|
|
|
2015-12-03 20:15:07 +01:00
|
|
|
public class ItemMisc extends ItemBase{
|
2014-11-10 16:47:04 +01:00
|
|
|
|
2016-06-17 23:50:38 +02:00
|
|
|
public static final TheMiscItems[] ALL_MISC_ITEMS = TheMiscItems.values();
|
2015-01-29 20:23:19 +01:00
|
|
|
|
2015-12-03 20:15:07 +01:00
|
|
|
public ItemMisc(String name){
|
|
|
|
super(name);
|
2015-01-30 20:16:32 +01:00
|
|
|
this.setHasSubtypes(true);
|
2014-11-10 16:47:04 +01:00
|
|
|
}
|
|
|
|
|
2015-03-07 02:23:31 +01:00
|
|
|
@Override
|
2015-10-03 10:19:40 +02:00
|
|
|
public int getMetadata(int damage){
|
|
|
|
return damage;
|
2015-03-07 02:23:31 +01:00
|
|
|
}
|
|
|
|
|
2015-02-20 22:45:33 +01:00
|
|
|
@Override
|
2015-10-03 10:19:40 +02:00
|
|
|
public String getUnlocalizedName(ItemStack stack){
|
2016-11-19 23:12:22 +01:00
|
|
|
return stack.getItemDamage() >= ALL_MISC_ITEMS.length ? StringUtil.BUGGED_ITEM_NAME : this.getUnlocalizedName()+"_"+ALL_MISC_ITEMS[stack.getItemDamage()].name;
|
2015-10-03 10:19:40 +02:00
|
|
|
}
|
|
|
|
|
2016-05-29 23:49:35 +02:00
|
|
|
|
2015-10-03 10:19:40 +02:00
|
|
|
@Override
|
|
|
|
public EnumRarity getRarity(ItemStack stack){
|
2016-06-17 23:50:38 +02:00
|
|
|
return stack.getItemDamage() >= ALL_MISC_ITEMS.length ? EnumRarity.COMMON : ALL_MISC_ITEMS[stack.getItemDamage()].rarity;
|
2014-11-10 16:47:04 +01:00
|
|
|
}
|
|
|
|
|
2016-06-10 21:52:37 +02:00
|
|
|
@Override
|
2015-01-30 20:16:32 +01:00
|
|
|
@SideOnly(Side.CLIENT)
|
2016-11-19 21:11:17 +01:00
|
|
|
public void getSubItems(Item item, CreativeTabs tab, NonNullList list){
|
2016-06-17 23:50:38 +02:00
|
|
|
for(int j = 0; j < ALL_MISC_ITEMS.length; j++){
|
2016-06-12 13:39:26 +02:00
|
|
|
if(j != TheMiscItems.YOUTUBE_ICON.ordinal()){
|
|
|
|
list.add(new ItemStack(this, 1, j));
|
|
|
|
}
|
2014-11-10 16:47:04 +01:00
|
|
|
}
|
|
|
|
}
|
2016-01-10 01:17:17 +01:00
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void registerRendering(){
|
2016-06-17 23:50:38 +02:00
|
|
|
for(int i = 0; i < ALL_MISC_ITEMS.length; i++){
|
2016-11-19 23:12:22 +01:00
|
|
|
String name = this.getRegistryName()+"_"+ALL_MISC_ITEMS[i].name;
|
2016-06-01 00:37:28 +02:00
|
|
|
ActuallyAdditions.proxy.addRenderRegister(new ItemStack(this, 1, i), new ResourceLocation(name), "inventory");
|
2016-01-10 01:17:17 +01:00
|
|
|
}
|
|
|
|
}
|
2016-09-11 14:51:52 +02:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean onEntityItemUpdate(EntityItem entity){
|
2016-11-26 21:32:27 +01:00
|
|
|
if(!entity.world.isRemote){
|
2016-09-11 14:51:52 +02:00
|
|
|
ItemStack stack = entity.getEntityItem();
|
2016-09-13 20:40:26 +02:00
|
|
|
if(stack != null){
|
|
|
|
boolean isEmpowered = stack.getItemDamage() == TheMiscItems.EMPOWERED_CANOLA_SEED.ordinal();
|
|
|
|
if(stack.getItemDamage() == TheMiscItems.CRYSTALLIZED_CANOLA_SEED.ordinal() || isEmpowered){
|
|
|
|
BlockPos pos = entity.getPosition();
|
2016-11-26 21:32:27 +01:00
|
|
|
IBlockState state = entity.world.getBlockState(pos);
|
2016-09-13 20:40:26 +02:00
|
|
|
Block block = state.getBlock();
|
2016-09-11 14:51:52 +02:00
|
|
|
|
2016-09-13 20:40:26 +02:00
|
|
|
if(block instanceof IFluidBlock && block.getMetaFromState(state) == 0){
|
|
|
|
Fluid fluid = ((IFluidBlock)block).getFluid();
|
|
|
|
if(fluid != null && fluid == (isEmpowered ? InitFluids.fluidCrystalOil : InitFluids.fluidOil)){
|
|
|
|
entity.setDead();
|
2016-11-26 21:32:27 +01:00
|
|
|
entity.world.setBlockState(pos, (isEmpowered ? InitFluids.blockEmpoweredOil : InitFluids.blockCrystalOil).getDefaultState());
|
2016-09-13 20:40:26 +02:00
|
|
|
}
|
2016-09-11 14:51:52 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return super.onEntityItemUpdate(entity);
|
|
|
|
}
|
2016-09-17 12:24:49 +02:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean hasEffect(ItemStack stack){
|
|
|
|
return stack.getItemDamage() == TheMiscItems.EMPOWERED_CANOLA_SEED.ordinal();
|
|
|
|
}
|
2015-01-29 20:23:19 +01:00
|
|
|
}
|