diff options
author | hannibal2 <24389977+hannibal00212@users.noreply.github.com> | 2023-02-16 17:09:13 +0100 |
---|---|---|
committer | hannibal2 <24389977+hannibal00212@users.noreply.github.com> | 2023-02-16 17:09:13 +0100 |
commit | 04cc6b44e2e433f25dd38bc709a2e652b2a693c9 (patch) | |
tree | b6926c001b552c273bb22db264080786e379ff22 /src/main/java/at/hannibal2/skyhanni | |
parent | cb4fa47b4120dd8c18cbef01d673c051dd883ce8 (diff) | |
download | skyhanni-04cc6b44e2e433f25dd38bc709a2e652b2a693c9.tar.gz skyhanni-04cc6b44e2e433f25dd38bc709a2e652b2a693c9.tar.bz2 skyhanni-04cc6b44e2e433f25dd38bc709a2e652b2a693c9.zip |
Fixed bug with particles that blocks NotEnoughUpdates' Fishing features.
Diffstat (limited to 'src/main/java/at/hannibal2/skyhanni')
-rw-r--r-- | src/main/java/at/hannibal2/skyhanni/events/ReceiveParticleEvent.kt | 6 | ||||
-rw-r--r-- | src/main/java/at/hannibal2/skyhanni/features/misc/ParticleHider.kt | 20 |
2 files changed, 19 insertions, 7 deletions
diff --git a/src/main/java/at/hannibal2/skyhanni/events/ReceiveParticleEvent.kt b/src/main/java/at/hannibal2/skyhanni/events/ReceiveParticleEvent.kt index 22c15606c..07cbd72fb 100644 --- a/src/main/java/at/hannibal2/skyhanni/events/ReceiveParticleEvent.kt +++ b/src/main/java/at/hannibal2/skyhanni/events/ReceiveParticleEvent.kt @@ -1,5 +1,6 @@ package at.hannibal2.skyhanni.events +import at.hannibal2.skyhanni.utils.LocationUtils import at.hannibal2.skyhanni.utils.LorenzVec import net.minecraft.util.EnumParticleTypes import net.minecraftforge.fml.common.eventhandler.Cancelable @@ -13,4 +14,7 @@ class ReceiveParticleEvent( val offset: LorenzVec, val longDistance: Boolean, val particleArgs: IntArray -) : LorenzEvent()
\ No newline at end of file +) : + LorenzEvent() { + val distanceToPlayer by lazy { location.distance(LocationUtils.playerLocation()) } +}
\ No newline at end of file diff --git a/src/main/java/at/hannibal2/skyhanni/features/misc/ParticleHider.kt b/src/main/java/at/hannibal2/skyhanni/features/misc/ParticleHider.kt index 1f4eda9a5..ad0a02453 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/misc/ParticleHider.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/misc/ParticleHider.kt @@ -2,7 +2,9 @@ package at.hannibal2.skyhanni.features.misc import at.hannibal2.skyhanni.SkyHanniMod import at.hannibal2.skyhanni.events.ReceiveParticleEvent -import at.hannibal2.skyhanni.utils.LocationUtils +import at.hannibal2.skyhanni.utils.getLorenzVec +import net.minecraft.client.Minecraft +import net.minecraft.entity.projectile.EntitySmallFireball import net.minecraft.util.EnumParticleTypes import net.minecraftforge.fml.common.eventhandler.SubscribeEvent @@ -10,9 +12,9 @@ class ParticleHider { @SubscribeEvent fun onHypExplosions(event: ReceiveParticleEvent) { - val distance = event.location.distance(LocationUtils.playerLocation()) + val distanceToPlayer = event.distanceToPlayer if (SkyHanniMod.feature.misc.hideFarParticles) { - if (distance > 40) { + if (distanceToPlayer > 40) { event.isCanceled = true return } @@ -21,7 +23,7 @@ class ParticleHider { val type = event.type if (SkyHanniMod.feature.misc.hideCloseRedstoneparticles) { if (type == EnumParticleTypes.REDSTONE) { - if (distance < 2) { + if (distanceToPlayer < 2) { event.isCanceled = true return } @@ -30,8 +32,14 @@ class ParticleHider { if (SkyHanniMod.feature.misc.hideFireballParticles) { if (type == EnumParticleTypes.SMOKE_NORMAL || type == EnumParticleTypes.SMOKE_LARGE) { - event.isCanceled = true - return + for (entity in Minecraft.getMinecraft().theWorld.loadedEntityList.toMutableList()) { + if (entity !is EntitySmallFireball) continue + val distance = entity.getLorenzVec().distance(event.location) + if (distance < 5) { + event.isCanceled = true + return + } + } } } } |