mirror of
https://github.com/Ellpeck/ActuallyAdditions.git
synced 2024-11-16 13:03:12 +01:00
2252bb094e
* update oil fluid name * resolve some npe
106 lines
4 KiB
Java
106 lines
4 KiB
Java
/*
|
|
* This file ("ItemMisc.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://ellpeck.de/actaddlicense
|
|
* View the source code at https://github.com/Ellpeck/ActuallyAdditions
|
|
*
|
|
* © 2015-2017 Ellpeck
|
|
*/
|
|
|
|
package de.ellpeck.actuallyadditions.mod.items;
|
|
|
|
import de.ellpeck.actuallyadditions.mod.ActuallyAdditions;
|
|
import de.ellpeck.actuallyadditions.mod.fluids.InitFluids;
|
|
import de.ellpeck.actuallyadditions.mod.items.base.ItemBase;
|
|
import de.ellpeck.actuallyadditions.mod.items.metalists.TheMiscItems;
|
|
import de.ellpeck.actuallyadditions.mod.util.StringUtil;
|
|
import net.minecraft.block.Block;
|
|
import net.minecraft.block.state.IBlockState;
|
|
import net.minecraft.creativetab.CreativeTabs;
|
|
import net.minecraft.entity.item.EntityItem;
|
|
import net.minecraft.item.EnumRarity;
|
|
import net.minecraft.item.ItemStack;
|
|
import net.minecraft.util.NonNullList;
|
|
import net.minecraft.util.ResourceLocation;
|
|
import net.minecraft.util.math.BlockPos;
|
|
import net.minecraftforge.fluids.Fluid;
|
|
import net.minecraftforge.fluids.IFluidBlock;
|
|
import net.minecraftforge.fml.relauncher.Side;
|
|
import net.minecraftforge.fml.relauncher.SideOnly;
|
|
|
|
public class ItemMisc extends ItemBase{
|
|
|
|
public static final TheMiscItems[] ALL_MISC_ITEMS = TheMiscItems.values();
|
|
|
|
public ItemMisc(String name){
|
|
super(name);
|
|
this.setHasSubtypes(true);
|
|
}
|
|
|
|
@Override
|
|
public int getMetadata(int damage){
|
|
return damage;
|
|
}
|
|
|
|
@Override
|
|
public String getUnlocalizedName(ItemStack stack){
|
|
return stack.getItemDamage() >= ALL_MISC_ITEMS.length ? StringUtil.BUGGED_ITEM_NAME : this.getUnlocalizedName()+"_"+ALL_MISC_ITEMS[stack.getItemDamage()].name;
|
|
}
|
|
|
|
|
|
@Override
|
|
public EnumRarity getRarity(ItemStack stack){
|
|
return stack.getItemDamage() >= ALL_MISC_ITEMS.length ? EnumRarity.COMMON : ALL_MISC_ITEMS[stack.getItemDamage()].rarity;
|
|
}
|
|
|
|
@Override
|
|
@SideOnly(Side.CLIENT)
|
|
public void getSubItems(CreativeTabs tab, NonNullList list){
|
|
if(this.isInCreativeTab(tab)){
|
|
for(int j = 0; j < ALL_MISC_ITEMS.length; j++){
|
|
if(j != TheMiscItems.YOUTUBE_ICON.ordinal()){
|
|
list.add(new ItemStack(this, 1, j));
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
@Override
|
|
protected void registerRendering(){
|
|
for(int i = 0; i < ALL_MISC_ITEMS.length; i++){
|
|
String name = this.getRegistryName()+"_"+ALL_MISC_ITEMS[i].name;
|
|
ActuallyAdditions.proxy.addRenderRegister(new ItemStack(this, 1, i), new ResourceLocation(name), "inventory");
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public boolean onEntityItemUpdate(EntityItem entity){
|
|
if(!entity.world.isRemote){
|
|
ItemStack stack = entity.getItem();
|
|
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();
|
|
IBlockState state = entity.world.getBlockState(pos);
|
|
Block block = state.getBlock();
|
|
|
|
if(block instanceof IFluidBlock && block.getMetaFromState(state) == 0){
|
|
Fluid fluid = ((IFluidBlock)block).getFluid();
|
|
if(fluid != null && fluid == (isEmpowered ? InitFluids.fluidCrystalOil : InitFluids.fluidRefinedCanolaOil)){
|
|
entity.setDead();
|
|
entity.world.setBlockState(pos, (isEmpowered ? InitFluids.blockEmpoweredOil : InitFluids.blockCrystalOil).getDefaultState());
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return super.onEntityItemUpdate(entity);
|
|
}
|
|
|
|
@Override
|
|
public boolean hasEffect(ItemStack stack){
|
|
return stack.getItemDamage() == TheMiscItems.EMPOWERED_CANOLA_SEED.ordinal();
|
|
}
|
|
}
|