2013-12-27 16:59:59 -06:00
|
|
|
package appeng.block;
|
|
|
|
|
|
|
|
import java.text.MessageFormat;
|
|
|
|
import java.util.List;
|
|
|
|
|
|
|
|
import net.minecraft.block.Block;
|
|
|
|
import net.minecraft.entity.player.EntityPlayer;
|
|
|
|
import net.minecraft.item.ItemStack;
|
|
|
|
import net.minecraft.nbt.NBTTagCompound;
|
|
|
|
import appeng.api.AEApi;
|
|
|
|
import appeng.api.config.AccessRestriction;
|
|
|
|
import appeng.api.config.PowerUnits;
|
2014-01-23 13:02:48 -06:00
|
|
|
import appeng.api.implementations.items.IAEItemPowerStorage;
|
2014-01-20 10:41:37 -06:00
|
|
|
import appeng.core.localization.GuiText;
|
2013-12-27 16:59:59 -06:00
|
|
|
import appeng.util.Platform;
|
|
|
|
|
|
|
|
public class AEBaseItemBlockChargeable extends AEBaseItemBlock implements IAEItemPowerStorage
|
|
|
|
{
|
|
|
|
|
2014-02-08 19:34:52 -06:00
|
|
|
public AEBaseItemBlockChargeable(Block id) {
|
2013-12-27 16:59:59 -06:00
|
|
|
super( id );
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void addInformation(ItemStack is, EntityPlayer player, List lines, boolean advancedItemTooltips)
|
|
|
|
{
|
|
|
|
NBTTagCompound tag = is.getTagCompound();
|
|
|
|
double internalCurrentPower = 0;
|
|
|
|
double internalMaxPower = getMax( is );
|
|
|
|
|
|
|
|
if ( tag != null )
|
|
|
|
{
|
|
|
|
internalCurrentPower = tag.getDouble( "internalCurrentPower" );
|
|
|
|
}
|
|
|
|
|
|
|
|
double percent = internalCurrentPower / internalMaxPower;
|
|
|
|
|
2014-01-20 10:41:37 -06:00
|
|
|
lines.add( GuiText.StoredEnergy.getLocal() + ":" + MessageFormat.format( " {0,number,#} ", internalCurrentPower )
|
2014-02-08 19:34:52 -06:00
|
|
|
+ Platform.gui_localize( PowerUnits.AE.unlocalizedName ) + " - " + MessageFormat.format( " {0,number,#.##%} ", percent ) );
|
2013-12-27 16:59:59 -06:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
private double getMax(ItemStack is)
|
|
|
|
{
|
2014-02-08 19:34:52 -06:00
|
|
|
Block blk = Block.getBlockFromItem( this );
|
2013-12-27 16:59:59 -06:00
|
|
|
if ( blk == AEApi.instance().blocks().blockEnergyCell.block() )
|
|
|
|
return 200000;
|
|
|
|
else
|
|
|
|
return 8 * 200000;
|
|
|
|
}
|
|
|
|
|
|
|
|
private double getInternal(ItemStack is)
|
|
|
|
{
|
|
|
|
NBTTagCompound nbt = Platform.openNbtData( is );
|
|
|
|
return nbt.getDouble( "internalCurrentPower" );
|
|
|
|
}
|
|
|
|
|
|
|
|
private void setInternal(ItemStack is, double amt)
|
|
|
|
{
|
|
|
|
NBTTagCompound nbt = Platform.openNbtData( is );
|
|
|
|
nbt.setDouble( "internalCurrentPower", amt );
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public double injectAEPower(ItemStack is, double amt)
|
|
|
|
{
|
|
|
|
double internalCurrentPower = getInternal( is );
|
|
|
|
double internalMaxPower = getMax( is );
|
|
|
|
internalCurrentPower += amt;
|
|
|
|
if ( internalCurrentPower > internalMaxPower )
|
|
|
|
{
|
|
|
|
amt = internalCurrentPower - internalMaxPower;
|
|
|
|
internalCurrentPower = internalMaxPower;
|
|
|
|
setInternal( is, internalCurrentPower );
|
|
|
|
return amt;
|
|
|
|
}
|
|
|
|
|
|
|
|
setInternal( is, internalCurrentPower );
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public double extractAEPower(ItemStack is, double amt)
|
|
|
|
{
|
|
|
|
double internalCurrentPower = getInternal( is );
|
|
|
|
if ( internalCurrentPower > amt )
|
|
|
|
{
|
|
|
|
internalCurrentPower -= amt;
|
|
|
|
setInternal( is, internalCurrentPower );
|
|
|
|
return amt;
|
|
|
|
}
|
|
|
|
|
|
|
|
amt = internalCurrentPower;
|
|
|
|
setInternal( is, 0 );
|
|
|
|
return amt;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public double getAEMaxPower(ItemStack is)
|
|
|
|
{
|
|
|
|
double internalMaxPower = getMax( is );
|
|
|
|
return internalMaxPower;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public double getAECurrentPower(ItemStack is)
|
|
|
|
{
|
|
|
|
double internalCurrentPower = getInternal( is );
|
|
|
|
return internalCurrentPower;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public AccessRestriction getPowerFlow(ItemStack is)
|
|
|
|
{
|
|
|
|
return AccessRestriction.WRITE;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|