summaryrefslogtreecommitdiff
path: root/src/main/java/fyresmodjam/blessings/standard/MinerBlessing.java
diff options
context:
space:
mode:
authorBenjamin Culkin <scorpress@gmail.com>2024-08-12 17:08:54 -0400
committerBenjamin Culkin <scorpress@gmail.com>2024-08-12 17:08:54 -0400
commitb8b41aa5846dae5a9bbf4fee82020f1d9e2b2a48 (patch)
tree9bce3e85926cfb68b3ebbc5d89f13ce10736e32d /src/main/java/fyresmodjam/blessings/standard/MinerBlessing.java
Initial commitHEADtrunk
Diffstat (limited to 'src/main/java/fyresmodjam/blessings/standard/MinerBlessing.java')
-rw-r--r--src/main/java/fyresmodjam/blessings/standard/MinerBlessing.java61
1 files changed, 61 insertions, 0 deletions
diff --git a/src/main/java/fyresmodjam/blessings/standard/MinerBlessing.java b/src/main/java/fyresmodjam/blessings/standard/MinerBlessing.java
new file mode 100644
index 0000000..f261faa
--- /dev/null
+++ b/src/main/java/fyresmodjam/blessings/standard/MinerBlessing.java
@@ -0,0 +1,61 @@
+package fyresmodjam.blessings.standard;
+
+import fyresmodjam.blessings.Blessing;
+import net.minecraft.block.material.Material;
+import net.minecraft.entity.EntityLivingBase;
+import net.minecraft.item.ItemStack;
+import net.minecraft.item.ItemTool;
+import net.minecraft.util.EnumHand;
+import net.minecraftforge.event.entity.living.LivingHurtEvent;
+import net.minecraftforge.event.entity.player.PlayerEvent.BreakSpeed;
+
+public class MinerBlessing extends Blessing {
+ @Override
+ public String name() {
+ return "Miner";
+ }
+
+ @Override
+ public String description() {
+ return "Increased breaking speed on stone and iron blocks, and increased damage with pickaxes";
+ }
+
+ @Override
+ public void checkBreakSpeed(BreakSpeed pebsev) {
+ if (pebsev.getState().getMaterial() == Material.ROCK
+ || pebsev.getState()
+ .getMaterial() == Material.IRON) {
+ pebsev.setNewSpeed(
+ pebsev.getOriginalSpeed() * 1.25F);
+ }
+ }
+
+ @Override
+ public float onOutgoingDamage(LivingHurtEvent event,
+ float damageMultiplier) {
+ ItemStack held = null;
+
+ if (event.getSource()
+ .getTrueSource() instanceof EntityLivingBase) {
+ held = ((EntityLivingBase) event.getSource()
+ .getTrueSource()).getHeldItem(
+ EnumHand.MAIN_HAND);
+ }
+
+ if (held != null && itemIsPickaxe(held)) {
+ return damageMultiplier + 0.2F;
+ }
+
+ return damageMultiplier;
+ }
+
+ private boolean itemIsPickaxe(ItemStack held) {
+ if (held.getItem() instanceof ItemTool) {
+ return ((ItemTool) held.getItem())
+ .getToolClasses(held)
+ .contains("pickaxe");
+ }
+
+ return false;
+ }
+}