forked from TAIGA/TAIGA
Fixed events showing up on every tool, instead on tool with trait. Also balanced new traits to be more useful, but with a small restriction.
This commit is contained in:
@@ -2,14 +2,23 @@ package com.sosnitzka.ztic_addon.util.traits;
|
|||||||
|
|
||||||
import net.minecraft.entity.item.EntityItem;
|
import net.minecraft.entity.item.EntityItem;
|
||||||
import net.minecraft.entity.monster.EntityMob;
|
import net.minecraft.entity.monster.EntityMob;
|
||||||
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
|
import net.minecraft.init.Blocks;
|
||||||
import net.minecraft.init.Items;
|
import net.minecraft.init.Items;
|
||||||
|
import net.minecraft.item.Item;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.util.text.TextFormatting;
|
import net.minecraft.util.text.TextFormatting;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
import net.minecraftforge.common.MinecraftForge;
|
import net.minecraftforge.common.MinecraftForge;
|
||||||
import net.minecraftforge.event.entity.living.LivingDropsEvent;
|
import net.minecraftforge.event.entity.living.LivingDropsEvent;
|
||||||
|
import net.minecraftforge.event.world.BlockEvent;
|
||||||
import net.minecraftforge.fml.common.eventhandler.SubscribeEvent;
|
import net.minecraftforge.fml.common.eventhandler.SubscribeEvent;
|
||||||
import slimeknights.tconstruct.library.traits.AbstractTrait;
|
import slimeknights.tconstruct.library.traits.AbstractTrait;
|
||||||
|
import slimeknights.tconstruct.library.utils.TagUtil;
|
||||||
|
import slimeknights.tconstruct.library.utils.TinkerUtil;
|
||||||
|
import slimeknights.tconstruct.library.utils.ToolHelper;
|
||||||
|
|
||||||
|
import static com.sosnitzka.ztic_addon.Items.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Created by Robert on 03.06.2016.
|
* Created by Robert on 03.06.2016.
|
||||||
@@ -24,11 +33,49 @@ public class TraitGarishly extends AbstractTrait {
|
|||||||
@SubscribeEvent
|
@SubscribeEvent
|
||||||
public void onMobDrops(LivingDropsEvent event) {
|
public void onMobDrops(LivingDropsEvent event) {
|
||||||
World w = event.getEntity().getEntityWorld();
|
World w = event.getEntity().getEntityWorld();
|
||||||
if (!w.isRemote && event.getEntity() instanceof EntityMob) {
|
if (event.getSource().getEntity() instanceof EntityPlayer) {
|
||||||
event.getDrops().add(0, new EntityItem(w, event.getEntity().posX, event.getEntity().posY, event.getEntity().posZ, new ItemStack(Items.BLAZE_POWDER, random.nextInt(3) + 1)));
|
EntityPlayer player = (EntityPlayer) event.getSource().getEntity();
|
||||||
|
if (!w.isRemote && event.getEntity() instanceof EntityMob && TinkerUtil.hasTrait(TagUtil.getTagSafe(player.getHeldItemMainhand()), identifier)) {
|
||||||
|
|
||||||
|
int r = random.nextInt(5);
|
||||||
|
ItemStack i = null;
|
||||||
|
switch (r) {
|
||||||
|
case 0:
|
||||||
|
i = new ItemStack(Items.BLAZE_POWDER, random.nextInt(3) + 1);
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
i = new ItemStack(Items.BLAZE_ROD, random.nextInt(2) + 1);
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
i = new ItemStack(glimmerstone_dust, random.nextInt(3));
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
i = new ItemStack(luminar_dust, random.nextInt(3));
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
i = new ItemStack(Items.COAL, random.nextInt(3) + 1);
|
||||||
|
break;
|
||||||
|
case 5:
|
||||||
|
i = new ItemStack(lignite, random.nextInt(3) + 1);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
event.getDrops().add(0, new EntityItem(w, event.getEntity().posX, event.getEntity().posY, event.getEntity().posZ, i));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void blockHarvestDrops(ItemStack tool, BlockEvent.HarvestDropsEvent event) {
|
||||||
|
int i = random.nextInt(10);
|
||||||
|
if (i == 9) event.getDrops().clear();
|
||||||
|
else if (i == 2 || i == 1 || i == 3) {
|
||||||
|
ItemStack stack = new ItemStack(Item.getItemFromBlock(event.getWorld().getBlockState(event.getPos()).getBlock()), i);
|
||||||
|
event.getDrops().add(0, stack);
|
||||||
|
ToolHelper.damageTool(tool, i * 2, event.getHarvester());
|
||||||
|
} else if (i == 0) event.getWorld().setBlockState(event.getPos(), Blocks.LAVA.getDefaultState());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -4,8 +4,7 @@ import net.minecraft.item.ItemStack;
|
|||||||
import net.minecraft.util.text.TextFormatting;
|
import net.minecraft.util.text.TextFormatting;
|
||||||
import net.minecraftforge.common.MinecraftForge;
|
import net.minecraftforge.common.MinecraftForge;
|
||||||
import net.minecraftforge.event.entity.player.PlayerEvent;
|
import net.minecraftforge.event.entity.player.PlayerEvent;
|
||||||
import net.minecraftforge.event.world.BlockEvent.HarvestDropsEvent;
|
import net.minecraftforge.event.world.BlockEvent;
|
||||||
import net.minecraftforge.fml.common.eventhandler.SubscribeEvent;
|
|
||||||
import slimeknights.tconstruct.library.traits.AbstractTrait;
|
import slimeknights.tconstruct.library.traits.AbstractTrait;
|
||||||
import slimeknights.tconstruct.library.utils.ToolHelper;
|
import slimeknights.tconstruct.library.utils.ToolHelper;
|
||||||
|
|
||||||
@@ -30,14 +29,15 @@ public class TraitPulverizing extends AbstractTrait {
|
|||||||
int durability = ToolHelper.getCurrentDurability(tool);
|
int durability = ToolHelper.getCurrentDurability(tool);
|
||||||
int maxDurability = ToolHelper.getMaxDurability(tool);
|
int maxDurability = ToolHelper.getMaxDurability(tool);
|
||||||
float speed = ToolHelper.getMiningSpeedStat(tool);
|
float speed = ToolHelper.getMiningSpeedStat(tool);
|
||||||
return (speed / 3) / (maxDurability - 100) * (durability) + 0.5f;
|
return speed * (maxDurability - maxDurability / 10) / (durability);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@SubscribeEvent
|
@Override
|
||||||
public void onBlockBreak(HarvestDropsEvent event) {
|
public void blockHarvestDrops(ItemStack tool, BlockEvent.HarvestDropsEvent event) {
|
||||||
event.getDrops().clear();
|
if (random.nextFloat() < 0.9) {
|
||||||
|
event.getDrops().clear();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user