Applied-Energistics-2-tiler.../src/main/java/appeng/items/AEBaseItem.java

134 lines
4 KiB
Java
Raw Normal View History

2014-11-13 22:15:06 +01:00
/*
* This file is part of Applied Energistics 2.
* Copyright (c) 2013 - 2015, AlgorithmX2, All rights reserved.
2014-11-13 22:15:06 +01:00
*
* Applied Energistics 2 is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Applied Energistics 2 is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Applied Energistics 2. If not, see <http://www.gnu.org/licenses/lgpl>.
*/
2014-09-24 02:26:27 +02:00
package appeng.items;
2014-11-13 22:15:06 +01:00
2014-09-24 02:26:27 +02:00
import java.util.EnumSet;
import java.util.List;
2014-09-24 02:26:27 +02:00
import com.google.common.base.Optional;
import com.google.common.collect.Lists;
import net.minecraft.client.renderer.ItemMeshDefinition;
2015-12-24 02:07:03 +01:00
import net.minecraft.creativetab.CreativeTabs;
import net.minecraft.entity.player.EntityPlayer;
2014-09-24 02:26:27 +02:00
import net.minecraft.item.Item;
import net.minecraft.item.ItemStack;
import net.minecraft.util.ResourceLocation;
2015-06-16 02:44:59 +02:00
import net.minecraftforge.fml.relauncher.Side;
import net.minecraftforge.fml.relauncher.SideOnly;
2015-12-24 02:07:03 +01:00
2014-09-24 02:26:27 +02:00
import appeng.core.features.AEFeature;
import appeng.core.features.FeatureNameExtractor;
2014-09-24 02:26:27 +02:00
import appeng.core.features.IAEFeature;
import appeng.core.features.IFeatureHandler;
import appeng.core.features.ItemFeatureHandler;
2014-09-24 02:26:27 +02:00
2014-11-13 22:15:06 +01:00
public abstract class AEBaseItem extends Item implements IAEFeature
2014-09-24 02:26:27 +02:00
{
private final String fullName;
private final Optional<String> subName;
private IFeatureHandler feature;
2014-09-24 02:26:27 +02:00
public AEBaseItem()
2014-09-24 02:26:27 +02:00
{
this( Optional.<String>absent() );
this.setNoRepair();
2014-09-24 02:26:27 +02:00
}
2015-09-30 14:24:40 +02:00
public AEBaseItem( final Optional<String> subName )
2014-11-13 22:15:06 +01:00
{
this.subName = subName;
this.fullName = new FeatureNameExtractor( this.getClass(), subName ).get();
2014-09-24 02:26:27 +02:00
}
@Override
public String toString()
2014-11-13 22:15:06 +01:00
{
return this.fullName;
2014-09-24 02:26:27 +02:00
}
@Override
public IFeatureHandler handler()
2014-09-24 02:26:27 +02:00
{
return this.feature;
2014-09-24 02:26:27 +02:00
}
@Override
public void postInit()
{
// override!
}
2015-09-30 14:24:40 +02:00
public void setFeature( final EnumSet<AEFeature> f )
{
this.feature = new ItemFeatureHandler( f, this, this, this.subName );
}
@Override
@SuppressWarnings( "unchecked" )
2015-09-30 14:24:40 +02:00
public final void addInformation( final ItemStack stack, final EntityPlayer player, final List lines, final boolean displayMoreInfo )
{
this.addCheckedInformation( stack, player, lines, displayMoreInfo );
}
@Override
@SuppressWarnings( "unchecked" )
2015-09-30 14:24:40 +02:00
public final void getSubItems( final Item sameItem, final CreativeTabs creativeTab, final List itemStacks )
{
this.getCheckedSubItems( sameItem, creativeTab, itemStacks );
}
@Override
2015-09-30 14:24:40 +02:00
public boolean isBookEnchantable( final ItemStack itemstack1, final ItemStack itemstack2 )
{
return false;
}
2015-09-30 14:24:40 +02:00
protected void addCheckedInformation( final ItemStack stack, final EntityPlayer player, final List<String> lines, final boolean displayMoreInfo )
{
super.addInformation( stack, player, lines, displayMoreInfo );
}
2015-06-16 02:44:59 +02:00
2015-09-30 14:24:40 +02:00
protected void getCheckedSubItems( final Item sameItem, final CreativeTabs creativeTab, final List<ItemStack> itemStacks )
{
super.getSubItems( sameItem, creativeTab, itemStacks );
}
/**
* During registration of the item in the registry, this method is used to determine which models need to be registered for the item to be
* rendered. If your item subclass requires more than just the default, override this method and add them to the list, or replace it entirely.
*/
@SideOnly( Side.CLIENT )
public List<ResourceLocation> getItemVariants() {
return Lists.newArrayList( getRegistryName() );
}
/**
* If this item requires special logic to select the model for rendering, this method can be overriden to return that selection logic.
* Return null to use the standard logic.
*/
@SideOnly( Side.CLIENT )
public ItemMeshDefinition getItemMeshDefinition() {
return null;
}
2014-09-24 02:26:27 +02:00
}