mirror of
https://github.com/Auxilor/Reforges.git
synced 2026-01-04 15:41:40 +00:00
Added EffectDurabilityMultiplier
This commit is contained in:
@@ -6,6 +6,7 @@ import com.google.common.collect.ImmutableList;
|
||||
import com.willfp.reforges.effects.effects.EffectAttackSpeedMultiplier;
|
||||
import com.willfp.reforges.effects.effects.EffectCritMultiplier;
|
||||
import com.willfp.reforges.effects.effects.EffectDamageMultiplier;
|
||||
import com.willfp.reforges.effects.effects.EffectDurabilityMultiplier;
|
||||
import com.willfp.reforges.effects.effects.EffectIncomingDamageMultiplier;
|
||||
import com.willfp.reforges.effects.effects.EffectKnockbackMultiplier;
|
||||
import com.willfp.reforges.effects.effects.EffectRewardBlockBreak;
|
||||
@@ -31,6 +32,7 @@ public class Effects {
|
||||
public static final Effect REWARD_BLOCK_BREAK = new EffectRewardBlockBreak();
|
||||
public static final Effect INCOMING_DAMAGE_MULTIPLIER = new EffectIncomingDamageMultiplier();
|
||||
public static final Effect ATTACK_SPEED_MULTIPLIER = new EffectAttackSpeedMultiplier();
|
||||
public static final Effect DURABILITY_MULTIPLIER = new EffectDurabilityMultiplier();
|
||||
|
||||
/**
|
||||
* Get effect matching id.
|
||||
|
||||
@@ -1,14 +1,30 @@
|
||||
package com.willfp.reforges.effects.effects
|
||||
|
||||
import com.willfp.eco.core.config.interfaces.JSONConfig
|
||||
import com.willfp.eco.util.NumberUtils
|
||||
import com.willfp.reforges.effects.Effect
|
||||
import org.bukkit.event.player.PlayerItemDamageEvent
|
||||
import kotlin.math.ceil
|
||||
|
||||
class EffectDurabilityMultiplier : Effect("damage_multiplier") {
|
||||
class EffectDurabilityMultiplier : Effect("durability_multiplier") {
|
||||
override fun onDurabilityDamage(
|
||||
event: PlayerItemDamageEvent,
|
||||
config: JSONConfig
|
||||
) {
|
||||
val multiplier = config.getDouble("multiplier")
|
||||
if (multiplier == 0.0) {
|
||||
event.isCancelled = true
|
||||
return
|
||||
}
|
||||
|
||||
if (multiplier < 1) {
|
||||
event.damage *= ceil(1 / multiplier).toInt()
|
||||
return
|
||||
}
|
||||
|
||||
val chance = 1 - (1 / multiplier)
|
||||
if (NumberUtils.randFloat(0.0, 1.0) < chance) {
|
||||
event.isCancelled = true
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user