2015-08-29 14:33:25 +02:00
|
|
|
/*
|
2016-05-16 22:52:27 +02:00
|
|
|
* This file ("ItemBattery.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
|
|
|
|
*
|
2016-05-16 22:54:42 +02:00
|
|
|
* © 2015-2016 Ellpeck
|
2015-08-29 14:33:25 +02:00
|
|
|
*/
|
|
|
|
|
2016-01-05 04:47:35 +01:00
|
|
|
package de.ellpeck.actuallyadditions.mod.items;
|
2015-06-21 02:28:49 +02:00
|
|
|
|
2016-07-25 02:07:16 +02:00
|
|
|
import de.ellpeck.actuallyadditions.mod.ActuallyAdditions;
|
2016-01-05 04:47:35 +01:00
|
|
|
import de.ellpeck.actuallyadditions.mod.items.base.ItemEnergy;
|
2016-11-27 11:56:22 +01:00
|
|
|
import de.ellpeck.actuallyadditions.mod.util.ItemUtil;
|
2016-07-25 02:07:16 +02:00
|
|
|
import de.ellpeck.actuallyadditions.mod.util.ModUtil;
|
2016-11-16 20:31:16 +01:00
|
|
|
import de.ellpeck.actuallyadditions.mod.util.StackUtil;
|
2016-07-25 02:07:16 +02:00
|
|
|
import de.ellpeck.actuallyadditions.mod.util.StringUtil;
|
|
|
|
import de.ellpeck.actuallyadditions.mod.util.compat.TeslaUtil;
|
|
|
|
import net.darkhax.tesla.api.ITeslaConsumer;
|
|
|
|
import net.minecraft.entity.Entity;
|
|
|
|
import net.minecraft.entity.player.EntityPlayer;
|
2015-06-21 02:28:49 +02:00
|
|
|
import net.minecraft.item.EnumRarity;
|
|
|
|
import net.minecraft.item.ItemStack;
|
2016-07-25 02:07:16 +02:00
|
|
|
import net.minecraft.nbt.NBTTagCompound;
|
|
|
|
import net.minecraft.util.ActionResult;
|
|
|
|
import net.minecraft.util.EnumActionResult;
|
|
|
|
import net.minecraft.util.EnumHand;
|
|
|
|
import net.minecraft.world.World;
|
2016-11-26 19:00:02 +01:00
|
|
|
import net.minecraftforge.energy.CapabilityEnergy;
|
|
|
|
import net.minecraftforge.energy.IEnergyStorage;
|
2016-07-25 02:07:16 +02:00
|
|
|
|
|
|
|
import java.util.List;
|
2015-07-17 18:32:30 +02:00
|
|
|
|
2015-10-01 23:20:31 +02:00
|
|
|
public class ItemBattery extends ItemEnergy{
|
2015-06-21 02:28:49 +02:00
|
|
|
|
2015-07-16 16:52:28 +02:00
|
|
|
public ItemBattery(String name, int capacity, int transfer){
|
2015-12-03 20:15:07 +01:00
|
|
|
super(capacity, transfer, name);
|
2015-06-21 02:28:49 +02:00
|
|
|
this.setMaxStackSize(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public EnumRarity getRarity(ItemStack stack){
|
2016-01-07 21:41:28 +01:00
|
|
|
return EnumRarity.RARE;
|
2015-10-03 10:19:40 +02:00
|
|
|
}
|
2016-07-25 02:07:16 +02:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean hasEffect(ItemStack stack){
|
2016-11-27 11:56:22 +01:00
|
|
|
return ItemUtil.isEnabled(stack);
|
2016-07-25 02:07:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onUpdate(ItemStack stack, World world, Entity entity, int itemSlot, boolean isSelected){
|
2016-11-27 11:56:22 +01:00
|
|
|
if(!world.isRemote && entity instanceof EntityPlayer && ItemUtil.isEnabled(stack)){
|
2016-07-25 02:07:16 +02:00
|
|
|
EntityPlayer player = (EntityPlayer)entity;
|
|
|
|
for(int i = 0; i < player.inventory.getSizeInventory(); i++){
|
|
|
|
ItemStack slot = player.inventory.getStackInSlot(i);
|
2016-11-16 20:31:16 +01:00
|
|
|
if(StackUtil.isValid(slot)){
|
2016-11-26 19:00:02 +01:00
|
|
|
int extractable = this.extractEnergy(stack, Integer.MAX_VALUE, true);
|
2016-07-25 02:07:16 +02:00
|
|
|
int received = 0;
|
|
|
|
|
2016-11-26 20:43:50 +01:00
|
|
|
if(slot.hasCapability(CapabilityEnergy.ENERGY, null)){
|
2016-11-26 19:00:02 +01:00
|
|
|
IEnergyStorage cap = slot.getCapability(CapabilityEnergy.ENERGY, null);
|
|
|
|
if(cap != null){
|
|
|
|
received = cap.receiveEnergy(extractable, false);
|
|
|
|
}
|
2016-07-25 02:07:16 +02:00
|
|
|
}
|
|
|
|
else if(ActuallyAdditions.teslaLoaded && slot.hasCapability(TeslaUtil.teslaConsumer, null)){
|
|
|
|
ITeslaConsumer cap = slot.getCapability(TeslaUtil.teslaConsumer, null);
|
|
|
|
if(cap != null){
|
2016-11-26 19:00:02 +01:00
|
|
|
received = (int)cap.givePower(extractable, false);
|
2016-07-25 02:07:16 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if(received > 0){
|
|
|
|
this.extractEnergy(stack, received, false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2016-11-19 21:11:17 +01:00
|
|
|
public ActionResult<ItemStack> onItemRightClick(World worldIn, EntityPlayer player, EnumHand hand){
|
2016-07-25 02:07:16 +02:00
|
|
|
if(!worldIn.isRemote && player.isSneaking()){
|
2016-11-27 11:56:22 +01:00
|
|
|
ItemUtil.changeEnabled(player, hand);
|
|
|
|
return new ActionResult<ItemStack>(EnumActionResult.SUCCESS, player.getHeldItem(hand));
|
2016-07-25 02:07:16 +02:00
|
|
|
}
|
2016-11-19 21:11:17 +01:00
|
|
|
return super.onItemRightClick(worldIn, player, hand);
|
2016-07-25 02:07:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void addInformation(ItemStack stack, EntityPlayer player, List list, boolean bool){
|
|
|
|
super.addInformation(stack, player, list, bool);
|
2016-11-27 11:56:22 +01:00
|
|
|
list.add(StringUtil.localize("tooltip."+ModUtil.MOD_ID+".battery."+(ItemUtil.isEnabled(stack) ? "discharge" : "noDischarge")));
|
2016-07-25 02:07:16 +02:00
|
|
|
list.add(StringUtil.localize("tooltip."+ModUtil.MOD_ID+".battery.changeMode"));
|
|
|
|
}
|
2015-06-21 02:28:49 +02:00
|
|
|
}
|