2015-08-29 14:33:25 +02:00
|
|
|
/*
|
|
|
|
* This file ("ItemEnergy.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
|
2016-01-03 16:05:51 +01:00
|
|
|
* http://ellpeck.de/actaddlicense/
|
2015-08-29 14:33:25 +02:00
|
|
|
* View the source code at https://github.com/Ellpeck/ActuallyAdditions
|
|
|
|
*
|
2016-01-03 16:05:51 +01:00
|
|
|
* © 2016 Ellpeck
|
2015-08-29 14:33:25 +02:00
|
|
|
*/
|
|
|
|
|
2016-01-05 04:47:35 +01:00
|
|
|
package de.ellpeck.actuallyadditions.mod.items.base;
|
2015-07-07 20:20:24 +02:00
|
|
|
|
|
|
|
import cofh.api.energy.ItemEnergyContainer;
|
2016-01-08 20:51:03 +01:00
|
|
|
import de.ellpeck.actuallyadditions.mod.ActuallyAdditions;
|
2016-03-18 18:38:39 +01:00
|
|
|
import de.ellpeck.actuallyadditions.mod.util.ItemUtil;
|
2016-01-05 04:47:35 +01:00
|
|
|
import de.ellpeck.actuallyadditions.mod.util.ModUtil;
|
2015-07-07 20:20:24 +02:00
|
|
|
import net.minecraft.creativetab.CreativeTabs;
|
|
|
|
import net.minecraft.entity.player.EntityPlayer;
|
|
|
|
import net.minecraft.item.Item;
|
|
|
|
import net.minecraft.item.ItemStack;
|
|
|
|
import net.minecraft.nbt.NBTTagCompound;
|
2016-01-08 20:51:03 +01:00
|
|
|
import net.minecraft.util.ResourceLocation;
|
2015-07-07 20:20:24 +02:00
|
|
|
import net.minecraft.world.World;
|
2016-01-07 18:20:59 +01:00
|
|
|
import net.minecraftforge.fml.relauncher.Side;
|
|
|
|
import net.minecraftforge.fml.relauncher.SideOnly;
|
2015-07-07 20:20:24 +02:00
|
|
|
|
|
|
|
import java.util.List;
|
|
|
|
|
2015-12-19 10:30:39 +01:00
|
|
|
public abstract class ItemEnergy extends ItemEnergyContainer{
|
2015-07-07 20:20:24 +02:00
|
|
|
|
2015-12-03 20:15:07 +01:00
|
|
|
private String name;
|
|
|
|
|
|
|
|
public ItemEnergy(int maxPower, int transfer, String name){
|
2015-07-07 20:20:24 +02:00
|
|
|
super(maxPower, transfer);
|
|
|
|
this.setHasSubtypes(true);
|
|
|
|
this.setMaxStackSize(1);
|
2015-12-03 20:15:07 +01:00
|
|
|
this.name = name;
|
|
|
|
|
|
|
|
this.register();
|
|
|
|
}
|
|
|
|
|
|
|
|
private void register(){
|
2016-03-18 18:38:39 +01:00
|
|
|
ItemUtil.registerItem(this, this.getBaseName(), this.shouldAddCreative());
|
2016-01-08 16:52:53 +01:00
|
|
|
|
2016-01-08 20:51:03 +01:00
|
|
|
this.registerRendering();
|
|
|
|
}
|
|
|
|
|
2015-12-03 20:15:07 +01:00
|
|
|
protected String getBaseName(){
|
|
|
|
return this.name;
|
2015-07-07 20:20:24 +02:00
|
|
|
}
|
|
|
|
|
2015-12-19 10:30:39 +01:00
|
|
|
public boolean shouldAddCreative(){
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2016-02-01 17:49:55 +01:00
|
|
|
protected void registerRendering(){
|
2016-04-20 21:39:03 +02:00
|
|
|
ActuallyAdditions.proxy.addRenderRegister(new ItemStack(this), new ResourceLocation(ModUtil.MOD_ID, this.getBaseName()));
|
2016-02-01 17:49:55 +01:00
|
|
|
}
|
|
|
|
|
2015-07-07 20:20:24 +02:00
|
|
|
@Override
|
2015-10-03 10:19:40 +02:00
|
|
|
public boolean getShareTag(){
|
2015-07-07 20:20:24 +02:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onCreated(ItemStack stack, World world, EntityPlayer player){
|
|
|
|
this.setEnergy(stack, 0);
|
|
|
|
}
|
|
|
|
|
2015-10-05 19:55:28 +02:00
|
|
|
@SuppressWarnings("unchecked")
|
|
|
|
@Override
|
|
|
|
public void addInformation(ItemStack stack, EntityPlayer player, List list, boolean bool){
|
|
|
|
list.add(this.getEnergyStored(stack)+"/"+this.getMaxEnergyStored(stack)+" RF");
|
|
|
|
}
|
|
|
|
|
2016-02-01 17:49:55 +01:00
|
|
|
@Override
|
|
|
|
@SideOnly(Side.CLIENT)
|
|
|
|
public boolean hasEffect(ItemStack stack){
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2015-07-07 20:20:24 +02:00
|
|
|
@Override
|
|
|
|
@SuppressWarnings("unchecked")
|
|
|
|
@SideOnly(Side.CLIENT)
|
|
|
|
public void getSubItems(Item item, CreativeTabs tabs, List list){
|
|
|
|
ItemStack stackFull = new ItemStack(this);
|
|
|
|
this.setEnergy(stackFull, this.getMaxEnergyStored(stackFull));
|
|
|
|
list.add(stackFull);
|
|
|
|
|
|
|
|
ItemStack stackEmpty = new ItemStack(this);
|
|
|
|
this.setEnergy(stackEmpty, 0);
|
|
|
|
list.add(stackEmpty);
|
|
|
|
}
|
|
|
|
|
2015-10-03 10:19:40 +02:00
|
|
|
@Override
|
|
|
|
public boolean showDurabilityBar(ItemStack itemStack){
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public double getDurabilityForDisplay(ItemStack stack){
|
|
|
|
double energyDif = getMaxEnergyStored(stack)-getEnergyStored(stack);
|
|
|
|
double maxAmount = getMaxEnergyStored(stack);
|
|
|
|
return energyDif/maxAmount;
|
|
|
|
}
|
|
|
|
|
2015-07-07 20:20:24 +02:00
|
|
|
public void setEnergy(ItemStack stack, int energy){
|
|
|
|
NBTTagCompound compound = stack.getTagCompound();
|
2015-10-03 10:16:18 +02:00
|
|
|
if(compound == null){
|
|
|
|
compound = new NBTTagCompound();
|
|
|
|
}
|
2015-07-07 20:20:24 +02:00
|
|
|
compound.setInteger("Energy", energy);
|
|
|
|
stack.setTagCompound(compound);
|
|
|
|
}
|
|
|
|
}
|