ActuallyAdditions/src/main/java/de/ellpeck/actuallyadditions/mod/items/ItemPotionRing.java

256 lines
10 KiB
Java
Raw Normal View History

2015-08-29 14:33:25 +02:00
/*
2016-05-16 22:52:27 +02:00
* This file ("ItemPotionRing.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
*
2017-01-01 16:23:26 +01:00
* © 2015-2017 Ellpeck
2015-08-29 14:33:25 +02:00
*/
2016-01-05 04:47:35 +01:00
package de.ellpeck.actuallyadditions.mod.items;
2015-03-31 20:37:55 +02:00
import de.ellpeck.actuallyadditions.api.misc.IDisplayStandItem;
import de.ellpeck.actuallyadditions.mod.ActuallyAdditions;
2016-01-05 04:47:35 +01:00
import de.ellpeck.actuallyadditions.mod.items.base.ItemBase;
import de.ellpeck.actuallyadditions.mod.items.metalists.ThePotionRings;
2016-03-19 15:10:20 +01:00
import de.ellpeck.actuallyadditions.mod.util.IColorProvidingItem;
import de.ellpeck.actuallyadditions.mod.util.StackUtil;
2016-01-05 04:47:35 +01:00
import de.ellpeck.actuallyadditions.mod.util.StringUtil;
import de.ellpeck.actuallyadditions.mod.util.Util;
2016-03-19 15:10:20 +01:00
import net.minecraft.client.renderer.color.IItemColor;
2017-06-17 00:48:49 +02:00
import net.minecraft.client.util.ITooltipFlag;
2015-03-31 20:37:55 +02:00
import net.minecraft.creativetab.CreativeTabs;
import net.minecraft.entity.Entity;
import net.minecraft.entity.EntityLivingBase;
2015-03-31 20:37:55 +02:00
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.item.EnumRarity;
import net.minecraft.item.ItemStack;
import net.minecraft.nbt.NBTTagCompound;
2016-03-18 23:47:22 +01:00
import net.minecraft.potion.Potion;
2015-03-31 20:37:55 +02:00
import net.minecraft.potion.PotionEffect;
import net.minecraft.tileentity.TileEntity;
2016-11-19 21:11:17 +01:00
import net.minecraft.util.NonNullList;
import net.minecraft.util.math.AxisAlignedBB;
import net.minecraft.util.math.MathHelper;
2015-03-31 20:37:55 +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-03-31 20:37:55 +02:00
2017-06-17 00:48:49 +02:00
import javax.annotation.Nullable;
import java.util.Collections;
2015-03-31 20:37:55 +02:00
import java.util.List;
public class ItemPotionRing extends ItemBase implements IColorProvidingItem, IDisplayStandItem{
2015-03-31 20:37:55 +02:00
2016-06-17 23:50:38 +02:00
public static final ThePotionRings[] ALL_RINGS = ThePotionRings.values();
2015-03-31 20:37:55 +02:00
public static final int MAX_BLAZE = 800;
2016-05-19 20:05:12 +02:00
private final boolean isAdvanced;
2015-03-31 20:37:55 +02:00
public ItemPotionRing(boolean isAdvanced, String name){
super(name);
2015-03-31 20:37:55 +02:00
this.setHasSubtypes(true);
this.setMaxStackSize(1);
this.isAdvanced = isAdvanced;
}
2016-11-26 21:32:27 +01:00
public static int getStoredBlaze(ItemStack stack){
if(!StackUtil.isValid(stack) || !stack.hasTagCompound()){
return 0;
}
else{
return stack.getTagCompound().getInteger("Blaze");
}
}
public static void setStoredBlaze(ItemStack stack, int amount){
if(StackUtil.isValid(stack)){
if(!stack.hasTagCompound()){
stack.setTagCompound(new NBTTagCompound());
}
stack.getTagCompound().setInteger("Blaze", amount);
}
}
2015-10-03 10:19:40 +02:00
@Override
public int getMetadata(int damage){
return damage;
}
@Override
public double getDurabilityForDisplay(ItemStack stack){
double diff = MAX_BLAZE-getStoredBlaze(stack);
return diff/MAX_BLAZE;
}
@Override
public int getRGBDurabilityForDisplay(ItemStack stack){
int curr = getStoredBlaze(stack);
return MathHelper.hsvToRGB(Math.max(0.0F, (float)curr/MAX_BLAZE)/3.0F, 1.0F, 1.0F);
}
2015-10-03 10:19:40 +02:00
@Override
2018-08-04 04:22:20 +02:00
public String getTranslationKey(ItemStack stack){
return stack.getItemDamage() >= ALL_RINGS.length ? StringUtil.BUGGED_ITEM_NAME : this.getTranslationKey()+ALL_RINGS[stack.getItemDamage()].name;
2015-10-03 10:19:40 +02:00
}
@Override
public boolean showDurabilityBar(ItemStack itemStack){
return true;
}
2015-03-31 20:37:55 +02:00
@Override
public void onUpdate(ItemStack stack, World world, Entity player, int par4, boolean par5){
super.onUpdate(stack, world, player, par4, par5);
2016-06-17 23:50:38 +02:00
if(!world.isRemote && stack.getItemDamage() < ALL_RINGS.length){
if(player instanceof EntityPlayer){
EntityPlayer thePlayer = (EntityPlayer)player;
int storedBlaze = getStoredBlaze(stack);
if(storedBlaze > 0){
ItemStack equippedStack = thePlayer.getHeldItemMainhand();
ItemStack offhandStack = thePlayer.getHeldItemOffhand();
if(this.effectEntity(thePlayer, stack, (StackUtil.isValid(equippedStack) && stack == equippedStack) || (StackUtil.isValid(offhandStack) && stack == offhandStack))){
if(world.getTotalWorldTime()%10 == 0){
setStoredBlaze(stack, storedBlaze-1);
}
}
}
2015-03-31 20:37:55 +02:00
}
}
}
@Override
public boolean shouldCauseReequipAnimation(ItemStack oldStack, ItemStack newStack, boolean slotChanged){
return slotChanged || !ItemStack.areItemsEqual(oldStack, newStack);
}
2015-03-31 20:37:55 +02:00
@Override
public String getItemStackDisplayName(ItemStack stack){
if(Util.isClient()) {
2018-08-04 04:22:20 +02:00
String standardName = StringUtil.localize(this.getTranslationKey()+".name");
2016-06-17 23:50:38 +02:00
if(stack.getItemDamage() < ALL_RINGS.length){
String effect = StringUtil.localize(ALL_RINGS[stack.getItemDamage()].name);
2015-10-03 10:19:40 +02:00
return standardName+" "+effect;
}
return standardName;
}
2018-08-04 04:22:20 +02:00
String standardName = StringUtil.localizeIllegallyOnTheServerDontUseMePls(this.getTranslationKey()+".name");
if(stack.getItemDamage() < ALL_RINGS.length){
String effect = StringUtil.localizeIllegallyOnTheServerDontUseMePls(ALL_RINGS[stack.getItemDamage()].name);
return standardName+" "+effect;
}
return standardName;
2015-03-31 20:37:55 +02:00
}
@Override
public EnumRarity getRarity(ItemStack stack){
2016-06-17 23:50:38 +02:00
return stack.getItemDamage() >= ALL_RINGS.length ? EnumRarity.COMMON : ALL_RINGS[stack.getItemDamage()].rarity;
2015-03-31 20:37:55 +02:00
}
@Override
2015-03-31 20:37:55 +02:00
@SideOnly(Side.CLIENT)
public void getSubItems(CreativeTabs tab, NonNullList<ItemStack> list){
if(this.isInCreativeTab(tab)){
2017-06-17 00:48:49 +02:00
for(int j = 0; j < ALL_RINGS.length; j++){
list.add(new ItemStack(this, 1, j));
ItemStack full = new ItemStack(this, 1, j);
setStoredBlaze(full, MAX_BLAZE);
list.add(full);
}
2015-03-31 20:37:55 +02:00
}
}
@Override
protected void registerRendering(){
2016-06-17 23:50:38 +02:00
for(int i = 0; i < ALL_RINGS.length; i++){
2018-05-10 11:38:58 +02:00
ActuallyAdditions.PROXY.addRenderRegister(new ItemStack(this, 1, i), this.getRegistryName(), "inventory");
}
}
2016-03-19 15:10:20 +01:00
@Override
@SideOnly(Side.CLIENT)
2017-02-13 23:17:08 +01:00
public IItemColor getItemColor(){
2016-03-19 15:10:20 +01:00
return new IItemColor(){
@Override
2017-11-16 00:11:17 +01:00
public int colorMultiplier(ItemStack stack, int tintIndex){
2016-06-17 23:50:38 +02:00
return stack.getItemDamage() >= ALL_RINGS.length ? 0xFFFFFF : ALL_RINGS[stack.getItemDamage()].color;
2016-03-19 15:10:20 +01:00
}
};
}
@Override
public boolean update(ItemStack stack, TileEntity tile, int elapsedTicks){
boolean advanced = ((ItemPotionRing)stack.getItem()).isAdvanced;
int range = advanced ? 48 : 16;
List<EntityLivingBase> entities = tile.getWorld().getEntitiesWithinAABB(EntityLivingBase.class, new AxisAlignedBB(tile.getPos().getX()-range, tile.getPos().getY()-range, tile.getPos().getZ()-range, tile.getPos().getX()+range, tile.getPos().getY()+range, tile.getPos().getZ()+range));
if(entities != null && !entities.isEmpty()){
if(advanced){
//Give all entities the effect
for(EntityLivingBase entity : entities){
this.effectEntity(entity, stack, true);
}
return true;
}
else{
Potion potion = Potion.getPotionById(ThePotionRings.values()[stack.getItemDamage()].effectID);
for(EntityLivingBase entity : entities){
if(entity.isPotionActive(potion)){
//Sometimes make the effect switch to someone else
2016-11-02 19:36:32 +01:00
if(tile.getWorld().rand.nextInt(100) <= 0){
entity.removePotionEffect(potion);
break;
}
else{
//Continue giving the entity that already has the potion effect the effect
//Otherwise, it will randomly switch around to other entities
this.effectEntity(entity, stack, true);
return true;
}
}
}
//Give the effect to someone new if no one had it or it randomly switched
Collections.shuffle(entities);
this.effectEntity(entities.get(0), stack, true);
return true;
}
}
return false;
}
@Override
public int getUsePerTick(ItemStack stack, TileEntity tile, int elapsedTicks){
return 325;
}
private boolean effectEntity(EntityLivingBase thePlayer, ItemStack stack, boolean canUseBasic){
ThePotionRings effect = ThePotionRings.values()[stack.getItemDamage()];
Potion potion = Potion.getPotionById(effect.effectID);
PotionEffect activeEffect = thePlayer.getActivePotionEffect(potion);
if(!effect.needsWaitBeforeActivating || (activeEffect == null || activeEffect.getDuration() <= 1)){
if(!((ItemPotionRing)stack.getItem()).isAdvanced){
if(canUseBasic){
thePlayer.addPotionEffect(new PotionEffect(potion, effect.activeTime, effect.normalAmplifier, true, false));
return true;
}
}
else{
thePlayer.addPotionEffect(new PotionEffect(potion, effect.activeTime, effect.advancedAmplifier, true, false));
return true;
}
}
return false;
}
@Override
2017-06-17 00:48:49 +02:00
public void addInformation(ItemStack stack, @Nullable World playerIn, List<String> tooltip, ITooltipFlag advanced){
super.addInformation(stack, playerIn, tooltip, advanced);
2018-05-10 11:38:58 +02:00
tooltip.add(String.format("%d/%d %s", getStoredBlaze(stack), MAX_BLAZE, StringUtil.localize("item."+ActuallyAdditions.MODID+".item_misc_ring.storage")));
}
2015-03-31 20:37:55 +02:00
}